annotate src/emodules.c @ 3018:31e656a27dae

[xemacs-hg @ 2005-10-24 20:39:38 by malcolmp] Reflect changes in configure options in INSTALL and the FAQ.
author malcolmp
date Mon, 24 Oct 2005 20:39:47 +0000
parents ecf1ebac70d8
children 383ab474a241
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 /* emodules.c - Support routines for dynamic module loading
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2 (C) Copyright 1998, 1999 J. Kean Johnston. All rights reserved.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
3
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
4 This file is part of XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
5
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
6 XEmacs is free software; you can redistribute it and/or modify it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7 under the terms of the GNU General Public License as published by the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8 Free Software Foundation; either version 2, or (at your option) any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
9 later version.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
10
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
14 for more details.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
15
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
20
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21 #include "emodules.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22 #include "sysdll.h"
2078
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
23 #ifdef HAVE_LTDL
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
24 #include <ltdl.h>
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
25 #endif
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
26
1750
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
27 /* Load path */
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
28 static Lisp_Object Vmodule_load_path;
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
29
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
30 /* Module lFile extensions */
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
31 static Lisp_Object Vmodule_extensions;
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
32
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 #ifdef HAVE_SHLIB
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 /* CE-Emacs version number */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
36 Lisp_Object Vmodule_version;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
37
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
38 /* Do we do our work quietly? */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39 int load_modules_quietly;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
41 /* Set this while unloading a module. This should NOT be made set by users,
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
42 as it allows the unbinding of symbol-value-forward variables. */
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
43 int unloading_module;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
44
564
001628b7a5b3 [xemacs-hg @ 2001-05-24 09:37:25 by yoshiki]
yoshiki
parents: 563
diff changeset
45 Lisp_Object Qdll_error;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
46 Lisp_Object Qmodule, Qunload_module, module_tag;
564
001628b7a5b3 [xemacs-hg @ 2001-05-24 09:37:25 by yoshiki]
yoshiki
parents: 563
diff changeset
47
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
48 typedef struct _emodules_list
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
49 {
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
50 int used; /* Is this slot used? */
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
51 CIbyte *soname; /* Name of the shared object loaded (full path) */
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
52 CIbyte *modname; /* The name of the module */
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
53 CIbyte *modver; /* The module version string */
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
54 CIbyte *modtitle; /* How the module announces itself */
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
55 void (*unload)(void); /* Module cleanup function to run before unloading */
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
56 dll_handle dlhandle; /* Dynamic lib handle */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
57 } emodules_list;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
58
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
59 static int emodules_depth;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
60 static dll_handle dlhandle;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
61 static emodules_list *modules;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
62 static int modnum;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
63
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
64 static int find_make_module (const CIbyte *mod, const CIbyte *name,
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
65 const CIbyte *ver, int make_or_find);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 static Lisp_Object module_load_unwind (Lisp_Object);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67 static void attempt_module_delete (int mod);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
68
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 DEFUN ("load-module", Fload_module, 1, 3, "FLoad dynamic module: ", /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70 Load in a C Emacs Extension module named FILE.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 The optional NAME and VERSION are used to identify specific modules.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
73 DO NOT USE THIS FUNCTION in your programs. Use `require' instead.
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
74
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 This function is similar in intent to `load' except that it loads in
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 pre-compiled C or C++ code, using dynamic shared objects. If NAME is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 specified, then the module is only loaded if its internal name matches
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 the NAME specified. If VERSION is specified, then the module is only
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 loaded if it matches that VERSION. This function will check to make
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 sure that the same module is not loaded twice. Modules are searched
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81 for in the same way as Lisp files, except that the valid file
1632
64eaceca611d [xemacs-hg @ 2003-08-19 02:07:03 by james]
james
parents: 1381
diff changeset
82 extensions are `.so', `.dll', `.ell', or `.dylib'.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 All symbols in the shared module must be completely resolved in order
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 for this function to be successful. Any modules which the specified
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
86 FILE depends on will be automatically loaded. You can determine which
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
87 modules have been loaded as dynamic shared objects by examining the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 return value of the function `list-modules'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
90 It is possible, although unwise, to unload modules using `unload-feature'.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
91 The preferred mechanism for unloading or reloading modules is to quit
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 XEmacs, and then reload those new or changed modules that are required.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 Messages informing you of the progress of the load are displayed unless
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95 the variable `load-modules-quietly' is non-NIL.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 */
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
97 (file, name, version))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
98 {
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
99 CIbyte *mod, *mname, *mver;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
100 int speccount = specpdl_depth();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102 CHECK_STRING(file);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
104 mod = (CIbyte *) XSTRING_DATA (file);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 if (NILP (name))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 mname = "";
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 else
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
109 mname = (CIbyte *) XSTRING_DATA (name);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111 if (NILP (version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 mver = "";
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 else
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
114 mver = (CIbyte *) XSTRING_DATA (version);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 dlhandle = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
117 record_unwind_protect (module_load_unwind, make_int(modnum));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118 emodules_load (mod, mname, mver);
771
943eaba38521 [xemacs-hg @ 2002-03-13 08:51:24 by ben]
ben
parents: 665
diff changeset
119 unbind_to (speccount);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
120
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 return Qt;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
124 DEFUN ("unload-module", Funload_module, 1, 3, 0, /*
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
125 Unload a module previously loaded with load-module.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
127 DO NOT USE THIS FUNCTION in your programs. Use `unload-feature' instead.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 As with load-module, this function requires at least the module FILE, and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 optionally the module NAME and VERSION to unload. It may not be possible
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131 for the module to be unloaded from memory, as there may be Lisp objects
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
132 referring to variables inside the module code. However, once you have
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
133 requested a module to be unloaded, it will be unloaded from memory as
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134 soon as the last reference to symbols within the module is destroyed.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
135 */
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
136 (file, name, version))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
137 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
138 int x;
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
139 CIbyte *mod, *mname, *mver;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
140 Lisp_Object foundname = Qnil;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
141 struct gcpro gcpro1;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
142
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
143 CHECK_STRING(file);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
144
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
145 GCPRO1 (foundname);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
146 if (locate_file (Vmodule_load_path, file, Vmodule_extensions, &foundname, 0)
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
147 < 0)
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
148 return Qt;
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
149 mod = (CIbyte *) XSTRING_DATA (foundname);
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
150 UNGCPRO;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
151
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
152 if (NILP (name))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
153 mname = "";
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
154 else
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
155 mname = (CIbyte *) XSTRING_DATA (name);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
156
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157 if (NILP (version))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158 mver = "";
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 else
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
160 mver = (CIbyte *) XSTRING_DATA (version);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
162 x = find_make_module (mod, mname, mver, 1);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163 if (x != -1)
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
164 {
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
165 if (modules[x].unload != NULL)
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
166 modules[x].unload ();
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
167 attempt_module_delete (x);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
168 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169 return Qt;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
170 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
171
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
172 DEFUN ("list-modules", Flist_modules, 0, 0, "", /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 Produce a list of loaded dynamic modules.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
174
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
175 This function will return a list of all the loaded dynamic modules.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
176 Each element in the list is a list in the form (SONAME NAME VER DESC),
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
177 where SONAME is the name of the shared object that was loaded, NAME
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
178 is the internal module name, VER is the version of the module, and DESC
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
179 is how the module describes itself.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
180
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
181 This function returns a list, so you will need to assign the return value
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
182 to a variable and then examine the variable with `describe-variable'.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
183 For example:
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
184
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
185 (setq mylist (list-modules))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
186 (describe-variable 'mylist)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
187
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
188
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
189 NOTE: It is possible for the same module to be loaded more than once,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
190 at different versions. However, you should never see the same module,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
191 with the same name and version, loaded more than once. If you do, this
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
192 is a bug, and you are encouraged to report it.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
193 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
194 ())
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
195 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
196 Lisp_Object mlist = Qnil;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
197 int i;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
198
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
199 for (i = 0; i < modnum; i++)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
200 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
201 if (modules[i].used == 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
202 mlist = Fcons (list4 (build_string (modules[i].soname),
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
203 build_string (modules[i].modname),
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
204 build_string (modules[i].modver),
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
205 build_string (modules[i].modtitle)), mlist);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
206 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
207
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
208 return mlist;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
209 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
210
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
211 static int
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
212 find_make_module (const CIbyte *mod, const CIbyte *name, const CIbyte *ver,
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
213 int mof)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
214 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
215 int i, fs = -1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
216
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
217 for (i = 0; i < modnum; i++)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
218 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
219 if (fs == -1 && modules[i].used == 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
220 fs = i;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
221 if (strcmp (modules[i].soname, mod) == 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
222 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
223 if (name && name[0] && strcmp (modules[i].modname, name))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
224 continue;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
225 if (ver && ver[0] && strcmp (modules[i].modver, ver))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
226 continue;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
227 return i; /* Found a match */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
228 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
229 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
230
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
231 if (mof)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
232 return fs;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
233
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
234 if (fs != -1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
235 return fs; /* First free slot */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
236
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
237 /*
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
238 * We only get here if we haven't found a free slot and the module was
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
239 * not previously loaded.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
240 */
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
241 if (modules == NULL)
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2078
diff changeset
242 modules = xnew (emodules_list);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
243 modnum++;
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2078
diff changeset
244 XREALLOC_ARRAY (modules, emodules_list, modnum);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
245
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
246 fs = modnum - 1;
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2078
diff changeset
247 memset (&modules[fs], 0, sizeof (emodules_list));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
248 return fs;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
249 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
250
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
251 static void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
252 attempt_module_delete (int mod)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
253 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
254 if (dll_close (modules[mod].dlhandle) == 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
255 {
1726
a8d8f419b459 [xemacs-hg @ 2003-09-30 15:26:34 by james]
james
parents: 1706
diff changeset
256 xfree (modules[mod].soname, CIbyte *);
a8d8f419b459 [xemacs-hg @ 2003-09-30 15:26:34 by james]
james
parents: 1706
diff changeset
257 xfree (modules[mod].modname, CIbyte *);
a8d8f419b459 [xemacs-hg @ 2003-09-30 15:26:34 by james]
james
parents: 1706
diff changeset
258 xfree (modules[mod].modver, CIbyte *);
a8d8f419b459 [xemacs-hg @ 2003-09-30 15:26:34 by james]
james
parents: 1706
diff changeset
259 xfree (modules[mod].modtitle, CIbyte *);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
260 modules[mod].dlhandle = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
261 modules[mod].used = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
262 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263 else if (modules[mod].used > 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
264 modules[mod].used = 1; /* We couldn't delete it - it stays */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
267 static Lisp_Object
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 module_load_unwind (Lisp_Object upto)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
270 int x,l=0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
271
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
272 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
273 * First close off the current handle if it is open.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
274 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
275 if (dlhandle != 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
276 dll_close (dlhandle);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
277 dlhandle = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
278
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
279 if (CONSP (upto))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
280 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
281 if (INTP (XCAR (upto)))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
282 l = XINT (XCAR (upto));
853
2b6fa2618f76 [xemacs-hg @ 2002-05-28 08:44:22 by ben]
ben
parents: 851
diff changeset
283 free_cons (upto);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
284 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
285 else
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
286 l = XINT (upto);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
287
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
288 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
289 * Here we need to go through and dlclose() (IN REVERSE ORDER!) any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
290 * modules that were loaded as part of this load chain. We only mark
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
291 * the slots as closed if the dlclose() succeeds.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
292 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
293 for (x = modnum-1; x >= l; x--)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
294 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
295 if (modules[x].used > 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
296 attempt_module_delete (x);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
297 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
298 emodules_depth = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
299
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
300 return Qnil;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
301 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
302
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
303 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
304 * Do the actual grunt-work of loading in a module. We first try and
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
305 * dlopen() the module. If that fails, we have an error and we bail
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
306 * out immediately. If the dlopen() succeeds, we need to check for the
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
307 * existence of certain special symbols.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
308 *
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
309 * All modules will have complete access to the variables and functions
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
310 * defined within XEmacs itself. It is up to the module to declare any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
311 * variables or functions it uses, however. Modules will also have access
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
312 * to other functions and variables in other loaded modules, unless they
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
313 * are defined as STATIC.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
314 *
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
315 * We need to be very careful with how we load modules. If we encounter an
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
316 * error along the way, we need to back out completely to the point at
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
317 * which the user started. Since we can be called recursively, we need to
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
318 * take care with marking modules as loaded. When we first start loading
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
319 * modules, we set the counter to zero. As we enter the function each time,
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
320 * we increment the counter, and before we leave we decrement it. When
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
321 * we get back down to 0, we know we are at the end of the chain and we
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
322 * can mark all the modules in the list as loaded.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
323 *
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
324 * When we signal an error, we need to be sure to unwind all modules loaded
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
325 * thus far (but only for this module chain). It is assumed that if any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
326 * modules in a chain fail, then they all do. This is logical, considering
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
327 * that the only time we recurse is when we have dependent modules. So in
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
328 * the error handler we take great care to close off the module chain before
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
329 * we call "error" and let the Fmodule_load unwind_protect() function handle
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
330 * the cleaning up.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
331 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
332 void
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
333 emodules_load (const CIbyte *module, const CIbyte *modname,
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
334 const CIbyte *modver)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
335 {
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2078
diff changeset
336 /* !!#### Needs serious work */
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
337 Lisp_Object old_load_list;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
338 Lisp_Object filename;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
339 Lisp_Object foundname, lisp_modname;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
340 int x, mpx;
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
341 CIbyte *soname;
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
342 const CIbyte **f;
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
343 const long *ellcc_rev;
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
344 CIbyte *mver, *mname, *mtitle, *symname;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
345 void (*modload)(void) = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
346 void (*modsyms)(void) = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
347 void (*modvars)(void) = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
348 void (*moddocs)(void) = 0;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
349 void (*modunld)(void) = 0;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
350 emodules_list *mp;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
351 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
352
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
353 filename = Qnil;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
354 foundname = Qnil;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
355
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
356 emodules_depth++;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
357 dlhandle = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
358
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
359 if (module == NULL || module[0] == '\0')
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
360 invalid_argument ("Empty module name", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
361
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
362 GCPRO4(filename, foundname, old_load_list, lisp_modname);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
363 filename = build_string (module);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
364 if (locate_file (Vmodule_load_path, filename, Vmodule_extensions,
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
365 &foundname, 0) < 0)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
366 signal_error (Qdll_error, "Cannot open dynamic module", filename);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
367
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
368 LISP_STRING_TO_EXTERNAL (foundname, soname, Qfile_name);
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
369 lisp_modname = call1 (Qfile_name_sans_extension,
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
370 Ffile_name_nondirectory (foundname));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
371
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
372 dlhandle = dll_open (foundname);
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
373 if (dlhandle == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
374 {
1811
3fe1a35b705d [xemacs-hg @ 2003-11-29 22:11:47 by james]
james
parents: 1750
diff changeset
375 signal_error (Qdll_error, "Opening dynamic module", dll_error ());
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
376 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
377
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
378 ellcc_rev = (const long *)dll_variable (dlhandle, "emodule_compiler");
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
379 if (ellcc_rev == NULL || *ellcc_rev <= 0L)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
380 signal_error (Qdll_error, "Invalid dynamic module: Missing symbol `emodule_compiler'", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
381 if (*ellcc_rev > EMODULES_REVISION)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
382 signal_ferror (Qdll_error, "Invalid dynamic module: Unsupported version `%ld(%ld)'", *ellcc_rev, EMODULES_REVISION);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
383
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
384 f = (const CIbyte **) dll_variable (dlhandle, "emodule_name");
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
385 if (f == NULL || *f == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
386 signal_error (Qdll_error, "Invalid dynamic module: Missing symbol `emodule_name'", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
387
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
388 mname = (CIbyte *) ALLOCA (strlen (*f) + 1);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
389 strcpy (mname, *f);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
390 if (mname[0] == '\0')
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
391 signal_error (Qdll_error, "Invalid dynamic module: Empty value for `emodule_name'", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
392
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
393 f = (const CIbyte **) dll_variable (dlhandle, "emodule_version");
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
394 if (f == NULL || *f == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
395 signal_error (Qdll_error, "Missing symbol `emodule_version': Invalid dynamic module", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
396
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
397 mver = (CIbyte *) ALLOCA (strlen (*f) + 1);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
398 strcpy (mver, *f);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
399
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
400 f = (const CIbyte **) dll_variable (dlhandle, "emodule_title");
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
401 if (f == NULL || *f == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
402 signal_error (Qdll_error, "Invalid dynamic module: Missing symbol `emodule_title'", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
403
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
404 mtitle = (CIbyte *) ALLOCA (strlen (*f) + 1);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
405 strcpy (mtitle, *f);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
406
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
407 symname = (CIbyte *) ALLOCA (strlen (mname) + 15);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
408
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
409 strcpy (symname, "modules_of_");
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
410 strcat (symname, mname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
411 modload = (void (*)(void))dll_function (dlhandle, symname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
412 /*
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
413 * modload is optional. If the module doesn't require other modules it can
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
414 * be left out.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
415 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
416
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
417 strcpy (symname, "syms_of_");
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
418 strcat (symname, mname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
419 modsyms = (void (*)(void))dll_function (dlhandle, symname);
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
420 if (modsyms == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
421 {
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
422 missing_symbol:
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
423 signal_error (Qdll_error, "Invalid dynamic module: Missing symbol",
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
424 build_string (symname));
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
425 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
426
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
427 strcpy (symname, "vars_of_");
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
428 strcat (symname, mname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
429 modvars = (void (*)(void))dll_function (dlhandle, symname);
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
430 if (modvars == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
431 goto missing_symbol;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
432
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
433 strcpy (symname, "docs_of_");
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
434 strcat (symname, mname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
435 moddocs = (void (*)(void))dll_function (dlhandle, symname);
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
436 if (moddocs == NULL)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
437 goto missing_symbol;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
438
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
439 /* Now look for the optional unload function. */
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
440 strcpy (symname, "unload_");
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
441 strcat (symname, mname);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
442 modunld = (void (*)(void))dll_function (dlhandle, symname);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
443
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
444 if (modname && modname[0] && strcmp (modname, mname))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
445 signal_error (Qdll_error, "Module name mismatch", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
446
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
447 if (modver && modver[0] && strcmp (modver, mver))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
448 signal_error (Qdll_error, "Module version mismatch", Qunbound);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
449
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
450 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
451 * Attempt to make a new slot for this module. If this really is the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
452 * first time we are loading this module, the used member will be 0.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
453 * If that is non-zero, we know that we have a previously loaded module
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
454 * of the same name and version, and we don't need to go any further.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
455 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
456 mpx = find_make_module (soname, mname, mver, 0);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
457 mp = &modules[mpx];
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
458 if (mp->used > 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
459 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
460 emodules_depth--;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
461 dll_close (dlhandle);
806
14089a93af0a [xemacs-hg @ 2002-04-05 10:52:06 by stephent]
stephent
parents: 771
diff changeset
462 dlhandle = 0; /* Zero this out before module_load_unwind runs */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
463 return;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
464 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
465
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
466 if (!load_modules_quietly)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
467 message ("Loading %s v%s (%s)", mname, mver, mtitle);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
468
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
469 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
470 * We have passed the basic initialization, and can now add this
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
471 * module to the list of modules.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
472 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
473 mp->used = emodules_depth + 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
474 mp->soname = xstrdup (soname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
475 mp->modname = xstrdup (mname);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
476 mp->modver = xstrdup (mver);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
477 mp->modtitle = xstrdup (mtitle);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
478 mp->dlhandle = dlhandle;
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
479 mp->unload = modunld;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
480 dlhandle = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
481
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
482 old_load_list = Vcurrent_load_list;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
483 Vcurrent_load_list = Qnil;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
484 LOADHIST_ATTACH (lisp_modname);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
485 LOADHIST_ATTACH (module_tag);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
486
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
487 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
488 * Now we need to call the module init function and perform the various
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
489 * startup tasks.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
490 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
491 if (modload != 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
492 (*modload)();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
493
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
494 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
495 * Now we can get the module to initialize its symbols, and then its
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
496 * variables, and lastly the documentation strings.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
497 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
498 (*modsyms)();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
499 (*modvars)();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
500 (*moddocs)();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
501
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
502 if (!load_modules_quietly)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
503 message ("Loaded module %s v%s (%s)", mname, mver, mtitle);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
504
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
505 Vload_history = Fcons (Fnreverse (Vcurrent_load_list), Vload_history);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
506 Vcurrent_load_list = old_load_list;
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
507 UNGCPRO;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
508
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
509 emodules_depth--;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
510 if (emodules_depth == 0)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
511 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
512 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
513 * We have reached the end of the load chain. We now go through the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
514 * list of loaded modules and mark all the valid modules as just
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
515 * that.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
516 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
517 for (x = 0; x < modnum; x++)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
518 if (modules[x].used > 1)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
519 modules[x].used = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
520 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
521 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
522
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
523 void
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
524 emodules_doc_subr(const char *symname, const char *doc)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
525 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
526 Bytecount len = strlen (symname);
867
804517e16990 [xemacs-hg @ 2002-06-05 09:54:39 by ben]
ben
parents: 853
diff changeset
527 Lisp_Object sym = oblookup (Vobarray, (const Ibyte *)symname, len);
440
8de8e3f6228a Import from CVS: tag r21-2-28
cvs
parents: 428
diff changeset
528 Lisp_Subr *subr;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
529
1632
64eaceca611d [xemacs-hg @ 2003-08-19 02:07:03 by james]
james
parents: 1381
diff changeset
530 /* Skip autoload cookies */
64eaceca611d [xemacs-hg @ 2003-08-19 02:07:03 by james]
james
parents: 1381
diff changeset
531 if (SYMBOLP (sym) && SUBRP (XSYMBOL (sym)->function))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
532 {
1632
64eaceca611d [xemacs-hg @ 2003-08-19 02:07:03 by james]
james
parents: 1381
diff changeset
533 subr = XSUBR (XSYMBOL (sym)->function);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
534 subr->doc = xstrdup (doc);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
535 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
536 /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
537 * FIXME: I wish there was some way to avoid the xstrdup(). Is it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
538 * possible to just set a pointer to the string, or somehow create a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
539 * symbol whose value we can point to the constant string? Can someone
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
540 * look into this?
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
541 */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
542 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
543
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
544 void
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
545 emodules_doc_sym (const char *symname, const char *doc)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
546 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
547 Bytecount len = strlen (symname);
867
804517e16990 [xemacs-hg @ 2002-06-05 09:54:39 by ben]
ben
parents: 853
diff changeset
548 Lisp_Object sym = oblookup (Vobarray, (const Ibyte *)symname, len);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
549 Lisp_Object docstr;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
550 struct gcpro gcpro1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
551
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
552 if (SYMBOLP(sym))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
553 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
554 docstr = build_string (doc);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
555 GCPRO1(docstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
556 Fput (sym, Qvariable_documentation, docstr);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
557 UNGCPRO;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
558 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
559 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
560
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
561
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
562 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
563 syms_of_module (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
564 {
564
001628b7a5b3 [xemacs-hg @ 2001-05-24 09:37:25 by yoshiki]
yoshiki
parents: 563
diff changeset
565 DEFERROR_STANDARD (Qdll_error, Qerror);
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
566 DEFSYMBOL (Qmodule);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
567 DEFSYMBOL (Qunload_module);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
568 DEFSUBR(Fload_module);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
569 DEFSUBR(Flist_modules);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
570 DEFSUBR(Funload_module);
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
571 module_tag = Fcons (Qmodule, Qnil);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
572 staticpro (&module_tag);
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
573 Fput (Qunload_module, Qdisabled, Qt);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
574 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
575
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
576 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
577 reinit_vars_of_module (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
578 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
579 emodules_depth = 0;
1706
9fc738581a9d [xemacs-hg @ 2003-09-22 03:21:12 by james]
james
parents: 1632
diff changeset
580 modules = NULL;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
581 modnum = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
582 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
583
1750
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
584 #endif /* HAVE_SHLIB */
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
585
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
586 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
587 vars_of_module (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
588 {
1750
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
589 #ifdef HAVE_SHLIB
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
590 Fprovide (intern ("modules"));
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
591
2078
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
592 #ifdef HAVE_LTDL
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
593 lt_dlinit ();
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
594 lt_dlmalloc = (lt_ptr (*) (size_t)) xmalloc;
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
595 lt_dlrealloc = (lt_ptr (*) (lt_ptr, size_t)) xrealloc;
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
596 lt_dlfree = (void (*) (lt_ptr)) xfree_1;
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
597 #endif
0bcc1e4dfd91 [xemacs-hg @ 2004-05-14 15:34:36 by james]
james
parents: 1811
diff changeset
598
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
599 DEFVAR_LISP ("module-version", &Vmodule_version /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
600 Emacs dynamic loading mechanism version, as a string.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
601
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
602 This string is in the form XX.YY.ppp, where XX is the major version
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
603 number, YY is the minor version number, and ppp is the patch level.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
604 This variable can be used to distinguish between different versions of
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
605 the dynamic loading technology used in Emacs, if required. It is not
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
606 a given that this value will be the same as the Emacs version number.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
607 */ );
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
608 Vmodule_version = build_string (EMODULES_VERSION);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
609
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
610 DEFVAR_BOOL ("load-modules-quietly", &load_modules_quietly /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
611 *Set to t if module loading is to be silent.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
612
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
613 Normally, when loading dynamic modules, Emacs will inform you of its
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
614 progress, and will display the module name and version if the module
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
615 is loaded correctly. Setting this variable to `t' will suppress these
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
616 messages. This would normally only be done if `load-module' was being
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
617 called by a Lisp function.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
618 */);
1733
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
619 load_modules_quietly = 0;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
620
1750
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
621 DEFVAR_BOOL ("unloading-module", &unloading_module /*
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
622 Used internally by `unload-feature'. Do not set this variable.
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
623 Danger, danger, Will Robinson!
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
624 */);
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
625 unloading_module = 0;
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
626
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
627 #endif /* HAVE_SHLIB */
7580e52a8218 [xemacs-hg @ 2003-10-15 03:09:02 by james]
james
parents: 1733
diff changeset
628
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
629 DEFVAR_LISP ("module-load-path", &Vmodule_load_path /*
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
630 *List of directories to search for dynamic modules to load.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
631 Each element is a string (directory name) or nil (try default directory).
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
632
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
633 Note that elements of this list *may not* begin with "~", so you must
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
634 call `expand-file-name' on them before adding them to this list.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
635
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
636 Initialized based on EMACSMODULEPATH environment variable, if any, otherwise
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
637 to default specified the file `paths.h' when XEmacs was built. If there
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
638 were no paths specified in `paths.h', then XEmacs chooses a default
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
639 value for this variable by looking around in the file-system near the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
640 directory in which the XEmacs executable resides.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
641
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
642 Due to the nature of dynamic modules, the path names should almost always
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
643 refer to architecture-dependent directories. It is unwise to attempt to
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 440
diff changeset
644 store dynamic modules in a heterogenous environment. Some environments
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
645 are similar enough to each other that XEmacs will be unable to determine
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
646 the correctness of a dynamic module, which can have unpredictable results
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
647 when a dynamic module is loaded.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
648 */);
1733
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
649 Vmodule_load_path = Qnil;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
650
1733
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
651 DEFVAR_LISP ("module-extensions", &Vmodule_extensions /*
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
652 *List of filename extensions to use when searching for dynamic modules.
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
653 */);
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
654 Vmodule_extensions = list5 (build_string (".ell"),
996
25e260cb7994 [xemacs-hg @ 2002-09-10 15:27:02 by james]
james
parents: 867
diff changeset
655 build_string (".so"),
1381
20547bbdcf1e [xemacs-hg @ 2003-03-25 23:09:53 by james]
james
parents: 996
diff changeset
656 build_string (".dll"),
1733
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
657 build_string (".dylib"),
5903b079bee1 [xemacs-hg @ 2003-10-07 21:52:12 by james]
james
parents: 1726
diff changeset
658 build_string (""));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
659 }