Introduction
============

If you're reading this, either you saw "\input pitex" at the beginning
of the documentation of one of my packages, or you spend desperate hours
browsing CTAN, or you're Arnaud Schmittbuhl. In any case, you're welcome
to use the PiTeX macros, provided that you don't forget that: nothing
is guaranteed; changes might occur without warning nor retrocompatibility;
the documentation isn't necessarily up-to-date; and, if you still want
to, you must load PiTeX with "\input pitex" on top of plain TeX, using
LuaTeX.

What is PiTeX? Originally, it was a set of files I loaded with plain TeX
to typeset documentation for my packages. But it's not just a few macros
anymore, but rather a format in progress. The format might never see the
public light, but if it does, its originality (compared to existing
format) will be an organization based on the Gates package: everything
will be highly customizable, not because there are tons of options
(although that can be the case too), but because big operations are
divided into gates, i.e. macros with a handle that you can control without
having to rewrite (nor understand) the big operation you're modifying;
which big operation also keeps its integrity, because removing or adding
something is neatly done. It also means that PiTeX can be changed
piecewise, and made into something that bears little resemblance to the
original code. In other words, there is nothing private, nothing forbidden.
For the moment, only sectionning commands and the output routine, plus
callback management in Lua and \everypar, are written with gates. See
the Gates documentation for further information.

Another thing with PiTeX is that it will rely heavily on external packages.
There will be as little PiTeX-only code as possible. Rather, in line
with Gates, each area will be independant code able to work with other
formats. That is no simple task, though, and far from complete. For
instance, the user's interface is made with YaX, which can be used (and
is used) elsewhere.

PiTeX uses three types of files: mandatory external packages, i.e.
independant code that PiTeX can't do without, optional external packages,
i.e. independant code that can be used, but is not automatically loaded,
and mandatory PiTeX-only files. All mandatory files aren't necessary to
the same degree, though, and in the future switches might be available
to load only some of them. Currently, the files are:

------------------------------------------------------------------
|                **Mandatory external packages**                 |
------------------------------------------------------------------
| texapi    | Macros to write independant code.                  |
| YaX       | User's interface (and convenient programming tool) |
|           | with "key = value" style).                         |
| Gates     | Overall architecture for modular code.             |
| Navigator | PDF features (links, bookmarks...)                 |
|           | Currently used by sections, but might become       |
|           | non-mandatory (although strongly recommended).     |
------------------------------------------------------------------

---------------------------------------------------------------------------
|                        **Mandatory PiTeX files**                        |
---------------------------------------------------------------------------
| pitex.tex            | The main file that inputs the other,             |
|                      | and contains a few macros.                       |
| lua.ptx              | Lua-related macros.                              |
| base.ptxlua          | Lua functions, input in the previous file.       |
| files.ptx            | Dealing with files.                              |
| fonts.ptx            | Interface for fonts; relies on the next file.    |
| fonts.ptxlua         | The Lua fontloader; should become independant    |
|                      | some day.                                        |
| foundry-settings.lua | Default settings for the fontloader.             |
| sections.ptx         | Sectionning commands.                            |
| blocks.ptx           | Blocks (delimited text with special formatting). |
| references.ptx       | Labels and references.                           |
| verbatim.ptx         | Typesetting verbatim material.                   |
| inserts.ptx          | Footnotes and figures.                           |
| output.ptx           | Page layout and output routine.                  |
---------------------------------------------------------------------------

The following can be used with PiTeX; actually I only list the packages
I've written, but anything working with plain TeX (e.g. TikZ) works with
PiTeX.

----------------------------------------------------------------------------
|                      **Optional external packages**                      |
----------------------------------------------------------------------------
| Librarian   | To create bibliographies without BibTeX.                   |
| Lecturer    | For screen presentations.                                  |
| Interpreter | To write text with non-TeX markup (as this documentation); |
|             | Interpreter does the conversion on the fly.                |
----------------------------------------------------------------------------

The PiTeX distribution also contains "i-pitex.lua", an interpretation
file for Interpreter used to typeset documentations, like the one you
are currently reading. Which is why you can read it quite comfortably
as a plain text file in a text editor (see "pitex-doc.txt").

