]> git.eshelyaron.com Git - emacs.git/commitdiff
Add new "make help" target
authorStefan Kangas <stefankangas@gmail.com>
Tue, 20 Aug 2019 23:02:43 +0000 (01:02 +0200)
committerStefan Kangas <stefankangas@gmail.com>
Thu, 29 Aug 2019 09:58:23 +0000 (11:58 +0200)
* GNUmakefile: Add new "help" target that shows a brief summary of
common make targets.  (Bug#12411)
* INSTALL
* etc/NEWS: Announce it.

GNUmakefile
INSTALL
etc/NEWS

index a67624e1f735ae147b353e5c4498777ffee3ea20..274109ca484d11d9cabb157ed7ea1efe04fa5552 100644 (file)
 # But run 'autogen.sh' first, if the source was checked out directly
 # from the repository.
 
+# Display help.
+
+ifeq (help,$(filter help,$(MAKECMDGOALS)))
+help:
+       @echo "NOTE:  This is a brief summary of some common make targets."
+       @echo "For more detailed information, please read the files INSTALL,"
+       @echo "INSTALL.REPO, Makefile or visit this URL:"
+       @echo "http://www.gnu.org/prep/standards/html_node/Standard-Targets.html"
+       @echo ""
+       @echo "make all              -- compile and build Emacs"
+       @echo "make install          -- install Emacs"
+       @echo "make TAGS             -- update tags tables"
+       @echo "make clean            -- delete built files but preserve configuration"
+       @echo "make mostlyclean      -- like 'make clean', but leave those files that"
+       @echo "                         usually do not need to be recompiled"
+       @echo "make distclean        -- delete all build and configuration files,"
+       @echo "                         leave only files included in source distribution"
+       @echo "make maintainer-clean -- delete almost everything that can be regenerated"
+       @echo "make bootstrap        -- delete all compiled files to force a new bootstrap"
+       @echo "                         from a clean slate, then build in the normal way"
+       @echo "make uninstall        -- remove files installed by 'make install'"
+       @echo "make check            -- run the Emacs test suite"
+       @echo "make docs             -- generate Emacs documentation in info format"
+       @echo "make html             -- generate documentation in html format"
+       @echo "make ps               -- generate documentation in ps format"
+       @echo "make pdf              -- generate documentation in pdf format "
+       @exit
+
+.PHONY: help
+
+else
+
 # If a Makefile already exists, just use it.
 
 ifeq ($(wildcard Makefile),Makefile)
@@ -82,3 +114,4 @@ bootstrap: Makefile
 
 endif
 endif
+endif
diff --git a/INSTALL b/INSTALL
index 6934022c4e51e72551ea7aaf12aaccbfcd0178cb..86f9e0080c13ae0ab3a6c87a083b1ea5db09944f 100644 (file)
--- a/INSTALL
+++ b/INSTALL
@@ -109,6 +109,9 @@ sections if you need to.
   (provided you have the 'gzip' program) those installed Lisp source (.el)
   files that have corresponding .elc versions, as well as the Info files.
 
+  You can read a brief summary about common make targets:
+
+                make help
 
 ADDITIONAL DISTRIBUTION FILES
 
index cd9a0947b92bccb17bf971eb6dc399fee55b7e6f..ddaee02e2683bc39bc377143677e7fe370289927 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -129,6 +129,8 @@ This is intended mostly to help developers.
 ** Emacs now requires GTK 2.24 and GTK 3.10 for the GTK 2 and GTK 3
 builds respectively.
 
+** New make target 'help' shows a summary of common make targets.
+
 \f
 * Startup Changes in Emacs 27.1