Skip to content

Jason-S-Ross/ox-context

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 

Repository files navigation

ox-context

This is a ConTeXt exporter for Org Mode.

Installation

Clone the repo to the desired location, then add that directory to your load-path:

git clone https://github.com/Jason-S-Ross/ox-context

Then, in your customization file, add

(add-to-list 'load-path "~/path-to-repo/ox-context/")

Examples

See the example repo for examples.

Document Customization

Each element type in the Org document is associated with a custom ConTeXt command whose name and definition is set by a customization variable. When you export a document, the command definition associated with each type of org element is exported into the ConTeXt document preamble. The element itself is formatted by the associated command. This allows documents to be customized by either changing the customization variable associated with each element type, or by inserting new command definitions into the document preamble after the original definitions in order to override them. There are several ways to insert command definitions into the preamble:

#+context_header
This keyword adds literal ConTeXt code at the beginning of the document preamble.

Note that these entries will be overriden by presets and other default definitions, so usually you want to use the _extra variant (unlike in ox-latex).

#+context_header_extra
This keyword inserts literal ConTeXt code directly into the document preamble after the default command definitions.

Here’s how to use it to set the paper size:

#+context_header_extra: \setuppapersize[A4]
    

Here’s the procedure to change description items:

  1. Find that description items are customized by org-context-description-command which has the associated ConTeXt command name OrgDesc.
  2. Add the following to our document:
    #+context_header_extra: \setupdescription[OrgDesc][headstyle=bold]
            

This could also be used to insert an environment file to customize multiple commands:

#+context_header_extra: \environment /home/jason/ctx-envs/my-env
    
#+context_snippet
This keyword allows a named “snippet” to be inserted into the document preamble after the default command definitions. Snippets are stored in the org-context-snippets-alist customization variable. A new snippet can be added to this list like this:
(add-to-list
'org-context-snippets-alist
'("paper-a4" . "\\setuppapersize[A4]")
t)
    

Then the snippet can be used in the document as follows:

#+context_snippet: paper-a4
    

As with #+context_header_extra, snippets can override existing command definitions.

#+context_preset
This keyword selects the document Preset. A Preset is a collection of ConTeXt instructions to insert into the preamble, a list of snippets, and an “inner template” that specifies overall document structure.

The following code adds the “paper-a4” snippet that we previously defined to the article template:

(let ((article-preset
    (cdr (assoc "article" org-context-presets-alist))))
(plist-put article-preset :snippets
            (cons "paper-a4" (plist-get article-preset :snippets))))
    

Alternatively, one could modify the literal code of the article template directly and skip declaring the snippet:

(let ((article-preset
        (cdr (assoc "article" org-context-presets-alist))))
(plist-put article-preset :literal
            (concat (plist-get article-preset :literal)
                    "\n\\setuppapersize[A4]")))
    

Features and Configuration

NOTE
In this section, any customization variables are prefixed with org-context- if not stated otherwise.
NOTE
Additional documentation on customization variables can be viewed with customize-group.

Tables

The entire table gets styled by whatever global xtable options are set in the document preamble by a command like \setupxtable[option=value]. Additionally, each part of the table has associated named styles applied to it. The styles depend on the position of the part in the table structure. Styles are applied in a cascading manner, with table styles getting overridden by section styles, which are overridden by row styles, which are finally overridden by cell styles.

Table Section Element Styling

Note
Customization variables in this section are prefixed with org-context-table.

Each table section gets a named style as follows:

NameElisp Customization VariableDefault ConTeXt nameKey
Headerheader-styleOrgTableHeader:h
Bodybody-styleOrgTableBody:b
Footerfooter-styleOrgTableFooter:f

Specific rows get named styles as well:

NameElisp Customization VariableDefault ConTeXt NameKey
Top Row[fn:1]toprow-styleOrgTableTopRow:n
Bottom Row[fn:2]bottomrow-styleOrgTableBottomRow:s
Header Top Row[fn:3]header-top-styleOrgTableHeaderTop:ht
Header Bottom Row[fn:3]header-bottom-styleOrgTableHeaderBottom:hb
Header Mid Row[fn:3]header-mid-styleOrgTableHeaderMid:hm
Footer Top Row[fn:4]footer-top-styleOrgTableFooterTop:ft
Footer Bottom Row[fn:4]footer-bottom-styleOrgTableFooterBottom:fb
Footer Mid Row[fn:4]header-mid-styleOrgTableFooterMid:fm
Row Group Top Rowrowgroup-start-styleOrgTableRowGroupStart:rgs
Row Group Bottom Rowrowgroup-end-styleOrgTableRowGroupEnd:rge

Likewise, cells in special columns get a named style depending on their position. The following special columns are defined:

NameElisp Customization VariableDefault ConTeXt NameKey
Left Columnleftcol-styleOrgTableLeftCol:w
Right Columnrightcol-styleOrgTableRightCol:e
Column Group Rightcolgroup-start-styleOrgTableColGroupStart:cgs
Column Group Leftcolgroup-end-styleOrgTableColGroupEnd:cge

Finally, cells at special positions are defined:

NameElisp Customization VariableDefault ConTeXt NameKey
Top Lefttopleft-styleOrgTableTopLeftCell:nw
Top Righttopright-styleOrgTableTopRightCell:ne
Bottom Leftbottomleft-styleOrgTableBottomLeftCell:sw
Bottom Rightbottomright-styleOrgTableBottomRightCell:se

Each of these styles can be configured like any other command. Additionally, there is a key that can be passed to #+attr_context to customize the styling of each element defined above.

Here’s an example table with the start of each row group set to have a blue background:

#+attr_context: :rgs background=color,backgroundcolor=blue
| H1 | H2 | H3 |
|----+----+----|
|  1 |  2 |  3 |
|  4 |  5 |  6 |
|----+----+----|
|  7 |  8 |  9 |
|  4 |  5 |  6 |
|----+----+----|
|  7 |  8 |  9 |
|  4 |  5 |  6 |
|----+----+----|
|  7 |  8 |  9 |
H1H2H3
123
456
789
456
789
456
789

Additional configuration for tables

The following additional configuration options are available for tables.

NameElisp Customization VariableDocument-level KeywordTable-level Keyword
Locationtable-location#+table_location:location
Headertable-header#+table_head:header
Footertable-footer#+table_foot:footer
Optiontable-option#+table_option:option
Table Styletable-style#+table_style:table-style
Float Styletable-float-style#+table_float:float-style
Splittable-split#+table_split:split
Footers
Org mode doesn’t formally support table footers. However, if enabled, footers can be inferred from tables that have 3 or more row groups. The last row group of such tables is considered the footer. Set this value to repeat to have footers repeat across pages. Any non-nil value will have associated named styles applied to footer rows.

Images

The following configuration options are available for images:

NameElisp Customization VariableImage-level Keyword
Float:float
Scaleimage-default-scale:scale
Widthimage-default-width:width
Heightimage-default-height:height
Placementimage-default-placement:placement
Optionsimage-default-options:options

Syntax Highlighting

Standard Syntax Highlighting (default)

ConTeXt does not support many languages by default. Vim syntax highlighting is recommended.

Configuration

Language aliases are defined in the highlighted-langs-alist customization variable. Language aliases are used in order to avoid invalid characters in the ConTeXt code and to alias from the Emacs language name to the ConTeXt name.

Vim Syntax Highlighting

The ConTeXt Vim highlighting module provides support for a large range of languages. Vim syntax highlighting is disabled by default.

Configuration

Language aliases are defined in the vim-langs-alist customization variable. Language aliases are used to rename a language in order to avoid invalid characters in the ConTeXt code and to alias from the Emacs language name to the Vim name.

Enabling Vim Syntax Highlighting

Vim syntax highlighting is enabled globally by setting syntax-engine customization variable to 'vim. Vim syntax highlighting can set on a per-document basis with #+options: syntax:vim.

The snippet syntax-pigmints is provided to give syntax highlighting that may superficially resemble the default setting of a popular syntax highlighting package written in python…

Custom Indices

The customization variable texinfo-indices-alist allows custom index keywords to be used in documents. The motivating example for this is the texinfo exporter which supports #+CINDEX, #+FINDEX, #+KINDEX, #+PINDEX, #+TINDEX, and #+VINDEX keywords for concepts, functions, keystrokes, programs, datatypes, and variables respectively.

An indexing keyword can be placed in the document to define where a term is used. The corresponding list of indices can be placed with the #+TOC: command.

#+CINDEX: Defining indexing entries
Indexing is presented by example.

#+TOC: cp

New indices may be defined as follows:

(add-to-list
   'org-context-texinfo-indices-alist
   '("myindex" . (:keyword "MYINDEX" :command "MySpecialIndex"))
   t)

They can then be used throughout documents as follows:

#+MYINDEX: Defining arbitrary indexing entries
Indexing is presented by example.

#+TOC: myindex

Additionally, indices defined this way can be used with headline properties just like with the texinfo exporter:

* My Custom Index
:PROPERTIES:
:INDEX: myindex
:END:

Tables of Contents

In addition to any custom indices, the #+TOC keyword can be used with the following values:

figures
Adds a list of figures.
equations
Adds a list of equations.
references
Adds a bibliography.
definitions
Places the default index.
headlines
Places a table of contents. Additional options are supported:
depth
An integer in the command will limit the toc to this depth.
local
If present, limits the scope of the toc to this section.
listings
Adds a list of code listings.
verses
Adds a list of verse blocks.
quotes
Adds a list of quote blocks.
examples
Adds a list of example blocks.

In-Text Keywords

Document Structure and Section Placement

The overall sectioning structure of the document is defined by the “inner template”. This is a format spec string that locates each part of the document. Inner templates are listed in inner-templates-alist.

Here’s an example inner template:

\startfrontmatter
\startOrgTitlePage
\OrgMakeTitle
%t
\stopOrgTitlePage
%f
\stopfrontmatter

\startbodymatter
%c
\stopbodymatter

\startappendices
%a
%i
\stopappendices

\startbackmatter
%b
%o
\stopbackmatter

The format string keys are as follows:

?f
Sections with the property :FRONTMATTER:
?c
Normal sections
?a
Sections with the property :APPENDIX:
?b
Sections with the property :BACKMATTER:
?o
Sections with the property :COPYING:
?i
Sections with the property :INDEX:
?t
Table of contents

The inner template exists primarily to allow separation to be inserted between different parts of a document, but it also allows the different parts to be reordered in the exported document if desired.

Footnotes

[fn:4] Only applies if the table has more than one footer row. [fn:3] Only applies if the table has more than one header row. [fn:2] Only applies if the table doesn’t have a footer. [fn:1] Only applies if the table doesn’t have a header.