The rest of this document is a terse description of existing commands,
parameters, and of course, gates.





Fonts (fonts.ptx and fonts.ptxlua)
==================================

The fontloader uses gates, but only superficially. They won't be
documented here.

\setfont <command>:<attributes>
Sets <command> to call the font described in <attributes>; all defaults
to the values of the !metafont parameter. If <command> is \mainfont, the
font is called at once. Also, \codefont is used in some places (e.g.
verbatim).

> name
The family name of the font; e.g. Chaparral Pro for the main text of
this document.

> size (dimension)
The size of the font.

> small (dimension)
The size of the font when \small is called. Can be a relative value by
prefixing it with "-" or "+", in which case it is set relative to ?size.

> verysmall (dimension)
The size (possibly relative) for \verysmall.

> big (dimension)
The size (possibly relative) for \big.

> verybig (dimension)
The size (possibly relative) for \verybig.

> bold (font modifier)
The modifier used for the bold version of the font, without the leading slash;
!metafont sets it to "Bold".

> italic (font modifier)
Same as !bold for the italic version; set to "Italic" by !metafont.

> math (true or false)
If true, math fonts will be created.

> features
Well, err, font features...

> slant (angle)
The slant applied to the font to create a fake italic.

> slantsc (angle)
The slant applied to the font to create fake italic smallcaps; if not
given, defaults to ?slant.

There's actually much more going under the hood, but "font.ptxlua" (the
font loader itself) is a work in progress, and undocumented.

The same macros as in plain TeX can be used, except they're cumulative,
i.e. "\it\bf" switches to a bold italic.

\it
Switches to italics.

\rm
Switches to roman.

\bf
Switches to bold.

\rg
Switches to regular weight.

\sc
Switches to small capitals.

\lc
Switches to lower case (i.e. not small caps).

\ital <text>
Typesets <text> in italics.

\bold <text>
Typesets <text> in bold.

\scap <text>
Typesets <text> in small caps.

\rom <text>
Typesets <text> in roman.

\emph <text>
Typesets <text> in italics or roman, depending on whether the current
font is roman or italics, respectively.

\underline <text>
Underlines <text>. Wow.

\small
Switches to small font.

\verysmall
Switches to very small font.

\big
Switches to big font.

\verybig
Got it?

\normalsize
Switches to default size.

