Browse Source

Edits, mainly to header args section

Dan Davison 15 years ago
parent
commit
91a169177a
1 changed files with 108 additions and 54 deletions
  1. 108 54
      doc/org.texi

+ 108 - 54
doc/org.texi

@@ -10663,7 +10663,7 @@ Using code blocks in table formulas
 @comment  Structure of Code Blocks, Editing Source Code, Working With Source Code, Working With Source Code
 @section Structure of Code Blocks
 
-The basic structure of code blocks is as follows:
+The structure of code blocks is as follows:
 
 @example
 #+srcname: <name>
@@ -10680,8 +10680,10 @@ The language of the code in the block.
 @item <switches>
 Optional links FIXME link/relocate switches discussion in @ref{Literal examples}
 @item <header arguments>
-Optional header arguments control many aspects of evaluation, export and tangling of
-source code blocks. See the [[header-arguments][Header Arguments]] section.
+Optional header arguments control many aspects of evaluation, export and
+tangling of source code blocks. See the [[header-arguments][Header
+Arguments]] section. Header arguments can also be set on a per-buffer or
+per-subtree basis using properties.
 @item <body>
 The code
 @end table
@@ -10723,10 +10725,14 @@ to a non-nil value to switch without asking.
 @section Exporting Code Blocks
 
 By default, code blocks export to HTML with the appearance of the fontified
-language major-mode Emacs buffer. A similar effect is possible with LaTeX if
-you turn on the option @code{org-export-latex-listings} and make sure that
-the listings package is included by the LaTeX header FIXME: be more specific
-about latex config.
+language major-mode Emacs buffer
+
+FIXME: say something more knowledgable about the HTML/CSS output.
+
+A similar effect is possible with LaTeX if you turn on
+the option @code{org-export-latex-listings} and make sure that the listings
+package is included by the LaTeX header FIXME: be more specific about latex
+config.
 
 FIXME: This duplicated discussion in @ref{Literal examples}. Add
 documentation of relevant switches.
@@ -10785,6 +10791,11 @@ FIXME: This variable may have been changed recently
 @comment  Evaluating Code Blocks,  , Extracting Source Code, Working With Source Code
 @section Evaluating Code Blocks
 
+For many languages, blocks of code can be evaluated, with the results being
+returned to the org buffer (or linked to from the org buffer).
+
+FIXME: Are we going to use ``evaluate'' or ``execute''
+
 This syntax can be expanded by naming the source code block.
 
 @example
@@ -10840,39 +10851,69 @@ body
   :CUSTOM_ID: languages
   :END:
 
