From b3134b95a55a3ce656d19ca74d3ddcc6a1e9f958 Mon Sep 17 00:00:00 2001 From: Glenn Morris Date: Fri, 2 Mar 2012 20:29:55 -0500 Subject: [PATCH] Checked lispref/tips.texi * doc/lispref/tips.texi: Copyedits. (Coding Conventions): Mention autoloads. Combine partially duplicated macro items. Fix xref. Refer to Library Headers for copyright notice. (Programming Tips): edit-options is long-obsolete. (Compilation Tips): Mention loading bytecomp for byte-compile props. (Warning Tips): Mention declare-function. (Documentation Tips): Remove old info. (Comment Tips): Mention comment-dwim, not indent-for-comment. (Library Headers): General update. * admin/FOR-RELEASE: Related markup. --- admin/FOR-RELEASE | 2 +- doc/lispref/ChangeLog | 13 ++ doc/lispref/tips.texi | 273 ++++++++++++++++++++---------------------- 3 files changed, 142 insertions(+), 146 deletions(-) diff --git a/admin/FOR-RELEASE b/admin/FOR-RELEASE index 8e712f5fcf8..31a2a7ddbf7 100644 --- a/admin/FOR-RELEASE +++ b/admin/FOR-RELEASE @@ -227,7 +227,7 @@ strings.texi cyd symbols.texi cyd syntax.texi cyd text.texi -tips.texi +tips.texi rgm variables.texi cyd windows.texi diff --git a/doc/lispref/ChangeLog b/doc/lispref/ChangeLog index 254ad0ae83b..bfd49e82d83 100644 --- a/doc/lispref/ChangeLog +++ b/doc/lispref/ChangeLog @@ -1,3 +1,16 @@ +2012-03-03 Glenn Morris + + * tips.texi: Copyedits. + (Coding Conventions): Mention autoloads. + Combine partially duplicated macro items. Fix xref. + Refer to Library Headers for copyright notice. + (Programming Tips): edit-options is long-obsolete. + (Compilation Tips): Mention loading bytecomp for byte-compile props. + (Warning Tips): Mention declare-function. + (Documentation Tips): Remove old info. + (Comment Tips): Mention comment-dwim, not indent-for-comment. + (Library Headers): General update. + 2012-03-02 Glenn Morris * backups.texi (Reverting): Un-duplicate revert-buffer-in-progress-p, diff --git a/doc/lispref/tips.texi b/doc/lispref/tips.texi index ad1f622bfac..5874a848807 100644 --- a/doc/lispref/tips.texi +++ b/doc/lispref/tips.texi @@ -58,7 +58,7 @@ Separate the prefix from the rest of the name with a hyphen, @samp{-}. This practice helps avoid name conflicts, since all global variables in Emacs Lisp share the same name space, and all functions share another name space@footnote{The benefits of a Common Lisp-style -package system are considered not to outweigh the costs.} +package system are considered not to outweigh the costs.}. Occasionally, for a command name intended for users to use, it is more convenient if some words come before the package's name prefix. And @@ -109,6 +109,17 @@ when the compiled version of @var{foo} is @emph{used}. It should be called before the first use of the macro in the file. @xref{Compiling Macros}. +@item +Avoid loading additional libraries at run time unless they are really +needed. If your file simply cannot work without some other library, +then just @code{require} that library at the top-level and be done +with it. But if your file contains several independent features, and +only one or two require the extra library, then consider putting +@code{require} statements inside the relevant functions rather than at +the top-level. Or use @code{autoload} statements to load the extra +library when needed. This way people who don't use those aspects of +your file do not need to load the extra library. + @item Please don't require the @code{cl} package of Common Lisp extensions at run time. Use of this package is optional, and it is not part of the @@ -194,11 +205,8 @@ replacements differs from that of the originals. @item Constructs that define a function or variable should be macros, -not functions, and their names should start with @samp{def}. - -@item -A macro that defines a function or variable should have a name that -starts with @samp{define-}. The macro should receive the name to be +not functions, and their names should start with @samp{define-}. +The macro should receive the name to be defined as the first argument. That will help various tools find the definition automatically. Avoid constructing the names in the macro itself, since that would confuse these tools. @@ -207,7 +215,7 @@ itself, since that would confuse these tools. In some other systems there is a convention of choosing variable names that begin and end with @samp{*}. We don't use that convention in Emacs Lisp, so please don't use it in your programs. (Emacs uses such names -only for special-purpose buffers.) The users will find Emacs more +only for special-purpose buffers.) People will find Emacs more coherent if all libraries use the same conventions. @item @@ -216,7 +224,7 @@ constants, you should make sure Emacs always decodes these characters the same way, regardless of the user's settings. The easiest way to do this is to use the coding system @code{utf-8-emacs} (@pxref{Coding System Basics}), and specify that coding in the @samp{-*-} line or the -local variables list. @xref{File variables, , Local Variables in +local variables list. @xref{File Variables, , Local Variables in Files, emacs, The GNU Emacs Manual}. @example @@ -224,8 +232,7 @@ Files, emacs, The GNU Emacs Manual}. @end example @item -Indent each function with @kbd{C-M-q} (@code{indent-sexp}) using the -default indentation parameters. +Indent the file using the default indentation parameters. @item Don't make a habit of putting close-parentheses on lines by @@ -233,29 +240,8 @@ themselves; Lisp programmers find this disconcerting. @item Please put a copyright notice and copying permission notice on the -file if you distribute copies. Use a notice like this one: - -@smallexample -;; Copyright (C) @var{year} @var{name} - -;; This program is free software: you can redistribute it and/or -;; modify it under the terms of the GNU General Public License as -;; published by the Free Software Foundation, either version 3 of -;; the License, or (at your option) any later version. +file if you distribute copies. @xref{Library Headers}. -;; This program is distributed in the hope that it will be useful, -;; but WITHOUT ANY WARRANTY; without even the implied warranty of -;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -;; GNU General Public License for more details. - -;; You should have received a copy of the GNU General Public License -;; along with this program. If not, see -;; . -@end smallexample - -If you have signed papers to assign the copyright to the Foundation, -then use @samp{Free Software Foundation, Inc.} as @var{name}. -Otherwise, use your name. @xref{Library Headers}. @end itemize @node Key Binding Conventions @@ -324,11 +310,11 @@ Similarly, don't bind a key sequence ending in @key{C-g}, since that is commonly used to cancel a key sequence. @item -Anything which acts like a temporary mode or state which the user can +Anything that acts like a temporary mode or state that the user can enter and leave should define @kbd{@key{ESC} @key{ESC}} or @kbd{@key{ESC} @key{ESC} @key{ESC}} as a way to escape. -For a state which accepts ordinary Emacs commands, or more generally any +For a state that accepts ordinary Emacs commands, or more generally any kind of state in which @key{ESC} followed by a function key or arrow key is potentially meaningful, then you must not define @kbd{@key{ESC} @key{ESC}}, since that would preclude recognizing an escape sequence @@ -398,8 +384,8 @@ An error message should start with a capital letter but should not end with a period. @item -A question asked in the minibuffer with @code{y-or-n-p} or -@code{yes-or-no-p} should start with a capital letter and end with +A question asked in the minibuffer with @code{yes-or-no-p} or +@code{y-or-n-p} should start with a capital letter and end with @samp{? }. @item @@ -457,10 +443,9 @@ to generate such messages. @item Try to avoid using recursive edits. Instead, do what the Rmail @kbd{e} -command does: use a new local keymap that contains one command defined -to switch back to the old local keymap. Or do what the -@code{edit-options} command does: switch to another buffer and let the -user switch back at will. @xref{Recursive Editing}. +command does: use a new local keymap that contains a command defined +to switch back to the old local keymap. Or simply switch to another +buffer and let the user switch back at will. @xref{Recursive Editing}. @end itemize @node Compilation Tips @@ -515,6 +500,10 @@ compiled specially (@pxref{Array Functions}): @end group @end example +@noindent +Note that in this case (and many others), you must first load the +@file{bytecomp} library, which defines the @code{byte-compile} property. + @item If calling a small function accounts for a substantial part of your program's running time, make the function inline. This eliminates @@ -540,6 +529,11 @@ dummy @code{defvar} definitions for these variables, like this: Such a definition has no effect except to tell the compiler not to warn about uses of the variable @code{foo} in this file. +@item +Similarly, to avoid a compiler warning about an undefined function +that you know @emph{will} be defined, use a @code{declare-function} +statement (@pxref{Declaring Functions}). + @item If you use many functions and variables from a certain file, you can add a @code{require} for that package to avoid compilation warnings @@ -561,8 +555,8 @@ functions and variables in your package. @item The last resort for avoiding a warning, when you want to do something -that usually is a mistake but it's not a mistake in this one case, -is to put a call to @code{with-no-warnings} around it. +that is usually a mistake but you know is not a mistake in your usage, +is to put it inside @code{with-no-warnings}. @xref{Compiler Errors}. @end itemize @node Documentation Tips @@ -580,11 +574,9 @@ Every command, function, or variable intended for users to know about should have a documentation string. @item -An internal variable or subroutine of a Lisp program might as well have -a documentation string. In earlier Emacs versions, you could save space -by using a comment instead of a documentation string, but that is no -longer the case---documentation strings now take up very little space in -a running Emacs. +An internal variable or subroutine of a Lisp program might as well +have a documentation string. Documentation strings take up very +little space in a running Emacs. @item Format the documentation string so that it fits in an Emacs window on an @@ -595,14 +587,14 @@ or it will look bad in the output of @code{apropos}. You can fill the text if that looks good. However, rather than blindly filling the entire documentation string, you can often make it much more readable by choosing certain line breaks with care. Use blank lines -between topics if the documentation string is long. +between sections if the documentation string is long. @item The first line of the documentation string should consist of one or two complete sentences that stand on their own as a summary. @kbd{M-x apropos} displays just the first line, and if that line's contents don't stand on their own, the result looks bad. In particular, start the -first line with a capital letter and end with a period. +first line with a capital letter and end it with a period. For a function, the first line should briefly answer the question, ``What does this function do?'' For a variable, the first line should @@ -630,7 +622,7 @@ important arguments. When a function's documentation string mentions the value of an argument of the function, use the argument name in capital letters as if it were a name for that value. Thus, the documentation string of the function -@code{eval} refers to its second argument as @samp{FORM}, because the +@code{eval} refers to its first argument as @samp{FORM}, because the actual argument name is @code{form}: @example @@ -654,7 +646,7 @@ string. If the symbol's name is @code{foo}, write ``foo,'' not This might appear to contradict the policy of writing function argument values, but there is no real contradiction; the argument -@emph{value} is not the same thing as the @emph{symbol} which the +@emph{value} is not the same thing as the @emph{symbol} that the function uses to hold the value. If this puts a lower-case letter at the beginning of a sentence @@ -825,8 +817,8 @@ In Dired, visit the file or directory named on this line. @end example @item -When you define a variable that users ought to set interactively, you -should use @code{defcustom}. @xref{Defining Variables}. +When you define a variable that represents an option users might want +to set, use @code{defcustom}. @xref{Defining Variables}. @item The documentation string for a variable that is a yes-or-no flag should @@ -839,19 +831,14 @@ all non-@code{nil} values are equivalent and indicate explicitly what @section Tips on Writing Comments @cindex comments, Lisp convention for - We recommend these conventions for where to put comments and how to -indent them: + We recommend these conventions for comments: @table @samp @item ; Comments that start with a single semicolon, @samp{;}, should all be aligned to the same column on the right of the source code. Such -comments usually explain how the code on the same line does its job. In -Lisp mode and related modes, the @kbd{M-;} (@code{indent-for-comment}) -command automatically inserts such a @samp{;} in the right place, or -aligns such a comment if it is already present. - -This and following examples are taken from the Emacs sources. +comments usually explain how the code on that line does its job. +For example: @smallexample @group @@ -873,7 +860,7 @@ at that point. For example: (prog1 (setq auto-fill-function @dots{} @dots{} - ;; update mode line + ;; Update mode line. (force-mode-line-update))) @end group @end smallexample @@ -882,17 +869,17 @@ We also normally use two semicolons for comments outside functions. @smallexample @group -;; This Lisp code is run in Emacs -;; when it is to operate as a server -;; for other processes. +;; This Lisp code is run in Emacs when it is to operate as +;; a server for other processes. @end group @end smallexample -Every function that has no documentation string (presumably one that is -used only internally within the package it belongs to), should instead -have a two-semicolon comment right before the function, explaining what -the function does and how to call it properly. Explain precisely what -each argument means and how the function interprets its possible values. +If a function has no documentation string, it should instead have a +two-semicolon comment right before the function, explaining what the +function does and how to call it properly. Explain precisely what +each argument means and how the function interprets its possible +values. It is much better to convert such comments to documentation +strings, though. @item ;;; Comments that start with three semicolons, @samp{;;;}, should start at @@ -903,7 +890,7 @@ semicolons depends on whether the comment should be considered a ``heading'' by Outline minor mode. By default, comments starting with at least three semicolons (followed by a single space and a non-whitespace character) are considered headings, comments starting -with two or less are not. +with two or fewer are not. Another use for triple-semicolon comments is for commenting out lines within a function. We use three semicolons for this precisely so that @@ -934,11 +921,11 @@ program. For example: @end table @noindent -The indentation commands of the Lisp modes in Emacs, such as @kbd{M-;} -(@code{indent-for-comment}) and @key{TAB} (@code{lisp-indent-line}), -automatically indent comments according to these conventions, -depending on the number of semicolons. @xref{Comments,, -Manipulating Comments, emacs, The GNU Emacs Manual}. +Generally speaking, the @kbd{M-;} (@code{comment-dwim}) command +automatically starts a comment of the appropriate type; or indents an +existing comment to the right place, depending on the number of +semicolons. +@xref{Comments,, Manipulating Comments, emacs, The GNU Emacs Manual}. @node Library Headers @section Conventional Headers for Emacs Libraries @@ -947,39 +934,28 @@ Manipulating Comments, emacs, The GNU Emacs Manual}. Emacs has conventions for using special comments in Lisp libraries to divide them into sections and give information such as who wrote -them. This section explains these conventions. - - We'll start with an example, a package that is included in the Emacs -distribution. - - Parts of this example reflect its status as part of Emacs; for -example, the copyright notice lists the Free Software Foundation as the -copyright holder, and the copying permission says the file is part of -Emacs. When you write a package and post it, the copyright holder would -be you (unless your employer claims to own it instead), and you should -get the suggested copying permission from the end of the GNU General -Public License itself. Don't say your file is part of Emacs -if we haven't installed it in Emacs yet! - - With that warning out of the way, on to the example: +them. Using a standard format for these items makes it easier for +tools (and people) to extract the relevant information. This section +explains these conventions, starting with an example: @smallexample @group -;;; lisp-mnt.el --- minor mode for Emacs Lisp maintainers +;;; foo.el --- Support for the Foo programming language -;; Copyright (C) 1992 Free Software Foundation, Inc. +;; Copyright (C) 2010-2012 Your Name @end group -;; Author: Eric S. Raymond -;; Maintainer: Eric S. Raymond -;; Created: 14 Jul 1992 -;; Version: 1.2 +;; Author: Your Name +;; Maintainer: Someone Else +;; Created: 14 Jul 2010 @group -;; Keywords: docs +;; Keywords: languages -;; This file is part of GNU Emacs. +;; This file is not part of GNU Emacs. + +;; This file is free software@dots{} @dots{} -;; along with GNU Emacs. If not, see . +;; along with this file. If not, see . @end group @end smallexample @@ -990,8 +966,19 @@ if we haven't installed it in Emacs yet! @end example @noindent -The description should be complete in one line. If the file +The description should be contained in one line. If the file needs a @samp{-*-} specification, put it after @var{description}. +If this would make the first line too long, use a Local Variables +section at the end of the file. + + The copyright notice usually lists your name (if you wrote the +file). If you have an employer who claims copyright on your work, you +might need to list them instead. Do not say that the copyright holder +is the Free Software Foundation (or that the file is part of GNU +Emacs) unless your file has been accepted into the Emacs distribution. +For more information on the form of copyright and license notices, see +@uref{http://www.gnu.org/licenses/gpl-howto.html, the guide on the GNU +website}. After the copyright notice come several @dfn{header comment} lines, each beginning with @samp{;; @var{header-name}:}. Here is a table of @@ -999,55 +986,55 @@ the conventional possibilities for @var{header-name}: @table @samp @item Author -This line states the name and net address of at least the principal -author of the library. - -If there are multiple authors, you can list them on continuation lines -led by @code{;;} and a tab character, like this: +This line states the name and email address of at least the principal +author of the library. If there are multiple authors, list them on +continuation lines led by @code{;;} and whitespace (this is easier +for tools to parse than having more than one author on one line). +We recommend including a contact email address, of the form +@samp{<@dots{}>}. For example: @smallexample @group -;; Author: Ashwin Ram -;; Dave Sill -;; Dave Brennan -;; Eric Raymond +;; Author: Your Name +;; Someone Else +;; Another Person @end group @end smallexample @item Maintainer -This line should contain a single name/address as in the Author line, or -an address only, or the string @samp{FSF}. If there is no maintainer -line, the person(s) in the Author field are presumed to be the -maintainers. The example above is mildly bogus because the maintainer -line is redundant. - -The idea behind the @samp{Author} and @samp{Maintainer} lines is to make -possible a Lisp function to ``send mail to the maintainer'' without -having to mine the name out by hand. +This header has the same format as the Author header. It lists the +person(s) who currently maintain(s) the file (respond to bug reports, +etc.). -Be sure to surround the network address with @samp{<@dots{}>} if -you include the person's full name as well as the network address. +If there is no maintainer line, the person(s) in the Author field +is/are presumed to be the maintainers. Some files in Emacs use +@samp{FSF} for the maintainer. This means that the original author is +no longer responsible for the file, and that it is maintained as part +of Emacs. @item Created -This optional line gives the original creation date of the -file. For historical interest only. +This optional line gives the original creation date of the file, and +is for historical interest only. @item Version -If you wish to record version numbers for the individual Lisp program, put -them in this line. - -@item Adapted-By -In this header line, place the name of the person who adapted the -library for installation (to make it fit the style conventions, for -example). +If you wish to record version numbers for the individual Lisp program, +put them in this line. Lisp files distributed with Emacs generally do +not have a @samp{Version} header, since the version number of Emacs +itself serves the same purpose. If you are distributing a collection +of multiple files, we recommend not writing the version in every file, +but only the main one. @item Keywords This line lists keywords for the @code{finder-by-keyword} help command. Please use that command to see a list of the meaningful keywords. -This field is important; it's how people will find your package when -they're looking for things by topic area. To separate the keywords, you -can use spaces, commas, or both. +This field is how people will find your package when they're looking +for things by topic. To separate the keywords, you can use spaces, +commas, or both. + +The name of this field is unfortunate, since people often assume it is +the place to write arbitrary keywords that describe their package, +rather than just the relevant Finder keywords. @item Package-Version If @samp{Version} is not suitable for use by the package manager, then @@ -1060,7 +1047,7 @@ If this exists, it names packages on which the current package depends for proper operation. @xref{Packaging Basics}. This is used by the package manager both at download time (to ensure that a complete set of packages is downloaded) and at activation time (to ensure that a -package is activated if and only if all its dependencies have been). +package is only activated if all its dependencies have been). Its format is a list of lists. The @code{car} of each sub-list is the name of a package, as a symbol. The @code{cadr} of each sub-list is @@ -1081,8 +1068,8 @@ appropriate. You can also put in header lines with other header names---they have no standard meanings, so they can't do any harm. We use additional stylized comments to subdivide the contents of the -library file. These should be separated by blank lines from anything -else. Here is a table of them: +library file. These should be separated from anything else by blank +lines. Here is a table of them: @table @samp @item ;;; Commentary: @@ -1092,16 +1079,12 @@ It should come right after the copying permissions, terminated by a text is used by the Finder package, so it should make sense in that context. -@item ;;; Documentation: -This was used in some files in place of @samp{;;; Commentary:}, -but it is deprecated. - @item ;;; Change Log: -This begins change log information stored in the library file (if you -store the change history there). For Lisp files distributed with Emacs, -the change history is kept in the file @file{ChangeLog} and not in the -source file at all; these files generally do not have a @samp{;;; Change -Log:} line. @samp{History} is an alternative to @samp{Change Log}. +This begins an optional log of changes to the file over time. Don't +put too much information in this section---it is better to keep the +detailed logs in a separate @file{ChangeLog} file (as Emacs does), +and/or to use a version control system. @samp{History} is an +alternative to @samp{Change Log}. @item ;;; Code: This begins the actual code of the program. -- 2.39.2