\smaller
Switches to the font smaller than the current one (e.g. \normalsize if
you're currently using \big).

\bigger
Same as \smaller, the other way around.

\color <color><text>
Typesets <text> with <color>, which should be a triplet "R G B" with
each value between 0 and 1.





Sections (sections.ptx)
=======================

Sections are among the victims of my fanaticism for grid-typesetting.



  Main sectioning commands
  ~~~~~~~~~~~~~~~~~~~~~~~~

\declaresection <type><level>
Creates a new section type with <level>. This is not necessary to make
\sectioncommand work with <type>, but with it all declared sections of
level larger than <level> are reset (i.e. their counters are set to 0).
Sections with <type> chapter, section, subsection and paragraph are
already declared.

\incrementsection <type>
Increments the counter of section <type>. If <type> hasn't been declared,
a new <type> is created, but without a level.

\getsectioncounter <type>
Returns the value of section <type>'s counter, or -1 if there is no
section of that type.

\sectioncommand <type><title><alternate title>[<label>]
Creates a section heading of type <type> with <title>. See the details
of the gates involved below. The <type> refers to the parameter of the
same name. The <alternate title> is very likely to disappear.

\chapter <title>[<label>]
Equivalent to \sectioncommand{chapter}{<title>}{<title>}[<label>].

\section <title>[<label>]
Equivalent to \sectioncommand{section}{<title>}{<title>}[<label>].

\subsection <title>[<label>]
Equivalent to \sectioncommand{subsection}{<title>}{<title>}[<label>].

\paragraph <title>[<label>]
Equivalent to \sectioncommand{paragraph}{<title>}{<title>}[<label>].

\ifsectiontitle
A conditional that is true when the section title is being typeset (sets by
the section_pre gate below.

\sectioninfile <optional star><title><space><type><space><file><space>
Creates a section with the contents of a file, unless there's an optional
star (useful to typeset only parts of a big document); <title> is a
\freedef argument, hence it can be given between braces, double quotes
or slashes (but the <space> is nonetheless mandatory); <type> is a section
type, and <file> is a file to be input: it shouldn't have an extension
(tex files are searched), but it can be a path with "/" as a separator.
A \label is also created, with the tail of <file> as its argument. In
other words, the following:

          \sectioninfile "A chapter" chapter mydir/myfile

is equivalent to:

          \chapter{A chapter}
          \label{myfile}
          \input mydir/myfile.tex

The \sectioncommand macro only contains a list gate, "section", itself
containing the gates typesetting a section heading; all the gates belong
to the "Section" family associated with the \Section command. Here are
all the gates involved; the first number between parentheses indicates
how many arguments the gate should receive, the second how many it
returns.

-------------------------------------------------------------------------------
| section | (4, 0) | section_break     | (1, 0) | section_vmode      | (1, 0) |
|         |        |                   |        | section_clearpage  | (1, 0) |
|         |        |                   |        | section_beforeskip | (1, 0) |
|         |        | section_advance   | (1, 0) |                    |        |
|         |        | section_advance   | (1, 0) |                    |        |
|         |        | section_bookmark  | (4, 0) |                    |        |
|         |        | section_toc       | (3, 0) |                    |        |
|         |        | section_pre       | (0, 0) |                    |        |
|         |        | section_typeset   | (2, 2) | section_number     | (2, 3) |
|         |        |                   |        | section_heading    | (3, 2) |
|         |        |                   |        | section_addfont    | (2, 2) |
|         |        |                   |        | section_addcolor   | (2, 2) |
|         |        |                   |        | section_do         | (2, 0) |
|         |        | section_post      | (0, 0) |                    |        |
|         |        | section_afterskip | (1, 0) |                    |        |
-------------------------------------------------------------------------------

Here's how the gates work:

> section <type><title><alternate title><label>
The main list gate that contains all sections. In what follows, when I
mention an attribute, I mean the attribute of the parameter <type>.

> section_break <type>
An l-gate managing whatever must happen before the section title is
typeset.

> section_vmode <type>
Inserts a \par and removes last skip. (Conditional: ?vmode is =true.)

> section_clear <type>
Inserts a \clearpage. (Conditional: ?clear is =true.)

> section_beforeskip <type>
Creates a vertical skip before the heading. If the current page cannot
accommodate ?beforeskip + ?minimum + ?afterskip worth of lines, then
the section heading is typeset on the next page (using \breakpage). If
the current page can accommodate the section, a skip of ?beforeskip
lines is inserted. The gate doesn't return anything. (Conditional:
?clear is not =true.)

> section_advance <type>
Increments the section counter, and resets the counters of those sections
whose level is larger than <type>'s level (provided <type> has been
declared with \declaresection and thus given a level). The gate doesn't
return anything.

> section_bookmark <type><title><alternate title><label>
The bookmark is created with Navigator's \outline command as follows:

          \outline[meta = <type>bookmark]{<bookmarklevel>}[<label>]{<alternate title>}

only if ?bookmarklevel is defined. For types chapter, section, subsection
and paragraph, the related !chapterbookmark, !sectionbookmark,
!subsectionbookmark and !paragraphbookmark parameters are predefined,
with simply ?meta set to =navigator. The <alternate title> is likely
to disappear, since Navigator can handle things correctly. The gate
doesn't return anything. (Conditional: ?link is =true.)

> section_toc <type><title><alternate title>
Writes what should be written to the auxiliary file for the next run
to produce a table of contents. The gate doesn't return anything.
(Conditional: ?toc is =true.)

> section_pre
Prepares the typesetting: open a group, sets \maintextfalse and
\sectiontitletrue, and sets a LuaTeX attribute to 0 (so the section title
is marked and can be spotted in the output routine). The gates doesn't
return anything.

> section_typeset <type><title>
A list gate containing the gates used to typeset the section heading.
It returns its final two arguments if only because list gate automatically
return. See description below.

> section_post
Closes the group opened in section_pre. The gate doesn't return anything.

> section_afterskip <type>
Creates a vertical skip of ?afterskip lines. Also, calls \removenextindent
if ?removenextindent is =true. The gate doesn't return anything.
(Conditional: ?inline is not =true.)

