annotate src/glade.c @ 5118:e0db3c197671 ben-lisp-object

merge up to latest default branch, doesn't compile yet
author Ben Wing <ben@xemacs.org>
date Sat, 26 Dec 2009 21:18:49 -0600
parents db7068430402
children 304aebb79cd3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
1 /* glade.c
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
2 **
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
3 ** Description: Interface to `libglade' for XEmacs/GTK
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
4 **
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
5 ** Created by: William M. Perry <wmperry@gnu.org>
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
6 **
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
7 ** Copyright (C) 1999 John Harper <john@dcs.warwick.ac.uk>
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
8 ** Copyright (c) 2000 Free Software Foundation
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
9 **
4709
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
10 ** This file is part of XEmacs.
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
11 **
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
12 ** XEmacs is free software; you can redistribute it and/or modify it
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
13 ** under the terms of the GNU General Public License as published by the
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
14 ** Free Software Foundation; either version 2, or (at your option) any
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
15 ** later version.
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
16 **
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
17 ** XEmacs is distributed in the hope that it will be useful, but WITHOUT
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
18 ** ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
19 ** FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
20 ** for more details.
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
21 **
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
22 ** You should have received a copy of the GNU General Public License
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
23 ** along with XEmacs; see the file COPYING. If not, write to
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
24 ** the Free Software Foundation, Inc., 51 Franklin Street - Fifth Floor,
db7068430402 Add explicit GPL v2 or later notices to Bill Perry's code, where such notices
Jerry James <james@xemacs.org>
parents: 4677
diff changeset
25 ** Boston, MA 02111-1301, USA. */
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
26 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
27
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
28 #if defined(HAVE_GLADE_H) || defined(HAVE_GLADE_GLADE_H)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
29
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
30 /* For COMPILED_FUNCTIONP */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
31 #include "bytecode.h"
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
32
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
33 #ifdef HAVE_GLADE_GLADE_H
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
34 #include <glade/glade.h>
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
35 #endif
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
36
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
37 #ifdef HAVE_GLADE_H
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
38 #include <glade.h>
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
39 #endif
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
40
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
41 /* This is based on the code from rep-gtk 0.11 in libglade-support.c */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
42
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
43 static void
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
44 connector (const gchar *handler_name, GtkObject *object,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
45 const gchar *signal_name, const gchar *signal_data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
46 GtkObject *connect_object, gboolean after, gpointer user_data)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
47 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
48 Lisp_Object func;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
49 Lisp_Object lisp_data = Qnil;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
50
826
6728e641994e [xemacs-hg @ 2002-05-05 11:30:15 by ben]
ben
parents: 563
diff changeset
51 func = VOID_TO_LISP (user_data);
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
52
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
53 if (NILP (func))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
54 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
55 /* Look for a lisp function called HANDLER_NAME */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
56 func = intern (handler_name);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
57 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
58
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
59 if (signal_data && signal_data[0])
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
60 {
4677
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2054
diff changeset
61 lisp_data
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2054
diff changeset
62 = IGNORE_MULTIPLE_VALUES (Feval (Fread (build_string (signal_data))));
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
63 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
64
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
65 /* obj, name, func, cb_data, object_signal, after_p */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
66 Fgtk_signal_connect (build_gtk_object (object),
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
67 intern (signal_name),
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
68 func,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
69 lisp_data,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
70 connect_object ? Qt : Qnil,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
71 after ? Qt : Qnil);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
72 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
73
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
74 /* This differs from lisp/subr.el (functionp) definition by allowing
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
75 ** symbol names that may not necessarily be fboundp yet.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
76 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
77 static int __almost_functionp (Lisp_Object obj)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
78 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
79 return (SYMBOLP (obj) ||
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
80 SUBRP (obj) ||
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
81 COMPILED_FUNCTIONP (obj) ||
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
82 EQ (Fcar_safe (obj), Qlambda));
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
83 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
84
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
85 DEFUN ("glade-xml-signal-connect", Fglade_xml_signal_connect, 3, 3, 0, /*
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
86 Connect a glade handler.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
87 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
88 (xml, handler_name, func))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
89 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
90 CHECK_GTK_OBJECT (xml);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
91 CHECK_STRING (handler_name);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
92
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
93 if (!__almost_functionp (func))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
94 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
95 func = wrong_type_argument (intern ("functionp"), func);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
96 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
97
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
98 glade_xml_signal_connect_full (GLADE_XML (XGTK_OBJECT (xml)->object),
2054
91d4c8c65a0f [xemacs-hg @ 2004-05-02 04:06:51 by malcolmp]
malcolmp
parents: 826
diff changeset
99 (char*) XSTRING_DATA (handler_name),
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
100 connector, LISP_TO_VOID (func));
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
101 return (Qt);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
102 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
103
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
104 DEFUN ("glade-xml-signal-autoconnect", Fglade_xml_signal_autoconnect, 1, 1, 0, /*
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
105 Connect all glade handlers.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
106 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
107 (xml))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
108 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
109 CHECK_GTK_OBJECT (xml);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
110
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
111 glade_xml_signal_autoconnect_full (GLADE_XML (XGTK_OBJECT (xml)->object),
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
112 connector, LISP_TO_VOID (Qnil));
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
113 return (Qt);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
114 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
115
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
116 DEFUN ("glade-xml-textdomain", Fglade_xml_textdomain, 1, 1, 0, /*
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
117 Return the textdomain of a GladeXML object.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
118 */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
119 (xml))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
120 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
121 gchar *the_domain = NULL;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
122
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
123 CHECK_GTK_OBJECT (xml);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
124
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
125 if (!GLADE_IS_XML (XGTK_OBJECT (xml)->object))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
126 {
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 462
diff changeset
127 wtaerror ("Object is not a GladeXML type.", xml);
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
128 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
129
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
130 #ifdef LIBGLADE_XML_TXTDOMAIN
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
131 the_domain = GLADE_XML (XGTK_OBJECT (xml)->object)->txtdomain;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
132 #else
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
133 the_domain = GLADE_XML (XGTK_OBJECT (xml)->object)->textdomain;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
134 #endif
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
135 return (build_string (the_domain));
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
136 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
137
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
138 void syms_of_glade (void)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
139 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
140 DEFSUBR (Fglade_xml_signal_connect);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
141 DEFSUBR (Fglade_xml_signal_autoconnect);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
142 DEFSUBR (Fglade_xml_textdomain);
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
143 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
144
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
145 void vars_of_glade (void)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
146 {
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
147 Fprovide (intern ("glade"));
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
148 }
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
149
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
150 #else /* !(HAVE_GLADE_H || HAVE_GLADE_GLADE_H) */
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
151 #define syms_of_glade()
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
152 #define vars_of_glade()
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
153 #endif