changeset 2972:2b58b7fd831c

[xemacs-hg @ 2005-10-04 17:00:32 by stephent] Document build infra for modules distributed in core <871x31uslr.fsf@tleepslib.sk.tsukuba.ac.jp>
author stephent
date Tue, 04 Oct 2005 17:00:33 +0000
parents fb22a4eb2694
children 414a64af46c9
files man/ChangeLog man/emodules.texi
diffstat 2 files changed, 57 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/man/ChangeLog	Tue Oct 04 16:47:10 2005 +0000
+++ b/man/ChangeLog	Tue Oct 04 17:00:33 2005 +0000
@@ -1,3 +1,9 @@
+2005-10-04  Stephen J. Turnbull  <stephen@xemacs.org>
+
+	* emodules.texi (Distribution with XEmacs): New node describing
+	organization of module-related code in top-level configure.ac and
+	src/Makefile.in.in.
+
 2005-09-27  Adrian Aichner  <adrian@xemacs.org>
 
 	* lispref/compile.texi (Compilation Options): Lowercase SYMBOL
--- a/man/emodules.texi	Tue Oct 04 16:47:10 2005 +0000
+++ b/man/emodules.texi	Tue Oct 04 17:00:33 2005 +0000
@@ -124,6 +124,7 @@
 * Introduction::                Introducing Emacs Modules
 * Anatomy of a Module::         Basic module layout and technology
 * Using ellcc::                 How to use the module compiler
+* Distribution with XEmacs::    Adding your module to the distribution
 * Defining Functions::          Creating new Lisp primitives
 * Defining Variables::          Creating new Lisp variables
 * Index::                       Concept Index
@@ -497,7 +498,7 @@
 that library.  Otherwise, interactions between modules must take place
 via Lisp function calls and Lisp variables accesses.
 
-@node Using ellcc, Defining Functions, Anatomy of a Module, Top
+@node Using ellcc, Distribution with XEmacs, Anatomy of a Module, Top
 @chapter Using @code{ellcc}
 @cindex @code{ellcc}
 @cindex module compiler
@@ -822,7 +823,55 @@
 Used during the compile phase of @value{emacs} itself.
 @end table
 
-@node Defining Functions, Defining Variables, Using ellcc, Top
+@node Distribution with XEmacs, Defining Functions, Using ellcc, Top
+@chapter Adding Modules to the XEmacs Distribution
+@cindex XEmacs integration
+@cindex integration, XEmacs
+@cindex modules and configure.ac
+@cindex configure.ac, modules and
+@cindex modules and Makefiles
+@cindex Makefiles, modules and
+
+#### This section needs to be filled out.
+
+@strong{Warning: The procedure described in the section is subject to
+change, as it is very stylized and thus a good candidate for further
+automation.}
+
+Modules distributed with XEmacs are placed in the @file{modules}
+subdirectory of the root of the source tree.  Each module's code is
+placed in a separate subdirectory.  The build infrastructure for a
+module consists of a @file{Makefile.in.in}, a @file{configure.ac}, and
+@file{install-sh}.  @file{install-sh} is a constant, and may simply be
+copied from an existing module.
+
+Most of the job of building a module is encapsulated in
+@file{modules/common/Makefile.common} and in @file{ellcc}.  The module's
+@file{Makefile.in.in} normally needs only to define module name and
+version information, and include @file{modules/common/Makefile.common}.
+The @file{configure.ac} is very module-specific, and little can be said
+about its contents.  However, since no logic that depends on XEmacs
+itself or other modules needs to be present, it is easier to write and
+maintain than if it were contained in the XEmacs distribution's
+@file{configure.ac}.
+
+Modules can usually be trivially built in to the XEmacs binary.  To make
+this work, you need to duplicate the detection logic for any resources
+the module requires in the top-level @file{configure.ac}.  Since module
+objects may be linked into modules or into @file{xemacs}, instead of
+adding library path and library information directly to some
+@file{@var{subsystem}_libs} variable, you should add them to a
+@file{@var{module}_libs} variable, which in turn must be added to
+@code{ld_libs_module} in the section ``Compute SUBST-itutable variables.''
+
+Furthermore, in @file{src/Makefile.in.in} you add rules to build the
+object without the module wrapper, and conditionalize these and the
+addition of the object to @code{objs} on @code{HAVE_SHLIB}.  The right
+way to do this is somewhat indirect.  Study the integration of LDAP and
+PostgreSQL for the details.
+
+
+@node Defining Functions, Defining Variables, Distribution with XEmacs, Top
 @chapter Defining Functions
 @cindex defining functions