Here are the gates contained in section_pre. Beware, there the nature
of the passed arguments slightly changes.

> section_indent <type>
Goes into horizontal mode and inserts an indent of width ?indent. The
gate doesn't return anything.

> section_number <type><title>
Sets the section number, if ?number isn't =none. The number is surrounded
by ?beforenumber and ?afternumber, converted to roman or arabic number
according to the value of ?number, and the whole is passed to ?numbercommand
(if it exists). The gate returns the following three arguments:
<type><number><title>, where <number> is what's just been described.

> section_heading <type><number><title>
Sets the <title>: it is prefixed with <number>, passed to ?function if
it exists, and suffixed with ?aftertitle if any. The gate returns <type>
and <title> as just described.

> section_addfont <type><title>
Prefixes <title> with the value of font and returns its two arguments.

> section_addcolor <type><title>
Adds color to the title and returns its two arguments. (Conditional:
?color is =true.)

> section_do <type><title>
At last! Inserts an horizontal skip of width ?indent, typesets <title>,
and if ?inline isn't =true, sets \rightskip to ?ragged. Oh, yes, this
could be divided into smaller gates. The gates doesn't return anything.

The relevant parameters are the one corresponding to the type of the
section, i.e. !chapter, !section, !subsection, !paragraph, which all
have !metasection as their meta-parameter. The relevant attributes are:

> vmode (true or false)
If =true, goes into vertical mode before typesetting the heading.

> clear (true or false)
If =true, the section starts on a new page.

> beforeskip (glue)
The skip added before the heading.

> afterskip (glue)
The skip added after the heading.

> minimum (number)
The minimum number of lines that should be present on the page after the
section heading. The "section_skip" gate above starts a new page if
?beforeskip + ?afterskip + ?minimum can't be accommodated.

> inline (true or false)
If =true, the section heading is inserted at the beginning of the following
paragraph.

> number (arabic, roman or none)
The way the section number should be typeset; =none means the number
isn't typeset.

> beforenumber
Material to be added before the section number.

> afternumber
Material to be added after the section number.

> numbercommand (control sequence)
A macro to which the section number (surrounded by ?beforenumber and
?afternumber) is passed.

> function (control sequence)
A macro to which the section title is passed.

> aftertitle
Material added after the section title.

> font
Font for the heading.

> color (a triplet of values)
Color for the heading.

> indent (glue)
The value of the glue added before the section title.

> ragged (glue)
The value of \rightskip for the heading.

> toc (true or false)
Sets whether the section should be added to the table of contents or
not.

> removenextindent (true or false)
Sets whether the next paragraph should be unindented.

> link (true or false)
Sets whether a bookmark should be created with the section's title.

> bookmarklevel (number)
The level of the bookmark created for the section (how surprising).
Further specification of the bookmark is done with !chapterbookmark,
!sectionbookmark, !subsectionbookmark, !paragraphbookmark, whose only
specification is that ?meta is set to =navigator. New "<type>bookmark"'s
can be created, of course. See the documentation of Navigator for advanced
use.



  Various commands
  ~~~~~~~~~~~~~~~~

\tableofcontents
Writes the table of contents (needs two runs). Not customizable for the
time being!

\newbreakpenalty <command>
Defines <command> as a number below "-10000", suffixed with a \relax.
The idea is to use it to break a page and check it in the output routine.

\clearpage
Fills the rest of the page with white space.

\clearpagepenalty
Penalty associated with \clearpage.

\breakpage
Same as \clearpage. They shouldn't be used for the same reasons. I use
\clearpage at the end of a chapter, and \breakpage elsewhere (e.g. when
a section heading would be orphaned and must move to the next page). The
latter triggers nothing special, but the former can be identified in the
output routine and for instance suppress footers.

\breakpagepenalty
Penalty associated with \breakpage.

\needspace <dimen>
Moves to the next page if there's less than <dimen>.

\iflines <number><true><false>
Executes <true> if there's at least <number> lines left on the page, and
<false> otherwise.

\ignorepars <material>
Ignores incoming \par commands (and spaces too) and executes <material>.
Useful when a blank line looks good in the source but you don't want it
to signal a paragraph's end. The command is used by sectionning commands,
so that if the section's title is supposed to be inserted at the beginning
of the next paragraph (e.g. if ?inline is =true), you can nonetheless
leave a blank line after the command.



