# HG changeset patch # User Ben Wing # Date 1268971961 18000 # Node ID 45753d9a0dc4aebfc98b961647a57e840644e3a7 # Parent 641d0cdd1d0048c4eb66ff6d9af67dbafa9913c3# Parent 0353d546dc1e2906d2b5908c181e26a1483ccecd merge diff -r 641d0cdd1d00 -r 45753d9a0dc4 ChangeLog --- a/ChangeLog Tue Mar 16 23:09:34 2010 -0500 +++ b/ChangeLog Thu Mar 18 23:12:41 2010 -0500 @@ -1,3 +1,12 @@ +2010-03-18 Mike Sperber + + * INSTALL: Reflect change from `lib' to `share'; also, document + how to invoke configure to get the old setting. + + * configure.ac: Set LATE_PACKAGE_DIRECTORIES_USER_DEFINED if + `datadir' was changed; set `with_late_packages' to something + sensible for this case. + 2010-02-20 Ben Wing * configure.ac (XE_COMPLEX_ARG): diff -r 641d0cdd1d00 -r 45753d9a0dc4 INSTALL --- a/INSTALL Tue Mar 16 23:09:34 2010 -0500 +++ b/INSTALL Thu Mar 18 23:12:41 2010 -0500 @@ -257,7 +257,7 @@ should put XEmacs and its data files. This defaults to `/usr/local'. - XEmacs (and the other utilities users run) go in PREFIXDIR/bin (unless the `--exec-prefix' option says otherwise). -- The architecture-independent files go in PREFIXDIR/lib/xemacs-VERSION +- The architecture-independent files go in PREFIXDIR/share/xemacs-VERSION (where VERSION is the version number of XEmacs, like `21.0'). - The architecture-dependent files go in PREFIXDIR/lib/xemacs-VERSION/CONFIGURATION-NAME @@ -284,6 +284,12 @@ part of the generated executable; everything else will continue to work as usual. +Unlike previous versions of XEmacs (21.4 or earlier), +architecture-independent files (in particular, the Lisp files and +package hierarchies) by default get installed under `/usr/local/share' +rather than `/usr/local/lib'. To create a setup as in previous +versions, use the `--datadir=/usr/local/lib' option to configure. + Configuring Feature Support --------------------------- @@ -567,7 +573,7 @@ `xemacs', `etags', `ctags', `b2m', `emacsclient', `ellcc', `gnuclient', `gnudoit', and `gnuattach'. -`/usr/local/lib/xemacs-VERSION/lisp' holds the Emacs Lisp libraries; +`/usr/local/share/xemacs-VERSION/lisp' holds the Emacs Lisp libraries; `VERSION' stands for the number of the XEmacs version you are installing, like `18.59' or `19.14'. Since the lisp libraries change from one version of XEmacs to @@ -578,14 +584,14 @@ XEmacs searches for its lisp files in these directories, and then in - `/usr/local/lib/xemacs/site-lisp/*'. + `/usr/local/share/xemacs/site-lisp/*'. -`/usr/local/lib/xemacs-VERSION/etc' holds the XEmacs tutorial, the +`/usr/local/share/xemacs-VERSION/etc' holds the XEmacs tutorial, the Unicode database, and other architecture-independent files XEmacs might need while running. VERSION is as specified for `.../lisp'. -`/usr/local/lib/xemacs/lock' contains files indicating who is +`/usr/local/share/xemacs/lock' contains files indicating who is editing what, so XEmacs can detect editing clashes between users. @@ -614,7 +620,7 @@ sub-directory of it, and then in `/usr/local/lib/xemacs/site-modules/*'. -`/usr/local/lib/xemacs-VERSION/info' holds the on-line documentation +`/usr/local/share/xemacs-VERSION/info' holds the on-line documentation for XEmacs, known as "info files". `/usr/local/man/man1' holds the man pages for the programs installed @@ -642,7 +648,7 @@ `datadir' indicates where to put the architecture-independent read-only data files that XEmacs refers to while it runs; it - defaults to /usr/local/lib. We create the following + defaults to /usr/local/data. We create the following subdirectories under `datadir': - `xemacs-VERSION/lisp', containing the XEmacs lisp libraries, and @@ -655,6 +661,13 @@ same time; this means that you don't have to make XEmacs unavailable while installing a new version. +`datarootdir' indicates where to put the documentation. (Usually, + this is identical to `datadir'---in the default configuration + `datadir' is set to the value of `datarootdir'.) + Specifically, the man pages are put in the `man' subdirectory + of `datarootdir', and the info pages are put in the + `xemacs/info' subdirectory. + `statedir' indicates where to put architecture-independent data files that XEmacs modifies while it runs; it defaults to /usr/local/lib as well. We create the following @@ -680,7 +693,7 @@ XEmacs is installed on. `infodir' indicates where to put the info files distributed with - XEmacs; it defaults to `/usr/local/lib/xemacs-VERSION/info'. + XEmacs; it defaults to `/usr/local/share/xemacs-VERSION/info'. `mandir' indicates where to put the man pages for XEmacs and its utilities (like `etags'); it defaults to @@ -710,23 +723,23 @@ `lispdir' indicates where XEmacs installs and expects its lisp libraries. Its default value, based on `datadir' (see above), - is `/usr/local/lib/xemacs-VERSION/lisp' (where `VERSION' is as + is `/usr/local/share/xemacs-VERSION/lisp' (where `VERSION' is as described above). `sitelispdir' indicates where XEmacs should search for lisp libraries specific to your site. XEmacs checks them in order before checking `lispdir'. Its default value, based on `datadir' - (see above), is `/usr/local/lib/xemacs/site-lisp'. + (see above), is `/usr/local/share/xemacs/site-lisp'. `etcdir' indicates where XEmacs should install and expect the rest of its architecture-independent data, like the tutorial and yow database. Its default value, based on `datadir' - (see above), is `/usr/local/lib/xemacs-VERSION/etc' (where + (see above), is `/usr/local/share/xemacs-VERSION/etc' (where `VERSION' is as described above). `lockdir' indicates the directory where XEmacs keeps track of its locking information. Its default value, based on `statedir' - (see above), is `/usr/local/lib/xemacs/lock'. + (see above), is `/usr/local/share/xemacs/lock'. `archlibdir' indicates where XEmacs installs and expects the executable files and other architecture-dependent data it uses diff -r 641d0cdd1d00 -r 45753d9a0dc4 configure --- a/configure Tue Mar 16 23:09:34 2010 -0500 +++ b/configure Thu Mar 18 23:12:41 2010 -0500 @@ -1995,13 +1995,14 @@ --with-quick-build Speed up the build cycle by leaving out steps where XEmacs will still work (more or less) without them. Potentially dangerous if you don't know what you're - doing. This (1) doesn't garbage-collect after - loading each file during dumping, (2) doesn't + doing. This (1) Doesn't garbage-collect after + loading each file during dumping, (2) Doesn't automatically rebuild the DOC file (remove it by hand to get it rebuilt), (3) Removes config.h, lisp.h and associated files from the dependency lists, so changes to these files don't automatically - cause all .c files to be rebuilt. + cause all .c files to be rebuilt, (4) Doesn't check + for Lisp shadows. --with-union-type Use union definition of Lisp_Object type. Known to trigger bugs in some compilers. --with-quantify Support performance debugging using Quantify. @@ -5509,6 +5510,8 @@ $as_echo "#define ETCDIR_USER_DEFINED 1" >>confdefs.h + $as_echo "#define LATE_PACKAGE_DIRECTORIES_USER_DEFINED 1" >>confdefs.h + fi if test "x$libdir" != "x\${exec_prefix}/lib" @@ -5533,6 +5536,7 @@ inststaticdir='${PROGNAME}' instvardir='${PROGNAME}-${version}' sitemoduledir='${libdir}/${inststaticdir}/site-modules' +with_late_packages='${datadir}/${PROGNAME}' statedir=$with_statedir diff -r 641d0cdd1d00 -r 45753d9a0dc4 configure.ac --- a/configure.ac Tue Mar 16 23:09:34 2010 -0500 +++ b/configure.ac Thu Mar 18 23:12:41 2010 -0500 @@ -1108,6 +1108,7 @@ AC_DEFINE(INFODIR_USER_DEFINED) AC_DEFINE(LISPDIR_USER_DEFINED) AC_DEFINE(ETCDIR_USER_DEFINED) + AC_DEFINE(LATE_PACKAGE_DIRECTORIES_USER_DEFINED) fi if test "x$libdir" != "x\${exec_prefix}/lib" @@ -1128,6 +1129,7 @@ inststaticdir='${PROGNAME}' instvardir='${PROGNAME}-${version}' sitemoduledir='${libdir}/${inststaticdir}/site-modules' +with_late_packages='${datadir}/${PROGNAME}' AC_SUBST(inststaticdir) AC_SUBST(statedir,$with_statedir) diff -r 641d0cdd1d00 -r 45753d9a0dc4 man/ChangeLog --- a/man/ChangeLog Tue Mar 16 23:09:34 2010 -0500 +++ b/man/ChangeLog Thu Mar 18 23:12:41 2010 -0500 @@ -1,3 +1,9 @@ +2010-03-18 Mike Sperber + + * xemacs/startup.texi (Startup Paths): Reflect the (long-ago) + change from `lib' to `share' for the architecture-independent + directories. + 2010-03-13 Ben Wing * internals/internals.texi (Working with Lisp Objects): diff -r 641d0cdd1d00 -r 45753d9a0dc4 man/xemacs/startup.texi --- a/man/xemacs/startup.texi Tue Mar 16 23:09:34 2010 -0500 +++ b/man/xemacs/startup.texi Thu Mar 18 23:12:41 2010 -0500 @@ -69,10 +69,10 @@ Moreover, XEmacs expects late hierarchies in the subdirectories @file{site-packages}, @file{mule-packages}, and @file{xemacs-packages} -(in that order) of the @file{/lib/xemacs} subdirectory of one of +(in that order) of the @file{/share/xemacs} subdirectory of one of the installation hierarchies. (If you run in-place, these are direct subdirectories of the build directory.) Furthermore, XEmacs will also -search these subdirectories in the @file{/lib/xemacs-} +search these subdirectories in the @file{/share/xemacs-} subdirectory and prefer directories found there. By default, XEmacs does not have a pre-configured last package @@ -113,12 +113,14 @@ @table @code @item version-specific @cindex version-specific directories -directories are specific to the version of XEmacs they belong to and -typically reside under @file{/lib/xemacs-}. +directories (such as @file{etc}, the @file{info} of the installed XEmacs +and its Lisp files in @file{lisp}) are specific to the version of XEmacs +they belong to and typically reside under +@file{/share/xemacs-}. @item site-specific @cindex site-specific directories -directories are independent of the version of XEmacs they belong to and -typically reside under @file{/lib/xemacs} +directories are independent of the version of XEmacs and +typically reside under @file{/share/xemacs}. @item architecture-specific @cindex architecture-specific directories directories are specific both to the version of XEmacs and the