emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
blob 04d67254d09450725fd303cf40ac9da8a88d8a23 6952 bytes (raw)
name: doc/Documentation_Standards.org 	 # note: path name is non-authoritative(*)

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
 
#+TITLE:    Notes on documenting Org
#+AUTHOR:   Phil Rooke
#+EMAIL:    phil@yax.org.uk
#+LANGUAGE: en
#+STARTUP:  showall
#+TEXT:     Notes to myself justifying the coventions and standards in my
#+TEXT:     set of recent doc patches.
#+OPTIONS:  H:3 num:t toc:t \n:nil @:t ::t |:t ^:t *:t TeX:t

* Background

I think it is an express objective of Carsten's that Org should be
readily accessible to all users of Emacs and not just those who might
happen to read or hack on the code of this particular package.  To that
end significant effort has been made and continues to be made by the Org
community to ensure that high quality, user focused, documentation is
readily available to everyone.

Org itself contains a comprehensive guide to using all aspects of the
system, how to extend it yourself, and highlights some of the many
burgeoning number of add-on packages that others are contributing.  This
guide, [[info:org:Top][The Org Manual]], concentrates on the facts of working with the
system. Supplementing this, the [[Org web pages]] contain pointers to many
tutorials and how-to's which capture much of spirit and imagination
people show when using Org as a basis for building broader
organizational systems that help them help themselves.

I use Org, but it is a big system, and so I happen to think that
improving the consistency, clarity and accuracy of Org documents helps
both me and all other users of the system.  In support of this and by
way of justification and clarification, this short note attempts to
capture some of the existing guidelines and standards that have been
used in the patches I am submitting and, which I hope, may be adopted by
others when making their own contributions.

* Org - Referencing systems, packages, modes and much else
 
Originally Org was a single mode and there was no ambiguity about what
Org mode could refer to.  Things have changed rapidly though and it
seems that Carsten now thinks of Org as the system encompassing the
major mode, some minor modes, and an increasing number of additional
packages and plug-ins that build on the core Org functionality. It is
really hard to find a consistent way to refer to all these things, but
what I am trying to do is follow these guidelines (which are not
perfect, merely a start):

 - In general write "Org" as much as possible and, in particular, when
   discussing concepts, features and functions that are generally
   applicable to Org as a whole.

 - Be more specific and write, for example, "the Orgtbl minor mode" when
   referring to something unique to that feature.  It maybe, for example,
   a command is only available when you are actually editing a file using
   just that mode, add-on package or plug-in.

 - Prefer "Org mode" to "Org-mode" or "org-mode". This is simply because
   it reflects an existing convention in [[info:emacs:Top][The Emacs Manual]] which
   consistently documents mode names in this form - "Text mode", "Outline
   mode", "Mail mode" etc.

 - Likewise refer, if at all possible, to "Org file or "Org buffer"
   meaning with, great generality, any file or buffer which requires use
   of some part of Org to edit it properly.

 - Org uses "org-..." to ring fence a name space for itself in the Emacs
   code base.  This is obviously retained in code snippets.

* Other Org specific conventions

Unless there is a good reason to do otherwise then try and adopt the
following conventions.  (I think all can be justified by reference to
Carsten or precedent in other significant Emacs documentation...unless I
have made them up of course).

 - Org has *lots* of commands and a /lot/ of them take prefix arguments
   of one sort or another.  Write in full "prefix argument", "numeric
   prefix argument" or, maybe, "a numeric prefix argument N" when you
   want to refer to the argument again.

 - Org lives in various states of harmony and discord with other Emacs
   packages.  Try and write the names of those packages as their authors
   and maintainers write them.  So it should be (I think) BBDB, MH-E,
   Rmail, VM, Gnus, CDLaTeX etc.

 - TODO keywords, whether Org or user defined, are written in capitals.

 - Built-in tags with a special meaning (eg ARCHIVE) are written in
   uppercase.  User defined tags (eg boss, home) are written in
   lowercase.

 - Built-in properties (eg PRIORITY) are written in uppercase.  User defined
   properties (eg Release) are written in lowercase.

 - [[info:org:Top][The Org Manual]] uses the @chapter, @section and @subsection Texinfo
   commands for sectioning.  I have tried to capitalize significant words
   in @chapter headings.  In @section and @subsection headings, just the
   first word is capitalized and all other words are lowercase (with
   exceptions of course...).  Thus, use:

   @chapter Properties and Columns

   @section Visibility cycling

   *but*

   @section Fast access to TODO states

* Miscellaneous

 - Only two of the standard Texinfo indexes are used; those for concepts
   and keys.  This has some implications:

   + The preference is to document commands by key rather than by name

   + Texinfo commands such as @var and @defoption are not used.  The
     preference for this type of thing is that the user browses the
     customize groups.  If you want or need to refer to, say, a variable
     then document it as "the variable @code{org-startup-folded}"
 
   + Entries in the concept index are normally all lower case unless
     some other rule dictates otherwise.

 - Org documentation is written in American English, which is somewhat
   foreign as far as I am concerned, but live with it anyway.

 - Org uses a number of compound words, words that I wouldn't necessarily
   run together.  Instead of worrying about whether these should be
   separate, hyphenated or compound I have simply gone with the majority
   case as originally written and then tried to make sure the spell
   checker knows what this chosen standard should be so that I do not
   worry about it anymore.

 - I have run a spell checker periodically. Aspell works well and has a
   useful Texinfo filter (although, annoyingly, I cannot make this work
   with ispell.el and so I run it from the command line).  I have an Org
   specific Aspell configuration file (which sets an American dictionary,
   rules for compound words etc) and which, along with the associated
   word and replacement files, captures some of the more detailed and
   somewhat arbitrary rules I have used.

 - Org has really low entry barriers.  The requirements seem simply
   to be:

   + You can use Text mode or, pretty much, any derivative of it

   + You have some motivation to become slightly better organized.

   Therefore, try and write the documentation so that it is relevant to,
   and can be read by such a diverse audience.

# Local variables:
# mode: org
# fill-column: 72
# ispell-local-dictionary: "en_US-w_accents"
# ispell-local-pdict: "./.aspell.org.pws"
# End:

debug log:

solving 04d6725 ...
found 04d6725 in https://git.savannah.gnu.org/cgit/emacs/org-mode.git

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).