References (references.ptx)
===========================

There is a nice reference system, but it is a mess and should be rewritten
in Lua. So it isn't fully described here.

\label <name>
Sets a label with <name>.

\ref [<pre>][<post>] <reference type> {<name>}
Makes a reference. Beware of the syntax: label should be enclosed between
braces, because the left brace is the delimiter for <reference name>,
which in turn should be enclosed in braces. E.g. a call is:

          \ref page {mylabel}

What is returned depends on <reference type>. If it is empty, then what
is returned is the value of \ptx@label when \label{<name>} was issued.
I think some commands define \ptx@label (nice in blocks, for instance).
Otherwise, <reference type> can be page, chapter, section, subsection,
paragraph or footnote (the latter if and only if \label was issued in a
footnote). The returned text is prefixed with <pre> and suffixed with
<post>.

Also, if <reference type> is page, it may take three runs to make things
work, because it is checked whether the returned value is the current
page, in which case nothing is printed (it's stupid to refer to the
current page). As mentioned above, this is a mess.

There also are commands like "\sref{label}" and the like, which are
shorthands for e.g. "\ref[ section~][] section {label}".





Blocks (blocks.ptx)
===================


Blocks are what are called environments elsewhere: they mark up a section
of the document, and generally apply some special operations. Given a
block myblock, it is launched with "\myblock", closed with "\myblock/"
and continued with "\myblock|". As you might imagine, this implies poking
at the next token, which in some rare case might be troublesome; hence,
\myblock can be followed by an optional ">" whose only goal is to protect
the next token. (You can also use a \relax, of course.)