-  Org-babel has support for the following languages.
-
-@c BEGIN RECEIVE ORGTBL org_babel_lang-table
-@multitable @columnfractions 0.036 0.205 0.026 0.733
-@item Language @tab Documentation @tab Identifier @tab Requirements
-@item Asymptote @tab org-babel-doc-asymptote @tab asymptote @tab [[http://asymptote.sourceforge.net/][asymptote]], [[http://asymptote.sourceforge.net/doc/Editing-modes.html][asy-mode]]
-@item C @tab [[file:languages/org-babel-doc-C.org][org-babel-doc-C]] @tab C @tab none
-@item Clojure @tab [[file:languages/org-babel-doc-clojure.org][org-babel-doc-clojure]] @tab clojure @tab [[http://clojure.org/][clojure]], [[http://www.emacswiki.org/emacs/clojure-mode.el][clojure-mode]], [[http://common-lisp.net/project/slime/][slime]], [[http://clojure.codestuffs.com/][swank-clojure]]
-@item css @tab org-babel-doc-css @tab css @tab none
-@item ditaa @tab org-babel-doc-ditaa @tab ditaa @tab [[http://ditaa.org/ditaa/][ditaa]] (bundled with Org-mode)
-@item Graphviz @tab org-babel-doc-dot @tab dot @tab [[http://www.graphviz.org/][dot]]
-@item Emacs Lisp @tab org-babel-doc-emacs-lisp @tab emacs-lisp @tab none
-@item gnuplot @tab org-babel-doc-gnuplot @tab gnuplot @tab [[http://www.gnuplot.info/][gnuplot]], [[http://cars9.uchicago.edu/~ravel/software/gnuplot-mode.html][gnuplot-mode]]
-@item Haskell @tab org-babel-doc-haskell @tab haskell @tab [[http://www.haskell.org/][haskell]], [[http://projects.haskell.org/haskellmode-emacs/][haskell-mode]], [[http://www.haskell.org/haskellwiki/Haskell_mode_for_Emacs#inf-haskell.el:_the_best_thing_since_the_breadknife][inf-haskell]], [[http://people.cs.uu.nl/andres/lhs2tex/][lhs2tex]]
-@item Matlab @tab [[file:languages/org-babel-doc-octave-matlab.org][org-babel-doc-octave-matlab]] @tab matlab @tab matlab, [[http://sourceforge.net/projects/matlab-emacs/][matlab.el]]
-@item LaTeX @tab [[file:languages/org-babel-doc-LaTeX.org][org-babel-doc-latex]] @tab latex @tab [[http://www.latex-project.org/][latex]], [[http://www.gnu.org/software/auctex/][auctex]], [[http://www.gnu.org/software/auctex/reftex.html][reftex]]
-@item Objective Caml @tab org-babel-doc-ocaml @tab ocaml @tab [[http://caml.inria.fr/][ocaml]], [[http://www-rocq.inria.fr/~acohen/tuareg/][tuareg-mode]]
-@item Octave @tab [[file:languages/org-babel-doc-octave-matlab.org][org-babel-doc-octave-matlab]] @tab octave @tab octave
-@item OZ @tab [[file:languages/org-babel-doc-oz.org][org-babel-doc-oz]] @tab oz @tab [[http://www.mozart-oz.org/][Mozart]] which includes a major mode
-@item Perl @tab org-babel-doc-perl @tab perl @tab [[http://www.perl.org/][perl]], [[http://www.emacswiki.org/emacs/CPerlMode][cperl-mode]] (optional)
-@item Python @tab org-babel-doc-python @tab python @tab [[http://www.python.org/][python]], [[https://launchpad.net/python-mode][python-mode]] (optional)
-@item R @tab [[file:languages/org-babel-doc-R.org][org-babel-doc-R]] @tab R @tab [[http://www.r-project.org/][R]], [[http://ess.r-project.org/][ess-mode]]
-@item Ruby @tab org-babel-doc-ruby @tab ruby @tab [[http://www.ruby-lang.org/][ruby]], [[http://www.ruby-lang.org/][irb]], [[http://github.com/eschulte/rinari/raw/master/util/ruby-mode.el][ruby-mode]], [[http://github.com/eschulte/rinari/raw/master/util/inf-ruby.el][inf-ruby mode]]
-@item Sass @tab org-babel-doc-sass @tab sass @tab [[http://sass-lang.com/][sass]], [[http://github.com/nex3/haml/blob/master/extra/sass-mode.el][sass-mode]]
-@item GNU Screen @tab [[file:languages/org-babel-doc-screen.org][org-babel-doc-screen]] @tab screen @tab [[http://www.gnu.org/software/screen/][screen]], a terminal
-@item shell @tab org-babel-doc-sh @tab sh[fn:1] @tab a shell
-@item SQL @tab org-babel-doc-sql @tab sql @tab none
+Org-babel can evaluate/execute/compile the following languages. See the
+language specific documentation on Worg for details.
+
+FIXME: How are we going to refer to the external documentation?
+
+@c BEGIN RECEIVE ORGTBL org-babel-lang-table
+@multitable @columnfractions 0.583 0.417
+@item Language @tab Identifier
+@item Asymptote @tab asymptote
+@item C @tab C
+@item Clojure @tab clojure
+@item css @tab css
+@item ditaa @tab ditaa
+@item Graphviz @tab dot
+@item Emacs Lisp @tab emacs-lisp
+@item gnuplot @tab gnuplot
+@item Haskell @tab haskell
+@item Matlab @tab matlab
+@item LaTeX @tab latex
+@item Objective Caml @tab ocaml
+@item Octave @tab octave
+@item OZ @tab oz
+@item Perl @tab perl
+@item Python @tab python
+@item R @tab R
+@item Ruby @tab ruby
+@item Sass @tab sass
+@item GNU Screen @tab screen
+@item shell @tab sh[fn:1]
+@item SQL @tab sql
 @end multitable
-@c END RECEIVE ORGTBL org_babel_lang-table
+@c END RECEIVE ORGTBL org-babel-lang-table
 
 @ignore
+The original table from reference.org is below; I'm just using the first column for now.
+
+#+ORGTBL: SEND org-babel-lang-table orgtbl-to-texinfo
+  | Language       | Identifier |
+  |----------------+------------|
+  | Asymptote      | asymptote  |
+  | C              | C          |
+  | Clojure        | clojure    |
+  | css            | css        |
+  | ditaa          | ditaa      |
+  | Graphviz       | dot        |
+  | Emacs Lisp     | emacs-lisp |
+  | gnuplot        | gnuplot    |
+  | Haskell        | haskell    |
+  | Matlab         | matlab     |
+  | LaTeX          | latex      |
+  | Objective Caml | ocaml      |
+  | Octave         | octave     |
+  | OZ             | oz         |
+  | Perl           | perl       |
+  | Python         | python     |
+  | R              | R          |
+  | Ruby           | ruby       |
+  | Sass           | sass       |
+  | GNU Screen     | screen     |
+  | shell          | sh[fn:1]   |
+  | SQL            | sql        |
+
 
-#+ORGTBL: SEND org-babel-lang-table orgtbl-to-texinfo :splice t :skip 2
   | Language       | Documentation                                                                   | Identifier | Requirements                                                                                                                                                                                                                                                                                |
   |----------------+---------------------------------------------------------------------------------+------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
   | Asymptote      | org-babel-doc-asymptote                                                         | asymptote  | [[http://asymptote.sourceforge.net/][asymptote]], [[http://asymptote.sourceforge.net/doc/Editing-modes.html][asy-mode]]                                                                                                                                                                     |
@@ -10897,31 +10938,34 @@ body
   | GNU Screen     | [[file:languages/org-babel-doc-screen.org][org-babel-doc-screen]]               | screen     | [[http://www.gnu.org/software/screen/][screen]], a terminal                                                                                                                                                                                                                                 |
   | shell          | org-babel-doc-sh                                                                | sh[fn:1]   | a shell                                                                                                                                                                                                                                                                                     |
   | SQL            | org-babel-doc-sql                                                               | sql        | none                                                                                                                                                                                                                                                                                        |
+
+
 @end ignore
 
-  To add support for a particular language to your Org-babel
-  installation first make sure that the requirements of the language
-  are met, then add a line like the following to your Emacs
-  configuration, (replace "identifier" with one of the
-  entries in the Identifier column of the table).
-  @example
-    (require 'org-babel-identifier)
-  @end example
+To add support for a particular language to your Org-babel installation
+first make sure that the requirements of the language are met, then add a
+line like the following to your Emacs configuration, (replace "identifier"
+with one of the entries in the Identifier column of the table).
+
+@example
+(require 'org-babel-identifier)
+@end example
 
 @section Header Arguments
     :PROPERTIES:
     :CUSTOM_ID: header-arguments
     :END:
 
-Definitions of all Org-babel header arguments are given [[header-argument-specific-documentation][below]].  In
-addition, some languages may add their own header arguments.  Please
-see the language-specific documentation for information on
-language-specific header arguments.
+Definitions of all Org-babel header arguments are given
+[[header-argument-specific-documentation][below]].  In addition, some
+languages may add their own header arguments.  Please see the
+language-specific documentation for information on language-specific header
+arguments.
 
 @subsection Using Header Arguments
 
-The values of header arguments can be set in three different ways,
-each more specific than the last.
+The values of header arguments can be set in four different ways, each
+more specific (and having higher priority) than the last.
 
 @subsubsection System-wide
     :PROPERTIES:
@@ -10955,10 +10999,20 @@ each more specific than the last.
 
 @subsubsection Org-mode Properties
 
- Header arguments are also read from [[http://orgmode.org/manual/Properties-and-Columns.html#Properties-and-Columns][Org-mode properties]], which
- means they can be set on the outline header level.  For example, the
- value of the =:cache= header argument will default to true in all
- source code blocks under the following example of an Org-mode outline header:
+Header arguments are also read from
+[[http://orgmode.org/manual/Properties-and-Columns.html#Properties-and-Columns][Org-mode
+properties]], which can be set on a buffer-wide or per-heading basis. An
+example of setting a header argument for all code blocks in a buffer is
+
+#+begin_example 
+#+property: tangle yes
+#+end_example
+
+When properties are used to set default header arguments, they are looked up
+with inheritance, so the value of the =:cache= header argument will default
+to true in all source code blocks in the subtree rooted at the following
+heading:
+
  @example
    * outline header
      :PROPERTIES: