From 0922634b28ff501ded2bf8f343c848f5e4db35d5 Mon Sep 17 00:00:00 2001 From: Eli Zaretskii Date: Fri, 31 Dec 2021 10:56:28 +0200 Subject: [PATCH] Minor improvements of 'lisp-directory' docs * lisp/startup.el (lisp-directory): * etc/NEWS: * doc/lispref/loading.texi (Library Search): Improve wording of documentation of 'lisp-directory' and related features. --- doc/lispref/loading.texi | 58 +++++++++++++++++++++++----------------- etc/NEWS | 6 ++--- lisp/startup.el | 2 +- 3 files changed, 37 insertions(+), 29 deletions(-) diff --git a/doc/lispref/loading.texi b/doc/lispref/loading.texi index 3efcf055dcf..070f763db87 100644 --- a/doc/lispref/loading.texi +++ b/doc/lispref/loading.texi @@ -293,30 +293,33 @@ directory). When Emacs starts up, it sets up the value of @code{load-path} in several steps. First, it looks for the directory containing its own -Lisp files, using default locations set when Emacs was compiled. -It saves this directory in @code{lisp-directory}. Normally, this -is a directory something like +Lisp files, using default locations set when Emacs was compiled. It +saves this directory in @code{lisp-directory}. Normally, this is a +directory where the @file{*.elc} files are installed, something like @example "/usr/local/share/emacs/@var{version}/lisp" @end example -(In this and the following examples, replace @file{/usr/local} with -the installation prefix appropriate for your Emacs.) -These directories contain the standard Lisp files that come with -Emacs. If Emacs cannot find them, it will not start correctly. +@noindent +where @var{version} is the Emacs version. (In this and the following +examples, replace @file{/usr/local} with the prefix appropriate for +your Emacs installation.) This directory and its subdirectories +contain the standard Lisp files that come with Emacs. If Emacs cannot +find its own Lisp files, it will not start correctly. If you run Emacs from the directory where it was built---that is, an -executable that has not been formally installed---Emacs instead -initializes @code{lisp-directory} using the @file{lisp} -directory in the directory containing the sources from which it -was built. +executable that has not been installed yet---Emacs instead initializes +@code{lisp-directory} using the @file{lisp} subdirectory of the +directory containing the sources from which it was built. -Emacs first initializes @code{load-path} with this @code{lisp-directory}. +Emacs then initializes @code{load-path} with this @code{lisp-directory}. @c Though there should be no *.el files in builddir/lisp, so it's pointless. If you built Emacs in a separate directory from the -sources, it also adds the lisp directories from the build directory. -(In all cases, elements are represented as absolute file names.) +sources, it also adds the @file{lisp} subdirectory of the build directory. + +All of these directories are stored in the above two variables as +absolute file names. @cindex site-lisp directories Unless you start Emacs with the @option{--no-site-lisp} option, @@ -336,12 +339,12 @@ and @end example @noindent -The first one is for locally installed files for a specific Emacs -version; the second is for locally installed files meant for use -with all installed Emacs versions. (If Emacs is running uninstalled, -it also adds @file{site-lisp} directories from the source and build -directories, if they exist. Normally these directories do not contain -@file{site-lisp} directories.) +The first one is for locally installed files for the current Emacs +@var{version}; the second is for locally installed files meant for use +with any installed Emacs version. (If Emacs is running uninstalled, +it also adds @file{site-lisp} subdirectories from the source and build +directories, if they exist. However, normally the source and build +directories do not contain @file{site-lisp} subdirectories.) @cindex @env{EMACSLOADPATH} environment variable If the environment variable @env{EMACSLOADPATH} is set, it modifies @@ -363,9 +366,10 @@ export EMACSLOADPATH=/home/foo/.emacs.d/lisp: @end example An empty element in the value of the environment variable, whether -trailing (as in the above example), leading, or embedded, is replaced -by the default value of @code{load-path} as determined by the standard -initialization procedure. If there are no such empty elements, then +trailing (as in the above example, note the trailing @samp{:}), +leading, or embedded, is replaced by the default value of +@code{load-path} as determined by the standard initialization +procedure. If there are no such empty elements, then @env{EMACSLOADPATH} specifies the entire @code{load-path}. You must include either an empty element, or the explicit path to the directory containing the standard Lisp files, else Emacs will not function. @@ -394,6 +398,9 @@ add one or more directories to @code{load-path}. For example: (push "~/.emacs.d/lisp" load-path) @end example +@noindent +@xref{List Variables, push}, for the description of @code{push}. + Dumping Emacs uses a special value of @code{load-path}. If you use a @file{site-load.el} or @file{site-init.el} file to customize the dumped Emacs (@pxref{Building Emacs}), any changes to @code{load-path} @@ -401,10 +408,11 @@ that these files make will be lost after dumping. @defvar lisp-directory This variable holds a string naming the directory which holds -Emacs's own @code{.el} and @code{.elc} files. This is usually the +Emacs's own @file{*.el} and @file{*.elc} files. This is usually the place where those files are located in the Emacs installation tree, unless Emacs is run from its build directory in which case it points -to the @code{lisp} directory in source directory from which it was built. +to the @file{lisp} subdirectory in the source directory from which +Emacs was built. @end defvar @deffn Command locate-library library &optional nosuffix path interactive-call diff --git a/etc/NEWS b/etc/NEWS index f6ba0167e0f..ca6a716ccd3 100644 --- a/etc/NEWS +++ b/etc/NEWS @@ -72,9 +72,9 @@ work on any underlying window system supported by GDK, such as Wayland and Broadway. --- -** The docstrings of preloaded files are not in etc/DOC any more. -Instead, they're fetched from the corresponding '.elc' file, as was already -the case for all the non-preloaded files. +** The docstrings of preloaded files are not in 'etc/DOC' any more. +Instead, they're fetched as needed from the corresponding '.elc' file, +as was already the case for all the non-preloaded files. * Startup Changes in Emacs 29.1 diff --git a/lisp/startup.el b/lisp/startup.el index 727432a4cbe..76cc9b2ca32 100644 --- a/lisp/startup.el +++ b/lisp/startup.el @@ -1057,7 +1057,7 @@ the `--debug-init' option to view a complete error backtrace." (setq debug-on-error debug-on-error-from-init-file)))) (defvar lisp-directory nil - "Directory containing the Lisp files that come with GNU Emacs.") + "Directory where Emacs's own *.el and *.elc Lisp files are installed.") (defun command-line () "A subroutine of `normal-top-level'. -- 2.39.2