\newblock <optional star><command><pre><optional start><optional middle><post>
Defines <command> as a block. If the first optional star is present, the
block is executed inside a group. If the second optional star is present,
then the <middle> argument should be present too. The block is defined
as follow: <pre> is executed at the beginning (i.e. "\myblock" or
"\myblock>"), <middle> is executed when the block is continued (i.e.
"\myblock|"), and <post> is executed when the block is closed (i.e.
"\myblock/"). If <middle> is not given, then "\myblock|" does nothing.
For instance, the following defines a grouped block (so the \rightskip
setting doesn't affect the rest of the document); note the \par at the
end, so the paragraph is built before the group is closed:

          \newblock*\raggedblock{\rightskip=0pt plus 1fil\relax}{\par}

And here's a simple example with a middle part:

          \newblock\listblock{\vskip\baselineskip-- }
                            *{\par-- }
                             {\vskip\baselineskip}

The continuation part can be used as a partial block opening: some markers
are repeated (the dash) others are not (the vertical space).

\newblocktype <command><pre><middle><post>
Defines <command> as a block definition command like \newblock with
<pre>, <middle> and <post> to be executed by default before the user-supplied
versions. The \newblock command itself has been thus defined, with empty
arguments. Arguments, after:

          \newblocktype\newlist{\vskip\baselineskip--}
                               {\par--}
                               {\vskip\baselineskip}

Then \newlist\listblock{}{} will have the same definition as in the
previous example (no need to supply a <middle> part, it's in the default),
and a variation can be created.

\removenextindent
Removes the indentation box of the next paragraph (used by section
macros). Technically, it sets ajar the "noindent" gate in the "everypar"
gate list (itself registered in the \everypar token list, which shouldn't
be handled otherwise if flexibility is to be ensured). Those two gates
belong to the "Everypar" family associated with the \Everypar command.

\Indent
Indents the next paragraph even if it \removenextindent has been issued
(a \kern is added).






Dealing with files (files.ptx)
==============================

\iffile [<format>]<file><true><false>
Executes <true> if "kpse.find_file" (from the LuaTeX "kpse" library,
implementing "kpathsea") with file type <format> (default: "tex"), and
<false> otherwise.

\ifffile [<format>]<file><true>
Same as \iffile, except nothing happens when the file isn't found. Yes,
three *f*'s.

\inputfileor [<format>]<file><no file>
Reads file <file> or executes <no file>.

\writeout <optional star><general text>
Writes <general text> to the auxilary file that is read at the beginning
of each job. Without a star, writing happens at once (it's \immediate),
with it writing is delayed until the current page is shipped out.





Verbatim (verbatim.ptx)
=======================

\verbcatcodes
A catcode table with usual verbatim catcodes: special characters have
catcode 12, except space and end-of-line, which have catcode 13 and are
defined to \quitvmode\spacecs and \quitvmode\par by default.

\newverbatim <command>[<catcode table>]<pre><post>
Defines a new block <command> with <catcode table>, <pre> at the beginning
and <post> at the end. If <catcode table> is missing, \verbcatcodes is
used. Verbatim blocks work as follows: first, there is no continuation
command, i.e. only "\myverbatimblock" and "\myverbatimblock/" are allowed,
not "\myverbatimblock|" (it might exist somewhere in the future). Second,
the block opening takes one optional argument between brackets, which
is the name of the verbatim block. Third, <pre> is executed at the
beginning, and <post> at the end, as defined with \newverbatim. Fourth,
the end statement "\myverbatimblock/" should be on a line of its own.
What a verbatim block does is the following (not taking into account
what <pre> and <post> execute): it stores its contents as is, along with
the <catcode table> the block was declared with, and that's it. Then
come the following two functions.

\doverbatim [<name>]
Executes the contents of <name> (with the current catcode regime). If
name is missing, last is used, a special name which refers to the last
verbatim block.

\printverbatim [<name>]
Executes the contents of <name> (or last if <name> is missing) with the
catcode table associated with the block <name> was stored with. Since
that catcode table is \verbcatcodes by default, it generally results in
the contents being typeset.

As an example:

          \newverbatim\myverbatim{\vskip\baselineskip}
          {\printverbatim\vskip\baselineskip}
          \myverbatim[example]
          \def\foo{hello !}%
          \foo
          \myverbatim/
          And now we are going to print: \doverbatim[example].

\verbatim
A predefined verbatim block, designed as follows:

          \newverbatim\verbatim{\codefont\parindent0pt}
                               {\vskip\baselineskip\printverbatim\relax
                                \vskip\baselineskip\removenextindent}

I.e. it switches to the console-like font, sets the paragraph indentation
to nothing, prints its contents between two blank lines and removes the
indentation of the paragraph to follow.

Each verbatim block adds a table to the Lua table "pitex.verbatims" (yes,
with an *s*); the key is the block's name, and the value is a table with
lines as values, indexed by numbers, plus a "regime" key which returns
the catcode table's number of the block. For instance, the core operation
performed by "\printverbatim[<name>]" is:

          tex.print(pitex.verbatims[<name>].regime, pitex.verbatims[<name>])





Insertions (inserts.ptx)
========================

Insertions are still a mess, and not related to parameters. Yet you can
use:

\footnote <text>
Typesets <text> in a footnote. How astounding.

\figure [<title>]
A block creating a figure with title <title>.

\table [<title>]
The same as <figure>, except "Table" will be used instead of "Fig" in
the caption.

\infigure
Ablock creating a figure in the main text, i.e. between paragraphs.




Layout and output routine (output.ptx)
=====================================

The page layout can be specified with the !page parameter, whose attributes
are:

> width (dimension)
The width of the page.

> height (dimension)
The height of the page.

> baselineskip (glue)
The baseline distance.

> topskip (glue)
The distance between the top of the textblock and the first baseline.

> top (dimension)
The height of the upper margin.

> lines
The number of lines on a page.

> hsize (dimension)
The width of the textblock.

> left (dimension)
Width of the left margin.

> right (dimension)
Width of the right margin. If specified, ?hsize is ignored and the
texblock's width is set to ?width - ?left - ?right.

> parindent (dimension)
The width of the indentation.

> parskip (glue)
The glue between paragraphs.

The output routine holds nothing very interesting for the moment. I
used to redefine it for each job. Now it is set up with gates, but I
haven't taken the time yet to make it really powerful. Plus I should
rewrite everything in Lua as much as possible. Anyway, \output contains
the "output" gate, from the "OutputRoutine" family associated with the
\OutputRoutine command; the gates work as follows (passed arguments
aren't indicated, because there isn't any; although someday perhaps the
gates will pass a box between them, to be less dependant on \outputbox,
which is used, by the way, instead of box 255, so any box register can
be used):

---------------------------------------------------------------
| output | precheck  |                    |                   |
|        | shipout   | processmarginalia  |                   |
|        |           | inserts            | inserts_figures   |
|        |           |                    | inserts_footnotes |
|        |           | headers            |                   |
|        |           | ship               |                   |
|        |           | postship           |                   |
---------------------------------------------------------------

> output
The main list gate, holding the following.

> precheck
Checks whether \outputpenalty is smaller than \widowpenalty. If not,
\vsize is increased or decreased (if there are inserts) by \baselineskip,
so that the widow is accommodated or a line is given to the next page.
In any case, the output box is repassed to TeX with "\holdinginserts=0".
The gate is then set to "skip", so it isn't executed again.

> shipout
A list gate containing gates to write the page. By default it is skipped,
so it isn't executed when the previous gate is, and vice-versa.

> processmarginalia
Insert the marginal notes (see \marginnote below). Can be obviously
removed if there are no such notes.

> inserts
An l-gate containing the following two m-gates.

> inserts_figures
Adds the figures. (Conditional: the box "\ptx@insert_figures" isn't
empty.)

> inserts_footnotes
Adds the footnotes. (Conditional: the box "\ptx@insert_footnotes" isn't
empty.)

> headers
Inserts headers or footers, i.e. page number, running title, etc.

> ship
Ships out the page.

> postship
Resets some stuff (set "output_shipout" back to "skip"), and increments
the page number.

And now a lonely command:

\marginnote [options]<text>
Produces a marginal note with <text>. Uses the attributes (font,
baselineskip, hsize) of the !marginnote parameter, with the following
attributes:

> hsize (dimension)
Width of the textblock in the note.

> hpos (ff, fr, rf, rr)
Justification of the text: flushed on both sides, ragged on the right,
ragged on the left, ragged on both sides.

> font
Font used to typeset the note.

> parindent (dimension)
Paragraph indentation for the note.

> side (left or right)
Side of the note relative to the textblock. That should depend on whether
the note is on an odd or even side, but for the moment that is not the
case.

> gap (dimension)
Distance between the textblock and the note.





Lua facilities (lua.ptx and base.ptxlua)
========================================

\inputluafile <file>
Shorthand for \directlua{dofile(kpse.find_file(<file>))}.

\luacatcodes
A catcode table with Lua-convenient catcodes: "#", "~", "%" and the end
of file "^^M" are set to catcode 12.

\luacode
A block to write Lua code with the catcodes above.

Lua code in PiTeX is organized mostly in gates; "pitex" is a gate table
associated with family "pitex", "pitex.callback" is another table
associated with family "pitex.callback", and "pitex.misc" is a third
table associated (how surprising) with family "pitex.misc". The
division of labour isn't perfectly defined, to say the least.

The "pitex" family holds general commands, namely:

> pitex.log (<message>, ...)
Writes a <message> formatted as "string.format(<message>, ...)"

> pitex.error (<message>, ...)
Same as the previous function, but less friendly.

The "pitex.callback" family is concerned with callback management. It
has one interesting function (well, a gate) devoted to handling functions
in callbacks as gates:

> pitex.callback.register (<callback>, <gate>)
An l-gate is registered in the callback, with subgates added to it; the
name of the l-gate is the same as the callback where it is registered
(with the family prefix "pitex.callback" added when necessary). For
instance the list gate containing functions to used in "process_input_buffer"
is called "process_input_buffer". Ordinary you would add a subgate to
such a callback with the "add" action:

          pitex.callback.add ("mygate", "process_input_buffer")

However, the l-gate associated with the callback isn't created by
default, nor registered in the callback. This means that "add" above
will fail miserably if "process_input_buffer" hasn't been created
beforehand. This function is meant to circumvent that: if the l-gate
exists, it boils down to "add"; otherwise it creates it and registers
it in the callback, and then add the gate. Note that the syntax follows
the original "callback.register" function, with the callback first and
the function second, even though you're adding gates to l-gates, with
the syntax of "add" being subgates first, l-gate second. To manage the
gates, thus created, you can then rely on the original gate actions.

So, when I say `gates "X" and "Y" are registered in callback "Z"', it
means `gates "X" and "Z" are subgates of l-gate "pitex.callback:Z",
itself registered in callback "Z"'; unless otherwise indicated, "X" and
"Z" belong to the "pitex.callback" family.

And here are the gates registered in callbacks: "process_input_buffer"
contains "convert", which turns latin1 into UTF-8. Verbatim blocks also
register "process_verbatim", which is removed when the block ends. The
"kerning" callback contains "french_punctuation", meant to add thin
space before some punctuation mark, and "original_kerning", which is
just a gate version of the "node.kerning" function. In "post_linebreak_filter"
you'll find "pitex.misc:underline", which deals with material to be
underline and "pitex.misc:mark_lines", which marks lines where a margin
note is to be added. Those last two gates should be rewritten as complex
l-gates (they're just big functions for the moment) some day. If you
neither underline nor use marginal notes, you can remove them.




Things that didn't make it elsewhere (pitex.tex)
================================================

General properties of the document can be set with the !document parameter,
with the following attributes (the !navigator parameter has a ?meta
attribute set to !document, which is why you'll find attributes here
used by Navigator):

> author
The author of the document.

> title
The title of the document.

> pdftitle
The title that Navigator will use for the document's properties (defaults
to ?title).

> date
The date of the document

> pdfdate
The date that Navigator will use for the document's properties; should
be a properly formatted PDF date (this corresponds to the ?date attribute
in the !navigator parameter; note that ?pdfdate doesn't defaults to
?date, because the latter is supposed to hold a readable date).

> subject
For the document's properties.

> keywords
Again, the properties.

> mode (outlines, bookmarks, thumbs, thumbnails, attachments, files, oc)
What should be displayed in the navigation bar when the document is
opened. See the documentation to Navigator.

> layout (onepage, onecolumn, twopage, twocolumn, twopage*, twocolumn*)
How the document is displayed when opened. See the documentation of
Navigator.

\newattribute <command>
Defines <command> as an attribute register.

\unsetattribute <command>
Unsets attribute <command>.

\attributenumber <command>
Returns the number of attribute register <command> (not its value; you
get the value with \the; this is to pass to Lua).

\freedef <command>{<definition>}
Same as "\def\foo#1{...}", except <command> can take its argument between
double quotes (°") or slahes (/), and of course as single token or
brace-delimited.

\ifmaintext
Conditional that is true when in main text; inserts, section headings,
etc., should turn it to false, and sets their own to true.

\newcatcodetable <command><catcode settings>
Defines <command> as a catcode table with <catcode settings>; the latter
are "<list of characters> = catcode" pairs, separated by commas, like
the argument of texapi's \setcatcodes.

\texcatcodes
A code catcode table with the traditional catcodes.

\inputpitexfile <file><space>
Inputs <file> unless the initialization script says otherwise. If <file>
has no extension, ".ptx" is used.

\antigobblespace
Adds a space if the next character has catcode 11 or is an opening
parenthesis. For instance, after "\def\tex{\TeX\antigobblespace}", you
can type "\tex is typesetting program" without worrying for gobbled
space. Note that only ASCII letters have catcode 11 by default (not
accented characters).

\strut <height><depth>
Produces an invisible vertical rule with the specified dimensions.

\colorbox [<dimensions>]<RGB color><text>
Puts <text> in a colored box with background color <RGB color> (e.g.
three space-separated numbers between 0 and 1) and with padding <dimensions>.
If <dimensions> is missing, padding is done according to the \extraboxspace
length. Otherwise, if <dimensions> contains one value, it is used on all
side; if there are two values (separated by commas), the first is used
for top and bottom padding, and the second for left and right padding;
with three value, the third specifies bottom padding, and a fourth
specifies left padding. Very unlikely to remain in its present state or
to remain at all.

\extraboxspace
Default padding for the previous command.

\og
Produces an opening guillemet: "«" (character "0x00AB").

\fg
Produces a closing guillemet: "»" (character "0x00BB"). Uses \antigobblespace.

\trace
Sets \tracingcommands to 3 and \tracingmacros to 2.

\untrace
Sets \tracingcommands and \tracingmacros to 0.