texlive[55699] Master/texmf-dist: langsci-avm (29jun20)
commits+karl at tug.org
commits+karl at tug.org
Mon Jun 29 23:31:09 CEST 2020
Revision: 55699
http://tug.org/svn/texlive?view=revision&revision=55699
Author: karl
Date: 2020-06-29 23:31:09 +0200 (Mon, 29 Jun 2020)
Log Message:
-----------
langsci-avm (29jun20)
Modified Paths:
--------------
trunk/Master/texmf-dist/doc/latex/langsci-avm/README
trunk/Master/texmf-dist/doc/latex/langsci-avm/langsci-avm.pdf
trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.dtx
trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.ins
trunk/Master/texmf-dist/tex/latex/langsci-avm/langsci-avm.sty
Removed Paths:
-------------
trunk/Master/texmf-dist/doc/latex/langsci-avm/include/
Modified: trunk/Master/texmf-dist/doc/latex/langsci-avm/README
===================================================================
--- trunk/Master/texmf-dist/doc/latex/langsci-avm/README 2020-06-29 21:30:59 UTC (rev 55698)
+++ trunk/Master/texmf-dist/doc/latex/langsci-avm/README 2020-06-29 21:31:09 UTC (rev 55699)
@@ -8,16 +8,13 @@
avm package, but shares no code base with that package.
langsci-avm was developed at Language Science Press to help in the
-production of scientific texts in linguistics, in particular an
-upcoming HPSG handbook.
+production of scientific texts in linguistics.
Copyright (C) 2020 by Felix Kopecky, Language Science Press
-This work consists of the file langsci-avm.dtx &
- include/smallcaps-standalone.pdf.
+This work consists of the file langsci-avm.dtx
and the derived files langsci-avm.ins,
- langsci-avm.pdf,
- langsci-avm.sty.
+ langsci-avm.pdf.
It may be distributed and/or modified under the conditions of the
LaTeX Project Public License (LPPL), either version 1.3c of this
@@ -27,7 +24,7 @@
This work is ``maintained'' (per LPPL maintenance status) by
Felix Kopecky <felix.kopecky at langsci-press.org>.
-The development version of the bundle can be found at
+The development version can be found at
https://github.com/langsci/langsci-avm
Modified: trunk/Master/texmf-dist/doc/latex/langsci-avm/langsci-avm.pdf
===================================================================
(Binary files differ)
Modified: trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.dtx
===================================================================
--- trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.dtx 2020-06-29 21:30:59 UTC (rev 55698)
+++ trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.dtx 2020-06-29 21:31:09 UTC (rev 55699)
@@ -11,15 +11,23 @@
\preamble
------------------------------------------------------------------------------
-langsci-avm: Attribute-value matrices (AVMs) and feature structures in LaTeX3.
+langsci-avm is aimed at typesetting beautiful feature structures,
+also known as attribute-value matrices (AVMs), for use in linguistics.
+The package provides a minimal and easy to read syntax.
+It depends only on the array package and can be placed almost everywhere,
+in particular in footnotes or graphs and tree structures. The package is meant
+as an update to, and serves the same purpose as, Christopher Manning’s
+avm package, but shares no code base with that package.
+
+langsci-avm was developed at Language Science Press to help in the
+production of scientific texts in linguistics.
+
Copyright (C) 2020 by Felix Kopecky, Language Science Press
-This work consists of the file langsci-avm.dtx &
- include/smallcaps-standalone.pdf.
+This work consists of the file langsci-avm.dtx
and the derived files langsci-avm.ins,
- langsci-avm.pdf,
- langsci-avm.sty.
+ langsci-avm.pdf.
It may be distributed and/or modified under the conditions of the
LaTeX Project Public License (LPPL), either version 1.3c of this
@@ -29,7 +37,7 @@
This work is ``maintained'' (per LPPL maintenance status) by
Felix Kopecky <felix.kopecky at langsci-press.org>.
-The development version of the bundle can be found at
+The development version can be found at
https://github.com/langsci/langsci-avm
@@ -75,7 +83,7 @@
% Please submit bug reports and feature requests to
% \protect\url{https://github.com/langsci/langsci-avm/issues}.
% }}
-% \date{Version 0.1.0-beta -- 11th March 2020}
+% \date{Version 0.2 -- 29th June 2020}
% \maketitle
% \frenchspacing
% \begin{documentation}
@@ -82,18 +90,17 @@
% \section{Introduction}
% \pkg{langsci-avm} is a \LaTeX3 package aimed at typesetting beautiful feature structures, also known as \emph{attribute-value matrices}, for use in linguistics. The package provides a minimal and easy to read syntax. It depends only on the \pkg{array} package and can be placed almost everywhere, in particular in footnotes or graphs and tree structures. The package is meant as an update to, and serves the same purpose as, Christopher Manning's \pkg{avm} package, but shares no code base with that package. When you come from \pkg{avm}, please see Section~\ref{sec:switching} for a quick conversion guide.
%
-% To start using \pkg{langsci-avm}, place |\usepackage{langsci-avm}| in your preamble.
+% To start using \pkg{langsci-avm}, place |\usepackage{langsci-avm}| in your preamble.\\\\
+% \emph{This document is structured as follows:} Section~\ref{sec:basiccommands} describes the input syntax for AVMs and their parts. Ways to customise your AVM's layout follow in Section~\ref{sec:options}, and selected usage cases are presented in Section~\ref{sec:applications}. There's also an administrative and \TeX nical appendix at the end of this document, in case you are interested.
%
% \subsection{Example}
% \begin{verbatim}
% \avm{
-% [ ctxt & [ max-qud \\
-% sal-utt & \{ [ cat \\
-% cont <ind & i>
-% ]
-% \}
-% ]
-% ]
+% [ ctxt & [ max-qud \\
+% sal-utt & \{ [ cat \\
+% cont <ind & i> ] \}
+% ]
+% ]
% }
% \end{verbatim}
% {\centering\avm{
@@ -105,43 +112,21 @@
% \subsection{Acknowledgements}
% Thanks to Phelype Oleinik for help on recursion and expansion with \LaTeX3. Thanks to Ahmet Bilal Özdemir and Stefan Müller for their contributions in planning and testing this package.
%
-% \section{User interface}
-% \subsection{Typing structures and settings}\label{sec:options}
+% \section{Structuring AVMs}
+% \label{sec:basiccommands}
%
% \begin{function}{\avm}
% \begin{syntax}
% \cs{avm} \oarg{options} \marg{structure}
% \end{syntax}
-% The heart of this package and its root document comand is |\avm|. It currently runs only in text mode, but can be run in math mode if it is escaped with |$\avm$|. In the scope of the command, delimiter characters are processed to open and close (sub-)structures, as described in Section~\ref{sec:commands}. For a description of the \meta{options}, see |\avmsetup|.
-% \end{function}
+% The heart of this package and its root document comand is |\avm|. In the scope of the command, delimiter characters are processed to open and close (sub-)structures, as described in Section~\ref{sec:commands}. Special elements are described in Section~\ref{sec:specialcommands}. For a description of the layout \meta{options}, see Section~\ref{sec:options}.
%
-% \begin{function}{\avmsetup}
-% \begin{syntax}
-% \cs{avmsetup} \marg{options}
-% \end{syntax}
-% \meta{options} is a comma-separated list of |key = value| settings. The \marg{options} are the same as in \cs{avm}\oarg{options}. When inserted in \cs{avm}\oarg{options}, they apply locally, and globally if given to \cs{avmsetup}. Local settings always override global ones, and you can have any feasible number of \cs{avmsetup}s in your document.
-%
-% \begin{description}[style=nextline]
-% \item[|stretch =| \meta{factor} \hfill (initially |1.15|)] Define \cs{arraystretch}, i.e. the factor of line spacing. Increasing this may be useful if there is too little vertical space between delimiters in subsequent rows.
-%
-% \item[|columnsep =| \meta{length} \hfill (initially |0.5ex|)] Define the \cs{arraycolsep}, i.e. horizontal space before and after any column. The first and second column will have |1\columnsep| to the left and right, respectively. Between the two the distance is |2\columnsep|. Using relative units (like |ex| or |em|) may be a good idea so that |columnsep| scales well with changes in font size.
-%
-% \item[|delimfactor =| \meta{factor} \hfill (initially |1000|)] Sets \cs{delimiterfactor}. The calculation for the minimum height of a delimiter is $y \cdot f /1000$, where $y$ is the height of the content and $f$ the value of \cmd{delimfactor}. The default |1000| ensure that the delimiters' height is at least that of the structure.
-%
-% \item[|delimfall =| \meta{length} \hfill (initially |0pt|)] Controls \cs{delimitershortfall}, i.e. the maximum height that the delimiters can be shorter than the enclosed structure. The default |0pt| ensure that the delimiters are not shorter than the contents.
-%
-% \item[|attributes =| \meta{font settings} \hfill (initially |\textbackslash scshape|)] The font for attributes, i.e. the first column of each structure.
-%
-% \item[|values =| \meta{font settings} \hfill (initially |\textbackslash itshape|)] The font for values, i.e. the second column of each structure.
-%
-% \item[|types =| \meta{font settings} \hfill (initially |\textbackslash itshape|)] The font used in \cs{type} and \cs{type*}.
-% \item[|tags =| \meta{format settings} \hfill (initially |\textbackslash footnotesize|)] The font (size) used in \cs{tag} and the shortcuts \cs{1}...\cs{9}.
-% \item[|switch =| \meta{token} \hfill (initially |!|)] Define the escape token. Change this if you need to use ``!'' as a text glyph.
-% \end{description}
+% A \meta{structure} is basically the content of a stylised \cmd{tabular}: The columns are separated by \cmd{&} and a new line is entered with \cmd{\\}.
% \end{function}
+%
+% \subsection{Entering (sub-)structures within \texttt{\textbackslash avm}}
+% \label{sec:commands}
%
-% \subsection{Commands available in the scope of \texttt{\textbackslash avm}}\label{sec:commands}
-%
% \begin{function}{[...],<...>,(...),\{...\}}
% \begin{syntax}
% \cmd{[} \meta{structure} \cmd{]}
@@ -149,11 +134,9 @@
% \cmd{(} \meta{structure} \cmd{)}
% \cmd{\{} \meta{structure} \cmd{\}}
% \end{syntax}
-% Within the scope of \cs{avm}, these delimiters create (sub-)structures that are enclosed by the respective delimiter. Due to the special meaning that curly braces have in \LaTeX, they are the only ones that need to be run with an escape token (|\|). It is currently possible to mix delimiters, e.g. with |<|\meta{structure}|)|, but this may change in future versions.
+% Within the scope of \cs{avm}, these delimiters create (sub-)structures that are enclosed by the respective delimiter. Due to the special meaning that curly braces have in \LaTeX, these are the only ones that need to be run with an escape token (|\|). It is currently possible to mix delimiters, e.g. with |<|\meta{structure}|)|, but this may change in future versions.
%
-% A \meta{structure} is basically the content of a stylised \cmd{array}: The columns are separated by \cmd{&} and a new line is entered with \cmd{\\}.
-%
-% \pkg{langsci-avm} expects your (sub-)structures to have \emph{at most two columns}, so that for every line in each (sub-)structure, there should be no more than one \cmd{&}. It is recommended to have exactly one \cmd{&} in your \meta{structure}. In the current beta version, display issues may appear in some structures if none is given.\bigskip\\
+% \pkg{langsci-avm} expects your (sub-)structures to have \emph{at most two columns}, so that for every line in each (sub-)structure, there should be no more than one \cmd{&}. It is recommended to have at least some lines with a \cmd{&} in your \meta{structure}. Currently, display issues may appear in some structures if none are given.\bigskip\\
% \noindent\begin{minipage}[c]{.5\linewidth}
% \begin{verbatim}
% \avm{
@@ -184,15 +167,16 @@
% \begin{syntax}
% \cmd{!} \meta{text} \cmd{!}
% \end{syntax}
-% Escapes the |avm| mode so that all delimiters can be used as usual characters. If you need |!| as a regular character, see \cs{avmsetup} to change the |switch| option.
+% Escapes the |avm| mode so that all delimiters can be used as usual characters. If you need |!| as a regular character, see Section~\ref{sec:options} for how to change the |switch|.
% \end{function}
%
-% \begin{function}{\tag,\1,...,\9}
+% \subsection{Commands for tags, types, unusal lines, and relations}\label{sec:specialcommands}
+% \begin{function}[updated=2020-04-29]{\tag,\0,\1,...,\9}
% \begin{syntax}
% \cs{tag} \marg{identifier}
-% \cmd{\1, \2, \3, \4, \5, \6, \7, \8, \9}
+% \cmd{\0, \1, \2, \3, \4, \5, \6, \7, \8, \9}
% \end{syntax}
-% \cs{tag} puts its \marg{identifier} in a box, more precisely an \cs{fbox}. Within the box, the |tags| font is applied. \cs{1}, ..., \cs{9} are shortcuts to \cs{tag} and place the respective number in the box. For example, \cs{4} is equivalent to |\tag{4}|. The shortcuts do not take any arguments.
+% \cs{tag} puts its \marg{identifier} in a box, more precisely an \cs{fbox}. Within the box, the |tags| font is applied. \cs{0}, \cs{1}, ..., \cs{9} are shortcuts to \cs{tag} and place the respective number in the box. For example, \cs{4} is equivalent to |\tag{4}|. The shortcuts do not take any arguments.
%
% If you want to use this command outside an AVM, you can obtain, for example, \avm{\4}, by using |\avm{\4}|, or the equivalent |{\fboxsep.25ex\fbox{\footnotesize 4}}|.\bigskip\\
% \noindent\begin{minipage}{.6\linewidth}
@@ -208,11 +192,11 @@
% \end{minipage}
% \end{function}
%
-% \begin{function}{\type,\type*}
+% \begin{function}[updated=2020-03-30]{\type,\type*}
% \begin{syntax}
% \cs{type}\meta{*} \marg{type}
% \end{syntax}
-% Will typeset the \meta{type} in the |types| font (roman italics by default). The starred variant \cs{type*} will span the complete (sub-)structure and \emph{can only be placed in the first column} of this structure. After the starred \cs{type*}, a |\\| is recommended, but can be omitted in ``normal'' cases.\bigskip\\
+% Will output the \meta{type} in the |types| font (roman italics by default). The starred variant \cs{type*} will span the complete (sub-)structure and \emph{can only be placed in the first column} of this structure. After the starred \cs{type*}, a |\\| is recommended, but can usually be omitted.\bigskip\\
% \noindent\begin{minipage}{.6\linewidth}
% \begin{verbatim}
% \avm{[ \type*{A type spanning a line}
@@ -238,7 +222,8 @@
% \avm{[ attr1 & val1\\
% \punk{a quite long attr2}{val2} ]}
% attr3 & val3\\
-% attr4 & val4\\
+% attr4 & val4
+% ]}
% \end{verbatim}
% \end{minipage}\begin{minipage}{.4\linewidth}
% \avm{[
@@ -245,17 +230,179 @@
% attr1 & val1\\
% \punk{a quite long attr2}{val2}
% attr3 & val3\\
-% attr4 & val4\\
+% attr4 & val4
% ]}
% \end{minipage}
% \end{function}
%
-% \begin{function}{+}
-% In the scope of \cs{avm}, \cmd{+} comes out as ``$\oplus$''. To obtain ``+'', please use the escape mode, as in |!+!|.
+% \begin{function}[updated=2020-03-16]{\+}
+% In the scope of \cs{avm}, \cs{+} comes out as ``$\oplus$''. ``+'' can be obtained normally. \textit{In the earlier Version 0.1.0-beta, \cmd{+} produced ``$\oplus$''.}
% \end{function}
%
-% \section{Applications}
+% \begin{function}[added=2020-03-17]{\-}
+% In the scope of \cs{avm}, \cs{-} comes out as ``$\ominus$''. To use the ``optional hyphenation'' meaning of \cs{-}, please write |!\-!|.
+% \end{function}
%
+% \begin{function}[added=2020-03-17]{\shuffle}
+% In the scope of \cs{avm}, \cs{shuffle} is a shortcut for ``$\bigcirc$'' to mark the shuffle relation.
+% \end{function}
+%
+% \section{AVM layout}\label{sec:options}
+%
+% \subsection{Defining styles}
+%
+% You can customise many aspects of how an AVM is printed, including the fonts or spacing between delimiters and content. You can apply them locally via the \oarg{options} of \cs{avm} or by using \cs{avmsetup}. And you can also define your own styles and use them via the \oarg{style = } option in \cs{avm}.
+%
+% \begin{function}{\avmsetup}
+% \begin{syntax}
+% \cs{avmsetup} \marg{options}
+% \end{syntax}
+% \marg{options} is a comma-separated list of |key = value| settings. See the list below for all user-configurable options. The \marg{options} are the same as in \cs{avm}\oarg{options}. When inserted in \cs{avm}\oarg{options}, they apply locally, and globally if given to \cs{avmsetup}. Local settings always override global ones, and you can have any feasible number of \cs{avmsetup}s in your document.
+%
+% \end{function}
+%
+% \begin{function}[added=2020-05-11]{\avmdefinestyle}
+% \begin{syntax}
+% \cs{avmdefinestyle} \marg{name} \marg{settings}
+% \end{syntax}
+% Instead of applying settings globally or per AVM, you can also define styles and assign them to AVMs, as in |\avm[style=|\meta{name}|]{...}|. The \meta{settings} are a comma-separated list of |key = value| settings, and should be a subset of the settings from \cs{avmsetup}. For example, the following |plain| style highlights neither attributes, values, nor types:
+%
+% \begin{verbatim}
+% \avmdefinestyle{plain}{attributes=\normalfont,
+% values=\normalfont,
+% types=\normalfont}
+% \end{verbatim}
+% The style is applied with |\avm[style=plain]{...}|.
+% \end{function}
+%
+% \bigskip
+%
+% \noindent Now to the list of settings you can actually apply:
+%
+% \begin{description}[style=nextline]
+% \item[|style =| \meta{name} \hfill (initially empty)] In addition to any style that you possibly define yourself, a style |narrow| is pre-defined in the package (see Section~\ref{sec:spacing}).
+%
+% \item[|stretch =| \meta{factor} \hfill (initially |0.9|)] Define \cs{arraystretch}, i.e. a factor in the determination of line height.
+%
+% \item[|columnsep =| \meta{length} \hfill (initially |0.5ex|)] Define the \cs{tabcolsep}, i.e. horizontal space between columns. The first and second column will have |0\columnsep| to the left and right, respectively. Between the two the distance is |2\columnsep|. Using relative units (like |ex| or |em|) may be a good idea so that |columnsep| scales well with changes in font size.
+%
+% \item[|delimfactor =| \meta{factor} \hfill (initially |1000|)] Sets \cs{delimiterfactor}. The calculation for the minimum height of a delimiter is $y \cdot f /1000$, where $y$ is the height of the content and $f$ the value of \cmd{delimfactor}. The default |1000| ensure that the delimiters' height is at least that of the structure.
+%
+% \item[|delimfall =| \meta{length} \hfill (initially |0pt|)] Controls \cs{delimitershortfall}, i.e. the maximum height that the delimiters can be shorter than the enclosed structure. The default |0pt| ensure that the delimiters are not shorter than the contents.
+%
+% \item[|extraskip| = \meta{length} \hfill (initially \cs{smallskipamount})] If a substructure is immediately followed by a \cmd{\\}, an extra amount of vertical skip is added so that the content of the next line, possibly another delimiter, does not clash with the delimiter in that line. This automatic skip insertion can be circumvented with placing a \cs{relax} before the linebreak, i.e. |\relax\\|.
+%
+% \item[|attributes =| \meta{font settings} \hfill (initially |\textbackslash scshape|)] The font for attributes, i.e. the first column of each structure.
+%
+% \item[|values =| \meta{font settings} \hfill (initially |\textbackslash itshape|)] The font for values, i.e. the second column of each structure.
+%
+% \item[|apptovalues=| \meta{code} \hfill (initially \cs{/})] The \meta{code} is applied after the second column (``append to''). This is useful if |values| is set to |\itshape|, since \cs{itshape} does not automatically insert italic correction.
+%
+% \item[|types =| \meta{font settings} \hfill (initially |\textbackslash itshape|)] The font used in \cs{type} and \cs{type*}.
+% \item[|tags =| \meta{format settings} \hfill (initially |\textbackslash footnotesize|)] The font (size) used in \cs{tag} and the shortcuts \cs{1}...\cs{9}.
+% \item[|switch =| \meta{token} \hfill (initially |!|)] Define the escape token. Change this if you need to use ``!'' as a text glyph.
+% \item[|customise = | \meta{settings} \hfill (initially empty)] An interface to input custom commands to be run at the beginning of every \cs{avm}.
+% \end{description}
+%
+% \subsection{Defining input patterns}
+%
+% \begin{function}[added=2020-06-29]{\avmdefinecommand}
+% \begin{syntax}
+% \cs{avmdefinecommand} \marg{name} \oarg{label} \marg{settings}
+% \end{syntax}
+% Sub-structures often come in patterns. For example, AVMs often have a \textsc{phon} attribute, which is mapped to a list, the entries of which are in italics. \cs{avmdefinecommand} can account for this and other input patterns. For example,
+%
+% \begin{verbatim}
+% \avmdefinecommand{custom}{...}
+% \end{verbatim}
+% will create a command \cs{custom} available only in the scope of \cs{avm} (this means that you can have a different meaning in the rest of your document). The \meta{settings} will then be applied to the scope in which \cs{custom} is called. If an optional \meta{label} is given, the label will be printed, in the current font, before the \meta{settings} are applied.
+%
+% \cs{custom} generated in this way automatically advances to the value column after the \meta{label} is printed. This means that commands generated with \cs{avmdefinecommand} should be called in the attribute column of an existing structure. This behaviour can be circumvented with the starred variant \cs{name*}, which is automatically generated by \cs{avmdefinecommand} as well. However, it seems advisable to use the starred variants sparingly.
+%
+% Here's an example for the aforementioned \text{phon} pattern:
+%
+% \begin{verbatim}
+% \avmdefinecommand{phon}[phon]
+% {
+% attributes = \itshape,
+% delimfactor = 900,
+% delimfall = 10pt
+% }
+% \end{verbatim}
+%
+% This creates a command \cs{phon} (and the variant \cs{phon*}) within the scope of any \cs{avm}. It will print the label \texttt{phon} in the current font and then apply three settings locally: italics for the attribute (first) column, and two settings for very narrow delimiter fitting.
+%
+% This results in: (The font of this documentation has little support for IPA.)\avmdefinecommand{phon}[phon] {attributes = \itshape,delimfactor = 900, delimfall = 10pt}\\\\
+% \noindent\begin{minipage}[c]{.5\linewidth}
+% \begin{verbatim}
+% \avm{
+% [\type*{word}
+% \phon <lin'gwistiks>\\
+% synsem & [ ... ]
+% ]
+% }
+% \end{verbatim}
+% \end{minipage}\begin{minipage}[c]{.5\linewidth}
+% \avm{
+% [\type*{word}
+% \phon <lin'gwistiks>\\
+% synsem & [ ... ]
+% ]
+% }
+% \end{minipage}
+%
+% Note that any other structure type would have worked instead of \avm{<>}. But \avm{<>} and any other markers for sub-structures are left unchanged by \cs{phon} and other custom commands. This is why the \emph{attribute} font is changed by \cs{phon}, although \emph{lin'gwistiks} is technically a value. Remember that \cmd{<} creates a new list sub-substructure, and the first content is printed in its attribute font.
+% \end{function}
+%
+% \section{Applications}\label{sec:applications}
+%
+% \subsection{Spacing and size of delimiters}\label{sec:spacing}
+% \pkg{langsci-avm} automatically detects if the end of a sub-structure is followed by a line break. This is useful to find cases in which two sub-structures are printed immediately below each other, and to add extra spacing (the |extraskip| from the options). This automatic detection can be suppressed with \cs{relax}. See below for the effect of that detection:\bigskip\\
+% \noindent\begin{minipage}[c]{.5\textwidth}\centering
+% \begin{verbatim}
+% \avm{[ [attr1 & val1 \\
+% attr2 & val2 ] \\
+% [attr1 & val1 \\
+% attr2 & val2 ]
+% ]}
+% \end{verbatim}
+%
+% \avm{[ [attr1 & val1 \\
+% attr2 & val2 ] \\
+% [attr1 & val1 \\
+% attr2 & val2 ]
+% ]}
+% \end{minipage}\begin{minipage}[c]{.5\textwidth}\centering
+% \begin{verbatim}
+% \avm{[ [attr1 & val1 \\
+% attr2 & val2 ] \relax\\
+% [attr1 & val1 \\
+% attr2 & val2 ]
+% ]}
+% \end{verbatim}
+%
+% \avm{[ [attr1 & val1 \\
+% attr2 & val2 ] \relax\\
+% [attr1 & val1 \\
+% attr2 & val2 ]
+% ]}
+% \end{minipage}\\\\
+%
+% If many delimiters are nested, this occasionally results in larger delimiter sizes. There is a pre-defined |narrow| style that resets |delimfall| (to |5pt|) and |delimfactor| (to |997|), which are the values recommended in the \textit{\TeX book}. This results in a more compact appearance:\bigskip\\
+% \noindent\begin{minipage}[t]{.5\textwidth}\centering
+% \begin{verbatim}
+% \avm{[ attr \{<\1>\}]}
+% \end{verbatim}
+%
+% \avm{[ attr <\{\1\}>]}
+% \end{minipage}\begin{minipage}[t]{.5\textwidth}\centering
+% \begin{verbatim}
+% \avm[style=narrow]{[ attr \{<\1>\}]}
+% \end{verbatim}
+%
+% \avm[style=narrow]{[ attr <\{\1\}>]}
+% \end{minipage}
+%
% \subsection{Disjunctions and other relations}
% Sometimes AMVs are placed beside other content to express disjunctions or other relations. In \pkg{langsci-avm} this is done naturally:\bigskip\\
% \noindent\begin{minipage}[c]{.5\textwidth}
@@ -289,7 +436,7 @@
% attribute3 & value3 ] }
% \end{minipage}
%
-% \subsection{Use as a vector}
+% \pagebreak\subsection{Use as a vector}
% It's possible to use \pkg{langsci-avm} for feature vectors rather than matrices, as may be useful in generative grammar.\medskip\\
% \noindent\begin{minipage}[c]{.8\textwidth}
% \begin{verbatim}
@@ -299,7 +446,7 @@
% \avm[attributes=\normalfont]{[v1\\v2\\v3]}$\varphi$
% \end{minipage}
%
-% \subsection{Combinations with \pkg{gb4e} and \pkg{expex}}
+% \subsection{Combinations with \pkg{gb4e}, \pkg{expex}, and \pkg{linguex}}
%
% This package works fine with \pkg{gb4e} and its fork \pkg{langsci-gb4e}. To align the example number at the top of your structure, please use \cs{attop} from \pkg{gb4e}:\bigskip\\
% \noindent\begin{minipage}[c]{.5\textwidth}
@@ -322,7 +469,7 @@
% \end{exe}
% \end{minipage}\bigskip\\
%
-% \noindent The same can be achieved with \pkg{expex} using an \emph{experimental} syntax:
+% \noindent The same can be achieved with \pkg{expex} using \cs{envup} from \pkg{lingmacros} (see below) or using this \emph{experimental} syntax:
%
% \begin{verbatim}
% \ex \vtop{\strut\vskip-\baselineskip{
@@ -333,8 +480,15 @@
% \xe
% \end{verbatim}
%
-% \noindent A future version of \pkg{langsci-avm} will include a more user-friendly approach. There is currently no known way of adjusting the alignment with \pkg{linguex}.
+% \noindent Examples typed with \pkg{linguex} can be combined with \cs{evnup} from \pkg{lingmacros} to align AVMs (many thanks to Jamie Findlay for pointing this out):
%
+% \begin{verbatim}
+% \ex. \envup{\avm{[ attr1 & val1\\
+% attr2 & val2\\
+% attr3 & val3]}
+% }
+% \end{verbatim}
+%
% \subsection{Combinations with \pkg{forest}}
% This package also works fine with \pkg{forest}. As per the \pkg{forest} documentation, it is recommended to protect any \cs{avm}-statements with |{}| in nodes:\bigskip\\
% \noindent\begin{minipage}[c]{.6\textwidth}
@@ -353,29 +507,36 @@
% \end{forest}
% \end{minipage}
%
+% It may happen that extensive AVMs protrude into the space reserved for other \pkg{forest} nodes or edges. In this case, the \pkg{forest} setting \cmd{for children = \{anchor=north\}} may be useful: (If you like, try this tree without that setting.)\bigskip\\
+% \noindent\begin{minipage}[c]{.6\textwidth}
+% \begin{verbatim}
+% \begin{forest}
+% [A, for children = {anchor=north}
+% [B] [{\avm{[attr1 & val1\\
+% attr2 & a long value val2\\
+% attr3 & val3\\
+% attr4 & val4\\
+% attr5 & val5]}} ]
+% ]
+% \end{forest}
+% \end{verbatim}
+% \end{minipage}\begin{minipage}[c]{.4\textwidth}
+% \begin{forest}
+% [A, for children = {anchor=north} [B] [{\avm{[attr1 & val1\\
+% attr2 & a long value val2\\
+% attr3 & val3\\
+% attr4 & val4\\
+% attr5 & val5]}} ] ]
+% \end{forest}
+% \end{minipage}
+%
% \subsection{Switching from Christopher Manning's \pkg{avm} package}\label{sec:switching}
-% Switching from \pkg{avm} to \pkg{langsci-avm} will require some, though hopefully minimal, changes to the code. In particular, the ``active mode'' has disappeared, there is now a single way of sorting (see \cs{type}), and tags are now produced without |@| (\cs{4} instead of \cmd{@4}, etc.). Please refer to Section~\ref{sec:caveats} for features known from \pkg{avm} that are not yet available in \pkg{langsci-avm}.
+% Switching from \pkg{avm} to \pkg{langsci-avm} will require some, though hopefully minimal, changes to the code. In particular, \pkg{langsci-avm} doesn't distinguish between ``active'' and ``passive'' modes, there is now a single way of sorting (see \cs{type}, which replaces \cs{asort} and \cs{osort}), and tags are now produced without |@| (\cs{4} instead of \cmd{@4}, etc.).
%
-% \subsection{Tweaking the \texttt{attribute} font with with \pkg{fontspec}}
-% The attributes in your structure are usually type set in \textsc{small caps}. That means that your input should usually be lowercase, unless capitals along small capitals in that attribute's description make sense. Some fonts also provide ``old style'' figures (also known as ``text'' or ``medieval'' figures). Those can be enabled with \pkg{fontspec}'s |Numbers=OldStyle| feature.
+% Paths can be printed with a normal \cmd{|}, and $\oplus$ and other relation symbols can be input more easily (see Section~\ref{sec:commands}), though the package will also work with \verb+$|$+ and \verb+$\oplus$+.
%
+% \pkg{langsci-avm} is not yet able to draw lines in elements of AVMs. This feature is planned for Version 0.3.
%
-% \textit{The following example is output in Libertinus, since the font for this documentation does not support the necessary font features.}\bigskip\\
-% \begin{minipage}[c]{.7\linewidth}
-% \begin{verbatim}
-% % Preamble
-% \usepackage{fontspec}
-% \usepackage{libertinus}
-% % Document
-% \avm[attributes={\addfontfeatures{
-% Numbers=OldStyle,
-% Letters=SmallCaps}
-% }
-% ] { [attr1 & val2] }
-% \end{verbatim}
-% \end{minipage}\begin{minipage}[c]{.3\linewidth}
-% \includegraphics{include/smallcaps-standalone.pdf}
-% \end{minipage}
%
% \subsection{Spanning both columns}
% You can use the \pkg{multicol} package to span both columns in a (sub-)structure. Please remember that every structure has two columns, so the only sensible usage is
@@ -389,11 +550,10 @@
% \section{Caveats and planned features}\label{sec:caveats}
% \begin{enumerate}
% \item There are currently no error messages. If you do not receive the intended output, please make sure that your code fits the syntax described in this documentation. If your code is fine but the output is not, please submit a bug report or feature request at \url{https://github.com/langsci/langsci-avm/issues}.
-% \item The package currently assumes that it is called in text mode.
% \item[] These features are planned for the future:
% \item A check whether the delimiters are balanced, i.e. whether all (sub-)structures are closed by a \verb+]+, \verb+}+, etc.
% \item Introduce the ability to draw (curved) lines between structures and elements.
-% \item Improve the appearance of angle brackets so that they vertically span the complete structure they enclose, maybe using \pkg{scalerel}.
+% \item Improve the appearance of (very) large angle brackets so that they vertically span the complete structure they enclose, maybe using \pkg{scalerel}.
% \end{enumerate}
%
% \section{Feedback and bug reports}
@@ -415,13 +575,13 @@
%
% \begin{macrocode}
\ProvidesExplPackage {langsci-avm}
- {2020-03-11} {0.1.0-beta}
+ {2020-06-29} {0.2}
{AVMs and feature structures in LaTeX3}
% \end{macrocode}
% \begin{macro}{\avm}
% This document command initialises an AVM. The first, optional argumet is a key-value list of settings (see \cs{keys_define:nn} below) and the second is the AVM itself, given in the syntax described in this documentation.
%
-% \cs{avm} enters a group so that keys- and macro-assignemts remain local. It then initialises the commands and shortcuts made locally available, sets its mode to |true| and assigns the keys as given in the optional argument (if any). After the wrapper \cs{avm_wrap:n} is called, the group is closed.
+% \cs{avm} enters a group so that keys- and macro-assignemts remain local. It then initialises the commands and shortcuts and any user customisation, sets its mode to |true| and assigns the keys as given in the optional argument (if any). After the wrapper \cs{avm_wrap:n} is called, the group is closed.
%
% \begin{macrocode}
\NewDocumentCommand{\avm}{ O{} +m }
@@ -428,6 +588,8 @@
{
\c_group_begin_token
\__avm_initialise_document_commands:
+ \__avm_initialise_custom_commands:
+ \tl_use:N \l__avm_defined_commands_tl
\bool_set_true:N \l__avm_mode_bool
\keys_set:nn { avm } { #1 }
\__avm_wrap:n { #2 }
@@ -435,9 +597,9 @@
}
% \end{macrocode}
% \end{macro}
-%
+%
% \begin{macro}{\avmsetup}
-% Forward the key-value settings given as the optional argument to \cs{avm} to the keys defined in |\keys_define:nn { avm }|. For the meaning of these keys and initial values, see Section~\ref{sec:options}.
+% Forward the key-value settings given as the optional argument to \cs{avm} to the keys defined in |\keys_define:nn { avm }|. For the meaning of these keys and initial values, see Section~\ref{sec:basiccommands}.
%
% \begin{macrocode}
\NewDocumentCommand{\avmsetup}{ m }
@@ -446,8 +608,8 @@
\keys_define:nn { avm }
{
stretch .code:n = {\def\arraystretch{#1}},
- stretch .initial:n = {1.15},
- columnsep .dim_set:N = \arraycolsep,
+ stretch .initial:n = {0.9},
+ columnsep .dim_set:N = \tabcolsep,
columnsep .initial:n = {.5ex},
delimfactor .int_set:N = \delimiterfactor,
delimfactor .initial:n = {1000},
@@ -460,19 +622,58 @@
values .code:n = {\cs_set:Nn \__avm_font_value: {#1}},
values .initial:n = {\itshape},
tags .code:n = {\cs_set:Nn \__avm_font_tag: {#1}},
- tags .initial:n = {\footnotesize},
+ tags .initial:n = {\footnotesize},
+ apptovalues .code:n = {\cs_set:Nn \__avm_deinit_second_column: {#1}},
+ apptovalues .initial:n = {\/},
+ singleton .code:n = {\cs_set:Nn \__avm_font_singleton: {#1}},
+ singleton .initial:n = {\normalfont},
switch .code:n = {\tl_set:Nn \__avm_mode_switch_character {#1}},
- switch .initial:n = { ! }
+ switch .initial:n = { ! },
+ extraskip .dim_set:N = \l__avm_extra_skip_dim,
+ extraskip .initial:n = {\smallskipamount},
+ customise .code:n = {\cs_set:Nn \__avm_initialise_custom_commands: {#1}},
+ customise .initial:n = { },
+ style .choice:,
+ style / narrow .code:n = {\delimiterfactor=997\delimitershortfall5pt},
}
% \end{macrocode}
% \end{macro}
-% \begin{variable}{\l__avm_math_bool, \l__avm_mode_bool, \l__avm_parens_tracker}
-% We need an auxiliary variable to store the current mode. The math mode boolean is already created, but it will have an effect only in a later version which will include a check whether \cs{avm} is called in math mode. \cs{l__avm_parens_tracker} is a stack for a future check whether the delimiters given to \cs{avm} are balanced.
+% \begin{macro}{\avmdefinestyle}
+% Define a style to be used together with the |style| key.
% \begin{macrocode}
-\bool_new:N \l__avm_math_bool
+\NewDocumentCommand{\avmdefinestyle}{ m m }
+ {
+ \keys_define:nn { avm }
+ {
+ style / #1 .code:n = { \keys_set:nn { avm } { #2 } }
+ }
+ }
+% \end{macrocode}
+% \end{macro}
+
+% \begin{macro}{\avmdefinecommand}
+% A factory function that creates commands for the layout of sub-structures and saves them to \cs{l__avm_defined_commands_tl}. The first argument describes the command's name, the second any (optional) label. The manufactured definitions are activated in the AVM group so that they remain local.
+% \begin{macrocode}
+\NewDocumentCommand{\avmdefinecommand}{ m O{} m }
+ {
+ \tl_put_right:Nn \l__avm_defined_commands_tl
+ {
+ \exp_args:Nc \DeclareDocumentCommand { #1 } { s }
+ {
+ #2 \IfBooleanF { ##1 } { & } \avmsetup{ #3 }
+ }
+ }
+ }
+% \end{macrocode}
+% \end{macro}
+
+% \begin{variable}{\l__avm_mode_bool, \l__avm_parens_tracker, \l__avm_defined_commands_tl}
+% We need an auxiliary variable to store the current mode. \cs{l__avm_parens_tracker} is a stack for a future check whether the delimiters given to \cs{avm} are balanced. \cs{l__avm_defined_commands_tl} is a token list that stores any commands provided by the user via \cs{avmdefinecommand}
+% \begin{macrocode}
\bool_new:N \l__avm_mode_bool
\seq_new:N \l__avm_parens_tracker
+\tl_new:N \l__avm_defined_commands_tl
% \end{macrocode}
% \end{variable}
@@ -483,84 +684,144 @@
% \end{macrocode}
% \end{macro}
+% \begin{variable}{\l__avm_in_first_column}
+% A boolean to check whether we are in the first column (value |true|) or in the second (value |false|).
+% \begin{macrocode}
+\bool_new:N \l__avm_in_first_column
+% \end{macrocode}
+% \end{variable}
+% \begin{macro}[int]{\__avm_init_first_column:, \__avm_init_second_column:}
+% These macros apply the settings for the columns in a (sub-)structure. They take care of font selection and report the currently active column back to the system. Knowing which column is active is important when closing the (sub-)structure. If the structure is closed without a second column present, we need to skip back |2\tabcolsep|.
+% \begin{macrocode}
+\cs_new:Nn \__avm_init_first_column:
+ {
+ \bool_set_true:N \l__avm_in_first_column
+ \normalfont\__avm_font_attribute:
+ }
+
+\cs_new:Nn \__avm_init_second_column:
+ {
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\__avm_font_value:
+ }
+% \end{macrocode}
+% \end{macro}
+
+% \begin{macro}[int]{\__avm_kern_unused_columns:}
+% A helper macro to fill the horizontal space if a row is ended prematurely, i.e. if no \cmd{&} is present.
+% \begin{macrocode}
+\cs_new:Nn \__avm_kern_unused_columns:
+ {
+ \bool_if:NTF \l__avm_in_first_column
+ { \span\hspace*{-2\tabcolsep} }
+ { }
+ }
+% \end{macrocode}
+% \end{macro}
+
+% \begin{macro}[int]{\__avm_extra_skip:}
+% This function is used together with the delimiter replacements. It checks whether the delimiter is followed by a line break, in which case an extra skip is automatically inserted
+% \begin{macrocode}
+\cs_new:Nn \__avm_extra_skip:
+ {
+ \peek_meaning_ignore_spaces:NTF \\ {\vspace*{\l__avm_extra_skip_dim}} {}
+ }
+% \end{macrocode}
+% \end{macro}
+
% \begin{macro}[int]{\__avm_module_begin:,\__avm_module_end:,etc.}
% The replacement instructions for \cs{__avm_parse:n}
% \begin{macrocode}
\cs_new:Nn \__avm_module_begin:
{
- \begin{array}{
- >{\c_math_toggle_token\normalfont\__avm_font_attribute:}l
- <\c_math_toggle_token
- >{\c_math_toggle_token\normalfont\__avm_font_value:}l
- <\c_math_toggle_token}
+ \begin{tabular}{@{}
+ >{\__avm_init_first_column:}l
+ >{\__avm_init_second_column:}l
+ <{\__avm_deinit_second_column:}
+ @{}}
}
\cs_new:Nn \__avm_module_end:
- { \end{array} }
+ {
+ \__avm_kern_unused_columns:
+ \end{tabular}
+ }
\cs_new:Nn \__avm_replace_lbrace:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left\lbrace\__avm_module_begin: }
+ { \c_math_toggle_token\left\lbrace\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rbrace:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right\rbrace\c_math_toggle_token }
+ { \__avm_module_end:\right\rbrace\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_lbrack:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left\lbrack\__avm_module_begin: }
+ { \c_math_toggle_token\left\lbrack\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rbrack:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right\rbrack\c_math_toggle_token }
+ { \__avm_module_end:\right\rbrack\c_math_toggle_token\__avm_extra_skip: }
}
-\cs_new:Nn \__avm_replace_lparen:
- {
+\cs_new:Nn \__avm_replace_lparen:
+ {
\__avm_parse_output:nw
- { \c_math_toggle_token\left(\__avm_module_begin: }
+ { \c_math_toggle_token\left(\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rparen:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right)\c_math_toggle_token }
+ { \__avm_module_end:\right)\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_langle:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left<\__avm_module_begin: }
+ { \c_math_toggle_token\left<\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rangle:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right>\c_math_toggle_token }
+ { \__avm_module_end:\right>\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_plus:
{
- \__avm_parse_output:nw { \ensuremath { \oplus } }
+ \__avm_parse_output:nw { \ensuremath { \oplus \! } }
}
+\cs_new:Nn \__avm_replace_minus:
+ {
+ \__avm_parse_output:nw { \ensuremath { \ominus \! } }
+ }
+\cs_new:Nn \__avm_replace_circle:
+ {
+ \__avm_parse_output:nw { \ensuremath { \bigcirc \, } }
+ }
% \end{macrocode}
% \end{macro}
-% \begin{macro}{\tag,\type,\punk}
+% \begin{macro}[updated=2020-03-30]{\tag,\type,\punk}
% \begin{macrocode}
\cs_new:Npn \__avm_controls_tag:n #1
{ \fboxsep.25ex\fbox{\normalfont\__avm_font_tag: #1} }
\cs_new:Npn \__avm_controls_type:n #1
- {\normalfont\__avm_font_type: #1}
+ { \c_group_begin_token\normalfont\__avm_font_type: #1\c_group_end_token }
\cs_new_protected:Npn \__avm_controls_type_starred:n #1
{
- \normalfont\__avm_font_type: #1\span
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\__avm_font_type: #1
+ \__avm_deinit_second_column:\span\hspace*{-2\tabcolsep}
\peek_meaning_ignore_spaces:NTF \\ {} {\\}
}
\cs_new_protected:Npn \__avm_controls_punk:nn #1 #2
{
- \normalfont\c_group_begin_token\__avm_font_attribute:#1%
- \c_group_end_token\hspace{2\arraycolsep}%
- \c_group_begin_token\__avm_font_type: #2\c_group_end_token%
- \span\peek_meaning_ignore_spaces:NTF \\ {} {\\}
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\c_group_begin_token\__avm_font_attribute:#1%
+ \c_group_end_token\hspace{2\tabcolsep}%
+ \c_group_begin_token\__avm_font_type: #2\c_group_end_token%
+ \__avm_deinit_second_column:\span\hspace*{-2\tabcolsep}
+ \peek_meaning_ignore_spaces:NTF \\ {} {\\}
}
\cs_new:Nn \__avm_initialise_document_commands:
@@ -568,6 +829,9 @@
\cs_if_exist:NTF \tag
{ \RenewDocumentCommand{\tag}{m}{ \__avm_controls_tag:n {##1} } }
{ \NewDocumentCommand{\tag}{m}{ \__avm_controls_tag:n {##1} } }
+ \cs_if_exist:NTF \0
+ { \RenewDocumentCommand{\0}{}{ \__avm_controls_tag:n {0} } }
+ { \NewDocumentCommand{\0}{}{ \__avm_controls_tag:n {0} } }
\cs_if_exist:NTF \1
{ \RenewDocumentCommand{\1}{}{ \__avm_controls_tag:n {1} } }
{ \NewDocumentCommand{\1}{}{ \__avm_controls_tag:n {1} } }
@@ -637,7 +901,7 @@
% \end{macro}
% \begin{macro}{\__avm_parse:n}
-% Finnaly, the parser. It is build on \cs{@@_act:NNNnn} from \cmd{l3tl} (see the sub-section \emph{Token by token changes}). Many thanks to Phelype Oleinik for help on this, and in particular on help with expansion.
+% Finnaly, the parser. It is build on \cs{@@@@_act:NNNnn} from \cmd{l3tl} (see the sub-section \emph{Token by token changes}). Many thanks to Phelype Oleinik for help on this, and in particular on help with expansion.
% \begin{macrocode}
\cs_new:Npn \__avm_parse:n #1
{
@@ -685,7 +949,9 @@
{
\str_case:nnF {#1}
{
- { + }{ \__avm_replace_plus: }
+ { \+ }{ \__avm_replace_plus: }
+ { \- }{ \__avm_replace_minus: }
+ { \shuffle }{ \__avm_replace_circle: }
{ [ }{ \__avm_replace_lbrack: }
{ ] }{ \__avm_replace_rbrack: }
{ ( }{ \__avm_replace_lparen: }
Modified: trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.ins 2020-06-29 21:30:59 UTC (rev 55698)
+++ trunk/Master/texmf-dist/source/latex/langsci-avm/langsci-avm.ins 2020-06-29 21:31:09 UTC (rev 55699)
@@ -12,15 +12,23 @@
\preamble
------------------------------------------------------------------------------
-langsci-avm: Attribute-value matrices (AVMs) and feature structures in LaTeX3.
+langsci-avm is aimed at typesetting beautiful feature structures,
+also known as attribute-value matrices (AVMs), for use in linguistics.
+The package provides a minimal and easy to read syntax.
+It depends only on the array package and can be placed almost everywhere,
+in particular in footnotes or graphs and tree structures. The package is meant
+as an update to, and serves the same purpose as, Christopher Manning’s
+avm package, but shares no code base with that package.
+
+langsci-avm was developed at Language Science Press to help in the
+production of scientific texts in linguistics.
+
Copyright (C) 2020 by Felix Kopecky, Language Science Press
-This work consists of the file langsci-avm.dtx &
- include/smallcaps-standalone.pdf.
+This work consists of the file langsci-avm.dtx
and the derived files langsci-avm.ins,
- langsci-avm.pdf,
- langsci-avm.sty.
+ langsci-avm.pdf.
It may be distributed and/or modified under the conditions of the
LaTeX Project Public License (LPPL), either version 1.3c of this
@@ -30,7 +38,7 @@
This work is ``maintained'' (per LPPL maintenance status) by
Felix Kopecky <felix.kopecky at langsci-press.org>.
-The development version of the bundle can be found at
+The development version can be found at
https://github.com/langsci/langsci-avm
Modified: trunk/Master/texmf-dist/tex/latex/langsci-avm/langsci-avm.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/langsci-avm/langsci-avm.sty 2020-06-29 21:30:59 UTC (rev 55698)
+++ trunk/Master/texmf-dist/tex/latex/langsci-avm/langsci-avm.sty 2020-06-29 21:31:09 UTC (rev 55699)
@@ -7,15 +7,23 @@
%% langsci-avm.dtx (with options: `package')
%% ------------------------------------------------------------------------------
%%
-%% langsci-avm: Attribute-value matrices (AVMs) and feature structures in LaTeX3.
+%% langsci-avm is aimed at typesetting beautiful feature structures,
+%% also known as attribute-value matrices (AVMs), for use in linguistics.
%%
+%% The package provides a minimal and easy to read syntax.
+%% It depends only on the array package and can be placed almost everywhere,
+%% in particular in footnotes or graphs and tree structures. The package is meant
+%% as an update to, and serves the same purpose as, Christopher Manning’s
+%% avm package, but shares no code base with that package.
+%%
+%% langsci-avm was developed at Language Science Press to help in the
+%% production of scientific texts in linguistics.
+%%
%% Copyright (C) 2020 by Felix Kopecky, Language Science Press
%%
-%% This work consists of the file langsci-avm.dtx &
-%% include/smallcaps-standalone.pdf.
+%% This work consists of the file langsci-avm.dtx
%% and the derived files langsci-avm.ins,
-%% langsci-avm.pdf,
-%% langsci-avm.sty.
+%% langsci-avm.pdf.
%%
%% It may be distributed and/or modified under the conditions of the
%% LaTeX Project Public License (LPPL), either version 1.3c of this
@@ -25,7 +33,7 @@
%% This work is ``maintained'' (per LPPL maintenance status) by
%% Felix Kopecky <felix.kopecky at langsci-press.org>.
%%
-%% The development version of the bundle can be found at
+%% The development version can be found at
%%
%% https://github.com/langsci/langsci-avm
%%
@@ -38,12 +46,14 @@
%% ------------------------------------------------------------------------------
\RequirePackage{xparse,array}
\ProvidesExplPackage {langsci-avm}
- {2020-03-11} {0.1.0-beta}
+ {2020-06-29} {0.2}
{AVMs and feature structures in LaTeX3}
\NewDocumentCommand{\avm}{ O{} +m }
{
\c_group_begin_token
\__avm_initialise_document_commands:
+ \__avm_initialise_custom_commands:
+ \tl_use:N \l__avm_defined_commands_tl
\bool_set_true:N \l__avm_mode_bool
\keys_set:nn { avm } { #1 }
\__avm_wrap:n { #2 }
@@ -55,8 +65,8 @@
\keys_define:nn { avm }
{
stretch .code:n = {\def\arraystretch{#1}},
- stretch .initial:n = {1.15},
- columnsep .dim_set:N = \arraycolsep,
+ stretch .initial:n = {0.9},
+ columnsep .dim_set:N = \tabcolsep,
columnsep .initial:n = {.5ex},
delimfactor .int_set:N = \delimiterfactor,
delimfactor .initial:n = {1000},
@@ -70,86 +80,156 @@
values .initial:n = {\itshape},
tags .code:n = {\cs_set:Nn \__avm_font_tag: {#1}},
tags .initial:n = {\footnotesize},
+ apptovalues .code:n = {\cs_set:Nn \__avm_deinit_second_column: {#1}},
+ apptovalues .initial:n = {\/},
+ singleton .code:n = {\cs_set:Nn \__avm_font_singleton: {#1}},
+ singleton .initial:n = {\normalfont},
switch .code:n = {\tl_set:Nn \__avm_mode_switch_character {#1}},
- switch .initial:n = { ! }
+ switch .initial:n = { ! },
+ extraskip .dim_set:N = \l__avm_extra_skip_dim,
+ extraskip .initial:n = {\smallskipamount},
+ customise .code:n = {\cs_set:Nn \__avm_initialise_custom_commands: {#1}},
+ customise .initial:n = { },
+ style .choice:,
+ style / narrow .code:n = {\delimiterfactor=997\delimitershortfall5pt},
}
-\bool_new:N \l__avm_math_bool
+\NewDocumentCommand{\avmdefinestyle}{ m m }
+ {
+ \keys_define:nn { avm }
+ {
+ style / #1 .code:n = { \keys_set:nn { avm } { #2 } }
+ }
+ }
+
+\NewDocumentCommand{\avmdefinecommand}{ m O{} m }
+ {
+ \tl_put_right:Nn \l__avm_defined_commands_tl
+ {
+ \exp_args:Nc \DeclareDocumentCommand { #1 } { s }
+ {
+ #2 \IfBooleanF { ##1 } { & } \avmsetup{ #3 }
+ }
+ }
+ }
+
\bool_new:N \l__avm_mode_bool
\seq_new:N \l__avm_parens_tracker
+\tl_new:N \l__avm_defined_commands_tl
\cs_generate_variant:Nn \seq_set_split:Nnn { NVn }
+\bool_new:N \l__avm_in_first_column
+
+\cs_new:Nn \__avm_init_first_column:
+ {
+ \bool_set_true:N \l__avm_in_first_column
+ \normalfont\__avm_font_attribute:
+ }
+
+\cs_new:Nn \__avm_init_second_column:
+ {
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\__avm_font_value:
+ }
+
+\cs_new:Nn \__avm_kern_unused_columns:
+ {
+ \bool_if:NTF \l__avm_in_first_column
+ { \span\hspace*{-2\tabcolsep} }
+ { }
+ }
+
+\cs_new:Nn \__avm_extra_skip:
+ {
+ \peek_meaning_ignore_spaces:NTF \\ {\vspace*{\l__avm_extra_skip_dim}} {}
+ }
+
\cs_new:Nn \__avm_module_begin:
{
- \begin{array}{
- >{\c_math_toggle_token\normalfont\__avm_font_attribute:}l
- <\c_math_toggle_token
- >{\c_math_toggle_token\normalfont\__avm_font_value:}l
- <\c_math_toggle_token}
+ \begin{tabular}{@{}
+ >{\__avm_init_first_column:}l
+ >{\__avm_init_second_column:}l
+ <{\__avm_deinit_second_column:}
+ @{}}
}
\cs_new:Nn \__avm_module_end:
- { \end{array} }
+ {
+ \__avm_kern_unused_columns:
+ \end{tabular}
+ }
\cs_new:Nn \__avm_replace_lbrace:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left\lbrace\__avm_module_begin: }
+ { \c_math_toggle_token\left\lbrace\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rbrace:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right\rbrace\c_math_toggle_token }
+ { \__avm_module_end:\right\rbrace\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_lbrack:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left\lbrack\__avm_module_begin: }
+ { \c_math_toggle_token\left\lbrack\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rbrack:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right\rbrack\c_math_toggle_token }
+ { \__avm_module_end:\right\rbrack\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_lparen:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left(\__avm_module_begin: }
+ { \c_math_toggle_token\left(\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rparen:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right)\c_math_toggle_token }
+ { \__avm_module_end:\right)\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_langle:
{
\__avm_parse_output:nw
- { \c_math_toggle_token\left<\__avm_module_begin: }
+ { \c_math_toggle_token\left<\__avm_module_begin: }
}
\cs_new:Nn \__avm_replace_rangle:
{
\__avm_parse_output:nw
- { \__avm_module_end:\right>\c_math_toggle_token }
+ { \__avm_module_end:\right>\c_math_toggle_token\__avm_extra_skip: }
}
\cs_new:Nn \__avm_replace_plus:
{
- \__avm_parse_output:nw { \ensuremath { \oplus } }
+ \__avm_parse_output:nw { \ensuremath { \oplus \! } }
}
+\cs_new:Nn \__avm_replace_minus:
+ {
+ \__avm_parse_output:nw { \ensuremath { \ominus \! } }
+ }
+\cs_new:Nn \__avm_replace_circle:
+ {
+ \__avm_parse_output:nw { \ensuremath { \bigcirc \, } }
+ }
\cs_new:Npn \__avm_controls_tag:n #1
{ \fboxsep.25ex\fbox{\normalfont\__avm_font_tag: #1} }
\cs_new:Npn \__avm_controls_type:n #1
- {\normalfont\__avm_font_type: #1}
+ { \c_group_begin_token\normalfont\__avm_font_type: #1\c_group_end_token }
\cs_new_protected:Npn \__avm_controls_type_starred:n #1
{
- \normalfont\__avm_font_type: #1\span
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\__avm_font_type: #1
+ \__avm_deinit_second_column:\span\hspace*{-2\tabcolsep}
\peek_meaning_ignore_spaces:NTF \\ {} {\\}
}
\cs_new_protected:Npn \__avm_controls_punk:nn #1 #2
{
- \normalfont\c_group_begin_token\__avm_font_attribute:#1%
- \c_group_end_token\hspace{2\arraycolsep}%
- \c_group_begin_token\__avm_font_type: #2\c_group_end_token%
- \span\peek_meaning_ignore_spaces:NTF \\ {} {\\}
+ \bool_set_false:N \l__avm_in_first_column
+ \normalfont\c_group_begin_token\__avm_font_attribute:#1%
+ \c_group_end_token\hspace{2\tabcolsep}%
+ \c_group_begin_token\__avm_font_type: #2\c_group_end_token%
+ \__avm_deinit_second_column:\span\hspace*{-2\tabcolsep}
+ \peek_meaning_ignore_spaces:NTF \\ {} {\\}
}
\cs_new:Nn \__avm_initialise_document_commands:
@@ -157,6 +237,9 @@
\cs_if_exist:NTF \tag
{ \RenewDocumentCommand{\tag}{m}{ \__avm_controls_tag:n {##1} } }
{ \NewDocumentCommand{\tag}{m}{ \__avm_controls_tag:n {##1} } }
+ \cs_if_exist:NTF \0
+ { \RenewDocumentCommand{\0}{}{ \__avm_controls_tag:n {0} } }
+ { \NewDocumentCommand{\0}{}{ \__avm_controls_tag:n {0} } }
\cs_if_exist:NTF \1
{ \RenewDocumentCommand{\1}{}{ \__avm_controls_tag:n {1} } }
{ \NewDocumentCommand{\1}{}{ \__avm_controls_tag:n {1} } }
@@ -264,7 +347,9 @@
{
\str_case:nnF {#1}
{
- { + }{ \__avm_replace_plus: }
+ { \+ }{ \__avm_replace_plus: }
+ { \- }{ \__avm_replace_minus: }
+ { \shuffle }{ \__avm_replace_circle: }
{ [ }{ \__avm_replace_lbrack: }
{ ] }{ \__avm_replace_rbrack: }
{ ( }{ \__avm_replace_lparen: }
More information about the tex-live-commits
mailing list.