<html lang="en"> <head> <title>Documentation Tips - GNU Octave</title> <meta http-equiv="Content-Type" content="text/html"> <meta name="description" content="GNU Octave"> <meta name="generator" content="makeinfo 4.13"> <link title="Top" rel="start" href="index.html#Top"> <link rel="up" href="Tips-and-Standards.html#Tips-and-Standards" title="Tips and Standards"> <link rel="prev" href="Function-Headers.html#Function-Headers" title="Function Headers"> <link href="http://www.gnu.org/software/texinfo/" rel="generator-home" title="Texinfo Homepage"> <meta http-equiv="Content-Style-Type" content="text/css"> <style type="text/css"><!-- pre.display { font-family:inherit } pre.format { font-family:inherit } pre.smalldisplay { font-family:inherit; font-size:smaller } pre.smallformat { font-family:inherit; font-size:smaller } pre.smallexample { font-size:smaller } pre.smalllisp { font-size:smaller } span.sc { font-variant:small-caps } span.roman { font-family:serif; font-weight:normal; } span.sansserif { font-family:sans-serif; font-weight:normal; } --></style> </head> <body> <div class="node"> <a name="Documentation-Tips"></a> <p> Previous: <a rel="previous" accesskey="p" href="Function-Headers.html#Function-Headers">Function Headers</a>, Up: <a rel="up" accesskey="u" href="Tips-and-Standards.html#Tips-and-Standards">Tips and Standards</a> <hr> </div> <h3 class="section">C.4 Tips for Documentation Strings</h3> <p>As noted above, documentation is typically in a commented header block on an Octave function following the copyright statement. The help string shown above is an unformatted string and will be displayed as is by Octave. Here are some tips for the writing of documentation strings. <ul> <li>Every command, function, or variable intended for users to know about should have a documentation string. <li>An internal variable or subroutine of an Octave program might as well have a documentation string. <li>The first line of the documentation string should consist of one or two complete sentences that stand on their own as a summary. <p>The documentation string can have additional lines that expand on the details of how to use the function or variable. The additional lines should also be made up of complete sentences. <li>For consistency, phrase the verb in the first sentence of a documentation string as an infinitive with “to” omitted. For instance, use “Return the frob of A and B.” in preference to “Returns the frob of A and B.” Usually it looks good to do likewise for the rest of the first paragraph. Subsequent paragraphs usually look better if they have proper subjects. <li>Write documentation strings in the active voice, not the passive, and in the present tense, not the future. For instance, use “Return a list containing A and B.” instead of “A list containing A and B will be returned.” <li>Avoid using the word “cause” (or its equivalents) unnecessarily. Instead of, “Cause Octave to display text in boldface,” just write “Display text in boldface.” <li>Use two spaces between the period marking the end of a sentence and the word which opens the next sentence. This convention has no effect for typeset formats like TeX, but improves the readability of the documentation in fixed-width environments such as the Info reader. <li>Do not start or end a documentation string with whitespace. <li>Format the documentation string so that it fits within an 80-column screen. It is a good idea for most lines to be no wider than 60 characters. <p>However, rather than simply filling the entire documentation string, you can make it much more readable by choosing line breaks with care. Use blank lines between topics if the documentation string is long. <li><strong>Do not</strong> indent subsequent lines of a documentation string so that the text is lined up in the source code with the text of the first line. This looks nice in the source code, but looks bizarre when users view the documentation. Remember that the indentation before the starting double-quote is not part of the string! <li>When choosing variable names try to adhere to the following guidelines. <dl> <dt><dd>vectors : x,y,z,t,w <br><dt><dd>matrices : A,B,M <br><dt><dd>strings : str,s <br><dt><dd>filenames : fname <br><dt><dd>cells,cellstrs : c,cstr </dl> <li>The documentation string for a variable that is a yes-or-no flag should start with words such as “Nonzero means<small class="dots">...</small>”, to make it clear that all nonzero values are equivalent and indicate explicitly what zero and nonzero mean. <li>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 operator <code>/</code> refers to its second argument as ‘<samp><span class="samp">DIVISOR</span></samp>’, because the actual argument name is <code>divisor</code>. <p>Also use all caps for meta-syntactic variables, such as when you show the decomposition of a list or vector into subunits, some of which may vary. </ul> <p>Octave also allows extensive formatting of the help string of functions using Texinfo. The effect on the online documentation is relatively small, but makes the help string of functions conform to the help of Octave's own functions. However, the effect on the appearance of printed or online documentation will be greatly improved. <p>The fundamental building block of Texinfo documentation strings is the Texinfo-macro <code>@deftypefn</code>, which takes three arguments: The class the function is in, its output arguments, and the function's signature. Typical classes for functions include <code>Function File</code> for standard Octave functions, and <code>Loadable Function</code> for dynamically linked functions. A skeletal Texinfo documentation string therefore looks like this <pre class="example"> -*- texinfo -*- @deftypefn{Function File} {@var{ret} =} fn (...) @cindex index term Help text in Texinfo format. Code samples should be marked like @code{sample of code} and variables should be marked as @var{variable}. @seealso{fn2} @end deftypefn </pre> <p>This help string must be commented in user functions, or in the help string of the <code>DEFUN_DLD</code><!-- /@w --> macro for dynamically loadable functions. The important aspects of the documentation string are <dl> <dt>-*- texinfo -*-<dd>This string signals Octave that the following text is in Texinfo format, and should be the first part of any help string in Texinfo format. <br><dt>@deftypefn{class} <small class="dots">...</small> @end deftypefn<dd>The entire help string should be enclosed within the block defined by deftypefn. <br><dt>@cindex index term<dd>This generates an index entry, and can be useful when the function is included as part of a larger piece of documentation. It is ignored within Octave's help viewer. Only one index term may appear per line but multiple @cindex lines are valid if the function should be filed under different terms. <br><dt>@var{variable}<dd>All variables should be marked with this macro. The markup of variables is then changed appropriately for display. <br><dt>@code{sample of code}<dd>All samples of code should be marked with this macro for the same reasons as the @var macro. <br><dt>@seealso{function2}<dd>This is a comma separated list of function names that allows cross referencing from one function documentation string to another. </dl> <p>Texinfo format has been designed to generate output for online viewing with text terminals as well as generating high-quality printed output. To these ends, Texinfo has commands which control the diversion of parts of the document into a particular output processor. Three formats are of importance: info, HTML and TeX. These are selected with <pre class="example"> @ifinfo Text area for info only @end ifinfo </pre> <pre class="example"> @ifhtml Text area for HTML only @end ifhtml </pre> <pre class="example"> @tex Text area for TeX only @end tex </pre> <p>Note that often TeX output can be used in HTML documents and so often the <code>@ifhtml</code> blocks are unnecessary. If no specific output processor is chosen, by default, the text goes into all output processors. It is usual to have the above blocks in pairs to allow the same information to be conveyed in all output formats, but with a different markup. Currently, most Octave documentation only makes a distinction between TeX and all other formats. Therefore, the following construct is seen repeatedly. <pre class="example"> @tex text for TeX only @end tex @ifnottex text for info, HTML, plaintext @end ifnottex </pre> <p>Another important feature of Texinfo that is often used in Octave help strings is the <code>@example</code> environment. An example of its use is <pre class="example"> @example @group @code{2 * 2} @result{} 4 @end group @end example </pre> <p class="noindent">which produces <pre class="example"> <code>2 * 2</code> ⇒ 4 </pre> <p>The <code>@group</code> block prevents the example from being split across a page boundary, while the <code>@result{}</code> macro produces a right arrow signifying the result of a command. If your example is larger than 20 lines it is better NOT to use grouping so that a reasonable page boundary can be calculated. <p>In many cases a function has multiple ways in which it can be called, and the <code>@deftypefnx</code> macro can be used to give alternatives. For example <pre class="example"> -*- texinfo -*- @deftypefn {Function File} {@var{a} =} fn (@var{x}, ...) @deftypefnx{Function File} {@var{a} =} fn (@var{y}, ...) Help text in Texinfo format. @end deftypefn </pre> <p>Many complete examples of Texinfo documentation can be taken from the help strings for the Octave functions themselves. A relatively complete example of which is the <code>nchoosek</code> function. The Texinfo documentation string for <code>nchoosek</code> is <pre class="example"> -*- texinfo -*- @deftypefn {Function File} {@var{c} =} nchoosek (@var{n}, @var{k}) @deftypefnx {Function File} {@var{c} =} nchoosek (@var{set}, @var{k}) Compute the binomial coefficient or all combinations of a set of items. If @var{n} is a scalar then calculate the binomial coefficient of @var{n} and @var{k} which is defined as @tex $$ {n \choose k} = {n (n-1) (n-2) \cdots (n-k+1) \over k!} = {n! \over k! (n-k)!} $$ @end tex @ifnottex @example @group / \ | n | n (n-1) (n-2) @dots{} (n-k+1) n! | | = ------------------------- = --------- | k | k! k! (n-k)! \ / @end group @end example @end ifnottex @noindent This is the number of combinations of @var{n} items taken in groups of size @var{k}. If the first argument is a vector, @var{set}, then generate all combinations of the elements of @var{set}, taken @var{k} at a time, with one row per combination. The result @var{c} has @var{k} columns and @w{@code{nchoosek (length (@var{set}), @var{k})}} rows. For example: How many ways can three items be grouped into pairs? @example @group nchoosek (3, 2) @result{} 3 @end group @end example What are the possible pairs? @example @group nchoosek (1:3, 2) @result{} 1 2 1 3 2 3 @end group @end example @code{nchoosek} works only for non-negative, integer arguments. Use @code{bincoeff} for non-integer and negative scalar arguments, or for computing many binomial coefficients at once with vector inputs for @var{n} or @var{k}. @seealso{bincoeff, perms} @end deftypefn </pre> <p class="noindent">which demonstrates most of the concepts discussed above. <!-- DO NOT EDIT! Generated automatically by munge-texi.pl. --> <!-- Copyright (C) 2012 John W. Eaton --> <!-- Copyright (C) 2008-2012 Jaroslav Hajek --> <!-- This file is part of Octave. --> <!-- Octave 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. --> <!-- Octave 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 Octave; see the file COPYING. If not, see --> <!-- <http://www.gnu.org/licenses/>. --> </body></html>