% \iffalse meta-comment % An Infrastructure for Mathematical Statements in sTeX % Copyright (C) 2004-2008 Michael Kohlhase, all rights reserved % this file is released under the % LaTeX Project Public License (LPPL) % % The development version of this file can be found at % $HeadURL: https://svn.kwarc.info/repos/stex/trunk/sty/statements/statements.dtx $ % \fi % % \iffalse %\NeedsTeXFormat{LaTeX2e}[1999/12/01] %\ProvidesPackage{statements}[2012/01/28 v1.1 Semantic Markup for Statements] % %<*driver> \documentclass{ltxdoc} \usepackage{url,array,float,amsfonts} \usepackage{statements,modules,presentation} \usepackage{paralist} \usepackage[show]{ed} \usepackage[hyperref=auto,style=alphabetic]{biblatex} \bibliography{kwarc} \usepackage[eso-foot,today]{svninfo} \usepackage{stex-logo} \usepackage{../ctansvn} \usepackage{hyperref} \svnInfo $Id: statements.dtx 1999 2012-01-28 07:32:11Z kohlhase $ \svnKeyword $HeadURL: https://svn.kwarc.info/repos/stex/trunk/sty/statements/statements.dtx $ \makeindex \floatstyle{boxed} \newfloat{exfig}{thp}{lop} \floatname{exfig}{Example} \def\tracissue#1{\cite{sTeX:online}, \hyperlink{http://trac.kwarc.info/sTeX/ticket/#1}{issue #1}} \begin{document}\DocInput{statements.dtx}\end{document} % % \fi % % \CheckSum{597} % % \changes{v0.9}{2005/06/14}{First Version with Documentation} % \changes{v0.9a}{2005/07/01}{Completed Documentation} % \changes{v0.9b}{2005/08/06}{Complete functionality and Updated Documentation} % \changes{v0.9c}{2006/01/13}{more packaging} % \changes{v0.9d}{2007/09/09}{moved omtext and friends to the omdoc package} % \changes{v0.9d}{2007/09/09}{made dependence on the omdoc package explicit} % \changes{v0.9d}{2007/09/09}{adding ids to many elements} % \changes{v0.9e}{2008/05/27}{adding cross-references} % \changes{v0.9e}{2008/09/29}{augmenting the index macros with optional values} % \changes{v0.9f}{2008/12/04}{changed 'consymb' to 'symboldec' and documented it.} % \changes{v0.9g}{2010/01/14}{the package is now based on {\texttt{ntheorem for presentation}}} % \changes{v0.9g}{2010/01/19}{Added support for localization} % \changes{v0.9g}{2010/02/23}{added {\texttt{\textbackslash symref}}} % \changes{v1.0}{2010/06/18}{now based on {\texttt{omtext}} package instead of {\texttt{omdoc}}} % \changes{v1.0}{2010/07/13}{adding {\texttt{\textbackslash inlineex}}} % \changes{v1.1}{2011/08/25}{renaming all convenience macros for {\texttt{\textbackslash % definendum}} and {\texttt{\textbackslash termref}}} % % \GetFileInfo{statements.sty} % % \MakeShortVerb{\|} % \def\scsys#1{{{\sc #1}}\index{#1@{\sc #1}}} % \def\xml{\scsys{Xml}} % \def\mathml{\scsys{MathML}} % \def\omdoc{\scsys{OMDoc}} % \def\openmath{\scsys{OpenMath}} % \def\latexml{\scsys{LaTeXML}} % \def\perl{\scsys{Perl}} % \def\activemath{\scsys{ActiveMath}} % \title{Semantic Markup for Mathematical Statements\thanks{Version {\fileversion} (last revised % {\filedate})}} % \author{Michael Kohlhase\\ % Jacobs University, Bremen\\ % \url{http://kwarc.info/kohlhase}} % \maketitle % % \begin{abstract} % The |statements| package is part of the {\stex} collection, a version of {\TeX/\LaTeX} % that allows to markup {\TeX/\LaTeX} documents semantically without leaving the % document format, essentially turning {\TeX/\LaTeX} into a document format for % mathematical knowledge management (MKM). % % This package provides semantic markup facilities for mathematical statements like % Theorems, Lemmata, Axioms, Definitions, etc. in {\stex} files. This structure can be % used by MKM systems for added-value services, either directly from the {\sTeX} % sources, or after translation. % \end{abstract} % % \setcounter{tocdepth}{2}\tableofcontents\newpage % % \section{Introduction}\label{sec:intro} % % The motivation for the |statements| package is very similar to that for semantic macros % in the |modules| package: We want to annotate the structural semantic properties of % statements in the source, but present them as usual in the formatted documents. In % contrast to the case for mathematical objects, the repertoire of mathematical statements % and their structure is more or less fixed. % % This structure can be used by MKM systems for added-value services, either directly from % the {\sTeX} sources, or after translation. Even though it is part of the {\stex} % collection, it can be used independently, like it's sister package |sproofs|. % % {\stex}~\cite{Kohlhase:ulsmf08,sTeX:online} is a version of {\TeX/\LaTeX} that allows % to markup {\TeX/\LaTeX} documents semantically without leaving the document format, % essentially turning {\TeX/\LaTeX} into a document format for mathematical knowledge % management (MKM). Currently the {\omdoc} format~\cite{Kohlhase:omdoc1.2} is directly % supported. % % \section{The User Interface}\label{sec:user-interface} % % The |statements| package supplies a semantically oriented infrastructure for marking up % mathematical statements: fragments of natural language that state properties of % mathematical objects, e.g. axioms, definitions, or theorems. The |statement| package % provides an infrastructure for marking up the semantic relations between statements for % the {\omdoc} transformation and uses the |ntheorem| package~\cite{MaySch:eltte09} for % formatting (i.e. transformation to PDF). % % \subsection{Package Options}\label{sec:user:options} % % The |statements| package takes a single option: \DescribeMacro{showmeta}|showmeta|. If % this is set, then the metadata keys are shown (see~\cite{Kohlhase:metakeys:ctan} for details % and customization options). % % \subsection{Statements}\label{sec:statements} % % All the statements are marked up as environments, that take a |KeyVal| argument that % allows to annotate semantic information. Generally, we distinguish two forms of % statements: % \begin{description} % \item[{\twintoo{block}{statement}s}] have explicit discourse markers that delimit their % content in the surrounding text, e.g. the boldface word ``{\bf{Theorem}:}'' as a start % marker and a little line-end box as an end marker of a proof. % \item[{\twintoo{flow}{statement}s}] do not have explicit markers, they are interspersed % with the surrounding text. % \end{description} % Since they have the same semantic status, they must both be marked up, but styled % differently. We distinguis between these two presentational forms with the % \DescribeMacro{display=}|display| key, which is allowed on all statement % environments. If it has the value |block| (the default), then the statement will be % presented in a paragraph of its own, have explicit discourse markers for its begin and % end, possibly numbering, etc. If it has the value |flow|, then no extra presentation % will be added the semantic information is invisible to the reader. Another key that is % present on all statement environments in the \DescribeMacro{id=}|id| key it allows to % identify the statement with a name and to reference it with the semantic referencing % infrastructure provided by the |sref| package~\ctancite{Kohlhase:sref}. % % \subsubsection{Axioms and Assertions}\label{sec:user:axiomassertion} % % The \DescribeEnv{assertion}|assertion| environment is used for marking up statements % that can be justified from previously existing knowledge (usually marked with the % monikers ``Theorem'', ``Lemma'', ``Proposition'', etc. in mathematical vernacular). The % environment |assertion| is used for all of them, and the particular subtype of % assertion is given in the \DescribeMacro{type=}|type| key. So instead of % |\begin{Lemma}|\iffalse\end{Lemma}\fi we have to write % |\begin{assertion}[type=lemma]|\iffalse\end{assertion}\fi (see % Example~\ref{fig:assertion} for an example). % \begin{exfig} % \begin{verbatim} % \begin{assertion}[id=sum-over-odds,type=lemma] % $\sum_{i=1}^n{2i-1}=n^2$ % \end{assertion} % \end{verbatim} % \vspace{-1em}will lead to the result\vspace{-2em}\par\noindent % \begin{assertion}[id=sum-over-odds,type=lemma] % $\sum_{i=1}^n{2i-1}=n^2$ % \end{assertion} % \caption{Semantic Markup for a Lemma in a {\texttt{module}} context}\label{fig:assertion} % \end{exfig} % % Whether we will see the keyword ``Lemma'' will depend on the value of the optional % |display| key. In all of the |assertion| environments, the presentation expectation is % that the text will be presented in italic font. The presentation (keywords, spacing, and % numbering) of the |assertion| environment is delegated to a theorem styles from the % |ntheorem| environment. For an assertion of type \meta{type} the |assertion| environment % calls the |ST|\meta{type}|AssEnv| environment provided by the |statements| package; see % Figure~\ref{fig:assertion-types} for a list of provided assertion types. Their % formatting can be customized by redefining the |ST|\meta{type}|AssEnv| environment via % the |\renewtheorem| command from the |ntheorem| package; see~\cite{MaySch:eltte09} for % details. % % \begin{exfig} % \begin{tabular}{|l|l|}\hline % Value & Explanation \\\hline\hline % \textbf{theorem}, \textbf{proposition} % & an important assertion with a proof\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize Note that the meaning of \textbf{theorem} % (in this case the existence of a proof) is not % enforced by {\omdoc} applications. It can be appropriate to give an assertion % the \textbf{theorem}, if the % author knows of a proof (e.g. in the literature), but has not formalized it in % {\omdoc} yet.}\\\hline\hline % \textbf{lemma} & a less important assertion with a proof\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize The difference of importance specified % here is even softer than the other ones, since e.g. reusing % a mathematical paper as a chapter in a larger monograph, may make it necessary to % downgrade a theorem (e.g. the main theorem of the paper) and give it the status of % a lemma in the overall work.}\\\hline\hline % \textbf{corollary} & a simple consequence\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize An assertion is % sometimes marked as a corollary to some other statement, if the proof is % considered simple. This is often the case for important theorems that are simple % to get from technical lemmata.}\\\hline\hline % \textbf{postulate}, \textbf{conjecture} % & an assertion without proof or counter-exam\-ple\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize Conjectures are assertions, whose % semantic value is not yet decided, but which the author considers likely to be % true. In particular, there is no proof or counter-example.}\\\hline\hline % \textbf{false-conjecture} % & an assertion with a counter-example\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize A conjecture that has proven to be false, % i.e. it has a counter-example. Such assertions are often kept for illustration and % historical purposes.}\\\hline\hline % \textbf{obligation}, \textbf{assumption} % & an assertion on which a proof of another depends\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize These kinds of assertions % are convenient during the exploration of a mathematical theory. They can be used % and proven later (or assumed as an axiom).}\\\hline\hline % \textbf{observation} & if everything else fails\\\hline % \multicolumn{2}{|p{12cm}|}{\footnotesize This type is the catch-all if none of the others % applies.}\\\hline % \end{tabular} % \caption{Types of Mathematical Assertions}\label{fig:assertion-types} % \end{exfig} % % \DescribeEnv{axiom} The |axiom| environment is similar to |assertion|, but the content % has a different ontological status: axioms are assumed without (formal) justification, % whereas assertions are expected to be justified from other assertions, axioms or % definitions. This environment relegates the formatting to the |STaxiomEnv| environment, % which can be redefined for configuration. % % \subsubsection{Symbols}\label{sec:user:symbol} % % \DescribeEnv{symboldec} The |symboldec| environment can be used for declaring concepts % and symbols. Note the the |symdef| forms from the |modules| package will not do this % automatically (but the |definition| environment and the |\inlinedef| macro will for all % the definienda; see below). The |symboldec| environment takes an optional keywords % argument with the keys |id|, |role|, |title| and |name|. The first is for general % identification, the |role| specifies the {\openmath}/{\omdoc} role, which is one of % |object|, |type|, |sort|, |binder|, |attribution|, |application|, |constant|, % |semantic-attribution|, and |error| (see the {\omdoc} specification for details). The % |name| key specifies the {\openmath} name of the symbol, it should coincide with the % control sequence introduced by the corresponding |\symdef| (if one is present). The % |title| key is for presenting the title of this symbol as in other statements. Usually, % |axiom| and |symboldec| environments are used together as in Figure~\ref{fig:axioms}. % %\begin{exfig} % \begin{verbatim} % \symdef{zero}{0} % \begin{symboldec}[name=zero,title=The number zero,type=constant] % The number zero, it is used as the base case of the inductive definition % of natural numbers via the Peano Axioms. % \end{symboldec} % % \symdef{succ}[1]{\prefix{s}{#1}} % \begin{symboldec}[name=succ,title=The Successor Function,type=application] % The successor function, it is used for the step case of the inductive % definition of natural numbers via the Peano Axioms. % \end{symboldec} % % \symdef{NaturalNumbers}{\mathbb{N}} % \begin{symboldec}[name=succ,title=The Natural Numbers,type=constant] % The natural numbers inductively defined via the Peano Axioms. % \end{symboldec} % % \begin{axiom}[id=peano.P1,title=P1] % $\zero$ is a natural number. % \end{axiom} % ... % \begin{axiom}[id=peano.P5,title=P5] % Any property $P$ such $P(\zero)$ and $P(\succ{k})$ whenever $P(k)$ % holds for all $n$ in $\NaturalNumbers$ % \end{axiom} % \end{verbatim} % \vspace{-1em}will lead to the result\medskip\par\noindent % \begin{module}[id=peano] % \symdef{zero}{0} % \begin{symboldec}[name=zero,title=The number zero,role=constant] % The number zero, it is used as the base case of the inductive definition % of natural numbers via the Peano Axioms. % \end{symboldec} % % \symdef{succ}[1]{\prefix{s}{#1}} % \begin{symboldec}[name=succ,title=The Successor Function,role=application] % The successor function, it is used for the step case of the inductive % definition of natural numbers via the Peano Axioms. % \end{symboldec} % % \symdef{NaturalNumbers}{\mathbb{N}} % \begin{symboldec}[name=succ,title=The Natural Numbers,role=constant] % The natural numbers inductively defined via the Peano Axioms. % \end{symboldec} % % \begin{axiom}[id=peano.P1,title=P1] % $\zero$ is a natural number. % \end{axiom} % \ldots \stepcounter{STtheoremAssEnv}\stepcounter{STtheoremAssEnv}\stepcounter{STtheoremAssEnv} % \begin{axiom}[id=peano.P5,title=P5] % Any property $P$ such $P(\zero)$ and $P(\succ{k})$ whenever $P(k)$ % holds for all $n$ in $\NaturalNumbers$ % \end{axiom} % \end{module} % \caption{Semantic Markup for the Peano Axioms}\label{fig:axioms} % \end{exfig} % % \subsubsection{Definitions, and Definienda}\label{sec:definition} % % \DescribeEnv{definition} The |definition| environment is used for marking up % mathematical definitions. Its peculiarity is that it defines (i.e. gives a meaning to) % new mathematical concepts or objects. These\DescribeMacro{\definiendum} are identified % by the |\definiendum| macro, which is used as % |\definiendum[|\meta{sysname}|]{|\meta{text}|}|. Here, \meta{text} is the text that is % to be emphasized in the presentation and the optional \meta{sysname} is a system name of % the symbol defined (for reference via |\term|, see Section~\ref{sec:user:crossref}). If % \meta{sysname} is not given, then \meta{text} is used as a system name instead, which is % usually sufficient for most situations. % %\begin{exfig} % \begin{verbatim} % \symdef{one}{1} % \begin{definition}[id=one.def,for=one] % $\notatiendum[one]{\one}$ is the successor of $\zero$ % (formally: $\one\colon=\succ\zero$) % \end{definition} % \end{verbatim} % \vspace{-1em}will lead to the result\medskip\par\noindent % \begin{module} % \importmodule{peano} % \symdef{one}{1} % \begin{definition}[id=one.def,for=one] % $\notatiendum[one]{\one}$ is the successor of $\zero$ % (formally: $\one\colon=\succ\zero$) % \end{definition} % \end{module} % \caption{A Definition based on Figure {\ref{fig:axioms}}}\label{fig:definition} % \end{exfig} % The \DescribeMacro{defin}|\defi{|\meta{word}|}| macro combines the functionality of the % |\definiendum| macro with index markup from the |omdoc| % package~\ctancite{Kohlhase:smomdl}: use |\defi[|\meta{name}|]{|\meta{word}|}| to markup % a definiendum \meta{word} with system name \meta{name} that appear in the index --- in % other words in almost all definitions of single-word concepts. We also have the variants % \DescribeMacro{\defii}|\defii| and \DescribeMacro{\defiii}|\defiii| for (adjectivized) % two-word compounds. Finally, the varaiants \DescribeMacro{\adefi}|\adefi|, % \DescribeMacro{\adefii}|\adefii|,and \DescribeMacro{\adefiii}|\adefiii| have an % additional first argument that allows to specify an alternative text; see % Figure~\ref{fig:defin} % % \begin{exfig} % \begin{tabular}{l|l|l} % \multicolumn{3}{l}{source}\\ % system name & result & index \\\hline % \multicolumn{3}{l}{\texttt{\textbackslash defin\{concept\}}}\\ % |concept| & concept& concept\\\hline % \multicolumn{3}{l}{\texttt{\textbackslash defin[csymbol]\{concept\}}}\\ % |csymbol| & concept & concept\\\hline % \multicolumn{3}{l}{\texttt{\textbackslash definalt[csymbol]\{concepts\}\{concept\}}}\\ % |csymbol| & concepts & concept\\\hline % \multicolumn{3}{l}{\texttt{\textbackslash twindef\{concept\}\{group\}}}\\ % |concept-group| & concept group & concept group, \\ % && group - , concept\\\hline % \multicolumn{3}{l}{\texttt{\textbackslash atwindef\{small\}\{concept\}\{group\}}}\\ % |small-concept-group| & small concept group & small concept group, \\ % && concept group - , small\\ % \end{tabular} % \caption{Some definienda with Index}\label{fig:defin} % \end{exfig} % % Note that the |\definiendum|, |\defi|, |\defii|, and |\defiii| macros can only be % used inside the definitional situation, i.e. in a |definition| or |symboldec| % environment or a |\inlinedef| macro. If you find yourself in a situation where you want % to use it outside, you will most likely want to wrap the appropriate text fragment in a % |\begin{definition}[display=flow]| ... and |\end{definition}|. For instance, we could % continue the example in Figure~\ref{fig:axioms} with the |definition| environment in % Figure~\ref{fig:definition}. % % \DescribeMacro{\inlinedef} Sometimes we define mathematical concepts in passing, e.g. in % a phrase like ``\ldots $s(o)$ which we call {\textbf{one}}.''. For this we cannot use % the |definition| environment, which presupposes that its content gives all that is % needed to understand the definition. But we do want to make use of the infrastructure % introduced for the |definition| environment. In this situation, we just wrap the phrase % in an |\inlinedef| macro that makes them available. The |\inlinedef| macro accepts the % same |id| and |for| keys in its optional argument, and additionally the |verbalizes| key % which can be used to point to a full definition of the concept somewhere else. % % Note that definienda can only be referenced via a |\term| element, if they are only % allowed inside a named module, i.e. a |module| environment with a name given by the % |id=| key or the |theory=| key on is specified on the definitional environment. % % \subsubsection{Examples}\label{sec:user:example} % % \DescribeEnv{example} The |example| environment is a generic statement environment, % except that the |for| key should be given to specify the identifier what this is an % example for. The |example| environment also expects a |type| key to be specified, so % that we know whether this is an example or a counterexample. % % \DescribeMacro{\inlineex} The |\inlineex| is analogous to |\inlinedef|, only that it is % used for inline examples, e.g. ``\ldots mammals, e.g. goats''. Note that we have used an % inline example for an inline example. % % \subsection{Cross-Referencing Symbols and Concepts}\label{sec:user:crossref} % % If we have defined a concept with the |\definiendum| macro, then we can mark up other % occurrences of the term as referring to this concept. Note that this process cannot be % fully automatized yet, since that would need advanced language technology to get around % problems of disambiguation, inflection, and non-contiguous phrases\footnote{We do have a % program that helps annotate larger text collections spotting the easy cases; see % {\url{http://kwarc.info/projects/stex}} and look for the program % |termin|.}. Therefore, the \DescribeMacro{\termref}|\termref| can be used to make this % information explicit. It takes the keys % \begin{compactdesc} % \item[\texttt{cdbase}] to specify a URI (a path actually, since {\LaTeX} cannot load % from URIs) where the module can be found. % \item[\texttt{cd}] to specify the module in which the term is defined. If the |cd| key % is not given, then the current module is assumed. If no |cdbase| is specified (this is % the usual case), then the CD has to be imported via a |\importmodule| from the % |modules| package~\ctancite{KohAmb:smmssl}. % \item[\texttt{name}] to specify the name of the definiendum (which is given in the body % of the |\definiendum| or the optional argument). If the |name| key is not specified, % then argument of the |\termref| macro is used. % \item[\texttt{role}] is currently unused. % \end{compactdesc} % |\termref[cd=|\meta{cd}|,name=|\meta{name}|]{|\meta{text}|}| will just typeset the link % text \meta{text} with (if the |hyperref| package is loaded) a hyperlink to the % definition in module \meta{cd} that defines the concept \meta{name}, e.g. that contains % |\defi[|\meta{name}|]{|\meta{text}|}|. % % Just as the |\definiendum| macro has the convenience variants |\defi|, |\defii| and % |\defiii|, the |\termref| has variants |\trefi|, |\trefii|, and |\trefiii| that take two % and three arguments for the parts of the compositum. In the same module, concepts that % are marked up by |\defi{|\meta{name}|}| in the definition can be referenced by % \DescribeMacro{\trefi}|\trefi{|\meta{name}|}|. Here the link text is just % \meta{name}. Concepts defined via |\defii{|\meta{first}|}{|\meta{second}|}| can be % referenced by \DescribeMacro{\trefii}|\trefii{|\meta{first}|}{|\meta{second}|}| (with % link text ``\meta{first} \meta{second}'') and analogously for |\defiii| and % \DescribeMacro{\trefiii}|\trefiii|. Finally, we have variants % \DescribeMacro{\atref*}|\atrefi|, |\atrefii|, and |\atrefiii| with alternative link % text. For instance |\atrefii{|\meta{text}|{|\meta{first}|}{|\meta{second}|}| references % a concept introduced by |\defii{|\meta{first}|}{|\meta{second}|}| but with link text % \meta{text}. Of course, if the system identifier is given explicitly in the optional % argument of the definition form, as in % |\defii[|\meta{name}|]{|\meta{first}|}{|\meta{second}|}|, then the terms are referenced % by |\trefi{|\meta{name}|}|. % % For referencing terms outside the current module, the module name can be specified in % the first optional argument of the |\*tref*| macros. To specify the |cdbase|, we have to % resort to the |\termref| macro with the keyval arguments. % % Note that the |\termref| treatment above is natural for ``concepts'' declared by the % |\termdef| macro from the |modules| package~\ctancite{KohAmb:smmssl}. Concepts are % natural language names for mathematical objects. For ``symbols'', i.e. symbolic % identifiers for mathematical objects used in mathematical formulae, we use the |\symdef| % macro from the |modules| package. Sometimes, symbols also have an associated natural % language concept, and we want to use the symbol name to reference it (instead of % specifying |cd| and |name| which is more inconvenient). For this the |statements| % package supplies the \DescribeMacro{\symref}|\symref| macro. Like |\termref|, and % invocation of |\symref{|\meta{cseq}|}{|\meta{text}|}| will just typeset \meta{text} with % a hyperlink to the relevant definition (i.e. the one that has the declaration % |for=|\meta{cseq} in the metadata argument.) % % \section{Configuration of the Presentation}\label{sec:conf} % % \DescribeMacro{\defemph} The |\defemph| macro is a configuration hook that allows to % specify the style of presentation of the {\index*{definiendum}}. By default, it is set to % |\bf| as a fallback, since we can be sure that this is always available. It can be % customized by redefinition: For instance |\renewcommand{\defemph}[1]{\emph{#1}}|, % changes the default behavior to italics. % % \DescribeMacro{\termemph} The |\termenph| macro does the same for the style for % |\termref|, it is empty by default. Note the term might carry an implicit hyper-reference % to the defining occurrence and that the presentation engine might mark this up, changing % this behavior. % % \DescribeMacro{\stDMemph} The |\stDMemph| macro does the same for the style for the % markup of the discourse markers like ``Theorem''. If it is not defined, it is set to % |\bf|; that allows to preset this in the class file. \ednote{function declarations} % % Some authors like to lowercase the semantic references, i.e. use ``axiom 2.6'' instead % of the default ``\sref{peano.P5}'' to refer to the last axiom in % Figure~\ref{fig:axioms}. This can be achieved by redefining the % \DescribeMacro{\STpresent}|\STpresent| macro, which is applied to the keyword of the % |ST*Env| theorem environments.\ednote{this does not quite work as yet, since % \textbf{STpresent} is applied when the label is written. But we would really like to % have it applied when the reference is constructed. But for that we need to split the % label into keyword and number in package |sref|.} % % Finally, we provide configuration hooks in Figure~\ref{fig:hooks} for the statement % types provided by the |statement| package. These are mainly intended for package authors % building on |statements|, e.g. for multi-language support.\ednote{we might want to % develop an extension \texttt{statements-babel} in the future.}. %\begin{exfig} % \begin{tabular}{lll} % Environment & configuration macro & value\\\hline\hline % \texttt{STtheoremAssEnv} & \texttt{\textbackslash st@theorem@kw} & \makeatletter\st@theorem@kw\\\hline % \texttt{STlemmaAssEnv} & \texttt{\textbackslash st@lemma@kw} & \makeatletter\st@lemma@kw \\\hline % \texttt{STpropositionAssEnv} & \texttt{\textbackslash st@proposition@kw} & \makeatletter\st@proposition@kw \\\hline % \texttt{STcorollaryAssEnv} & \texttt{\textbackslash st@corollary@kw} & \makeatletter\st@corollary@kw\\\hline % \texttt{STconjectureAssEnv} & \texttt{\textbackslash st@conjecture@kw} & \makeatletter\st@conjecture@kw\\\hline % \texttt{STfalseconjectureAssEnv} & \texttt{\textbackslash st@falseconjecture@kw} & \makeatletter\st@falseconjecture@kw\\\hline % \texttt{STpostulateAssEnv} & \texttt{\textbackslash st@postulate@kw} & \makeatletter\st@postulate@kw\\\hline % \texttt{STobligationAssEnv} & \texttt{\textbackslash st@obligation@kw} & \makeatletter\st@obligation@kw\\\hline % \texttt{STassumptionAssEnv} & \texttt{\textbackslash st@assumption@kw} & \makeatletter\st@assumption@kw\\\hline % \texttt{STobservationAssEnv} & \texttt{\textbackslash st@observation@kw} & \makeatletter\st@observation@kw\\\hline % \texttt{STexampleEnv} & \texttt{\textbackslash st@example@kw} & \makeatletter\st@example@kw\\\hline % \texttt{STaxiomEnv} & \texttt{\textbackslash st@axiom@kw} & \makeatletter\st@axiom@kw\\\hline % \texttt{STdefinitionEnv} & \texttt{\textbackslash st@definition@kw} & \makeatletter\st@definition@kw\\\hline % \texttt{STnotationEnv} & \texttt{\textbackslash st@notation@kw} & \makeatletter\st@notation@kw % \end{tabular} % \caption{Configuration Hooks for statement types}\label{fig:hooks} % \end{exfig} % % \section{Limitations}\label{sec:limitations} % % In this section we document known limitations. If you want to help alleviate them, % please feel free to contact the package author. Some of them are currently discussed in % the \sTeX TRAC~\cite{sTeX:online}. % \begin{compactenum} % \item none reported yet % \end{compactenum} % % \StopEventually{\newpage\PrintIndex\newpage\PrintChanges\printbibliography} % % \section{The Implementation}\label{sec:impl} % % The |statements| package generates two files: the {\LaTeX} package (all the code between % {\textsf{$\langle$*package$\rangle$}} and {\textsf{$\langle$/package$\rangle$}}) and the % {\latexml} bindings (between {\textsf{$\langle$*ltxml$\rangle$ and % $\langle$/ltxml$\rangle$}}). We keep the corresponding code fragments together, % since the documentation applies to both of them and to prevent them from getting out of % sync. % % \subsection{Package Options}\label{sec:impl:options} % % We declare some switches which will modify the behavior according to the package % options. Generally, an option |xxx| will just set the appropriate switches to true % (otherwise they stay false). First we have the general options % \begin{macrocode} %<*package> \DeclareOption{showmeta}{\PassOptionsToPackage{\CurrentOption}{metakeys}} \DeclareOption*{\PassOptionsToPackage{\CurrentOption}{omdoc}} % \end{macrocode} % Finally, we need to declare the end of the option declaration section to {\LaTeX}. % \begin{macrocode} \ProcessOptions % % \end{macrocode} % % The next measure is to ensure that some {\sTeX} packages are loaded: |omdoc| for the % statement keys, |modules| since we need module identifiers for referencing. Furthermore, % we need the |ntheorem| package for presenting statements. For {\latexml}, we also % initialize the package inclusions, there we do not need |ntheorem|, since the XML does % not do the presentation. % \begin{macrocode} %<*package> \RequirePackage{omtext} \RequirePackage{modules} \RequirePackage[hyperref]{ntheorem} \theoremstyle{plain} % %<*ltxml> # -*- CPERL -*- package LaTeXML::Package::Pool; use strict; use LaTeXML::Package; RequirePackage('omtext'); RequirePackage('modules'); % % \end{macrocode} % Now, we define an auxiliary function that lowercases strings % \begin{macrocode} %<*ltxml> sub lowcase {my ($string) = @_; $string ? return lc(ToString($string)) : return('')}#$ sub dashed { join('-',map($_->toString,@_));}#$ % % \end{macrocode} % Sometimes it is necessary to fallback to symbol names in order to generate xml:id attributes. For this purpose, % we define an auxiliary function which ensures the name receives a unique NCName equivalent.\ednote{Hard to be unique here, % e.g. the names "foo\_bar" and "foo bar" would receive the same xml:id attributes... of course we can devise a more complex scheme % for the symbol replacement.} % \begin{macrocode} %<*ltxml> sub makeNCName { my ($name) = @_; my $ncname=$name; $ncname=~s/\s/_/g; #Spaces to underscores $ncname="_$ncname" if $ncname!~/^(\w|_)/; #Ensure start with letter or underscore ##More to come... $ncname; } % % \end{macrocode} % The following functions are strictly utility functions that makes our life easier later on % \begin{macrocode} %<*ltxml> sub simple_wrapper { #Deref if array reference my @input; foreach (@_) { if (ref $_ && $_ =~ /ARRAY/ && $_ !~ /LaTeXML/) { @input=(@input,@$_); } else { push (@input,$_); } } return '' if (!@input); @input = map(split(/\s*,\s*/,ToString($_)),@input); my $output=join(" ",@input); $output=~s/(^ )|[{}]//g; #remove leading space and list separator brackets $output||''; } sub hash_wrapper{ #Deref if array reference my @input; foreach (@_) { if (ref $_ && $_ =~ /ARRAY/ && $_ !~ /LaTeXML/) { @input=(@input,@$_); } else { push (@input,$_); } } return '' if (!@input); @input = map(split(/\s*,\s*/,ToString($_)),@input); my $output=join(".sym #",@input); $output=~s/(^\.sym )|[{}]//g; #remove leading space and list separator brackets "#$output"||''; } % % \end{macrocode} % % \subsection{Statements}\label{sec:impl:statements} % % \begin{macro}{\STpresent} % \begin{macrocode} %<*package> \providecommand\STpresent[1]{#1} % % \end{macrocode} % \end{macro} % % \begin{macro}{\define@statement@env} % We define a meta-macro that allows us to define several variants of statements. Upon % beginning this environment, we first set the |KeyVal| attributes, then we decide % whether to print the discourse marker based on the value of the |display| key, then % (given the right Options were set), we show the semantic annotations, and finally % initialize the environment using the appropriate macro. Upon ending the environment, % we just run the respective termination macro. % \begin{macrocode} %<*package> \def\define@statement@env#1{% \newenvironment{#1}[1][]{\metasetkeys{omtext}{##1}\sref@target% \ifx\omtext@display\st@flow\else% \ifx\omtext@title\@empty\begin{ST#1Env}\else\begin{ST#1Env}[\omtext@title]\fi% \ifx\sref@id\@empty\else\label{#1.\sref@id}\fi \csname st@#1@initialize\endcsname\fi \ifx\sref@id\@empty\sref@label@id{here}\else% \sref@label@id{\STpresent{\csname ST#1EnvKeyword\endcsname}~\@currentlabel}\fi} {\csname st@#1@terminate\endcsname\ifx\omtext@display\st@flow\else\end{ST#1Env}\fi}} % % \end{macrocode} % \end{macro} % % \begin{environment}{assertion} % \begin{macrocode} %<*package> \newenvironment{assertion}[1][]{\metasetkeys{omtext}{#1}\sref@target% \ifx\omtext@display\st@flow\else% \ifx\omtext@title\@empty\begin{ST\omtext@type AssEnv}% \else\begin{ST\omtext@type AssEnv}[\omtext@title]\fi\fi% \ifx\omtext@type\@empty\sref@label@id{here}\else% \sref@label@id{\STpresent{\csname ST\omtext@type AssEnvKeyword\endcsname}~\@currentlabel}\fi} {\ifx\omtext@display\st@flow\else\end{ST\omtext@type AssEnv}\fi} % %<*ltxml> DefEnvironment('{assertion} OptionalKeyVals:omtext', "" . "?&KeyVal(#1,'title')(&KeyVal(#1,'title'))()" . "#body" ."\n"); % % \end{macrocode} % \end{environment} % % \begin{macro}{\st@*@kw} % We configure the default keywords for the various theorem environments. % \begin{macrocode} %<*package> \def\st@theorem@kw{Theorem} \def\st@lemma@kw{Lemma} \def\st@proposition@kw{Proposition} \def\st@corollary@kw{Corollary} \def\st@conjecture@kw{Conjecture} \def\st@falseconjecture@kw{Conjecture (false)} \def\st@postulate@kw{Postulate} \def\st@obligation@kw{Obligation} \def\st@assumption@kw{Assumption} \def\st@observation@kw{Observation} % \end{macrocode} % \end{macro} % Then we configure the presentation of the theorem environments % \begin{macrocode} \theorembodyfont{\itshape} \theoremheaderfont{\normalfont\bfseries} % \end{macrocode} % and then we finally define the theorem environments in terms of the statement keywords % defined above. They are all numbered together with the section counter. % \begin{environment}{ST*AssEnv} % \begin{macrocode} \newtheorem{STtheoremAssEnv}{\st@theorem@kw} \newtheorem{STlemmaAssEnv}[STtheoremAssEnv]{\st@lemma@kw} \newtheorem{STpropositionAssEnv}[STtheoremAssEnv]{\st@proposition@kw} \newtheorem{STcorollaryAssEnv}[STtheoremAssEnv]{\st@corollary@kw} \newtheorem{STconjectureAssEnv}[STtheoremAssEnv]{\st@conjecture@kw} \newtheorem{STfalseconjectureAssEnv}[STtheoremAssEnv]{\st@falseconjecture@kw} \newtheorem{STpostulateAssEnv}[STtheoremAssEnv]{\st@postulate@kw} \newtheorem{STobligationAssEnv}[STtheoremAssEnv]{\st@obligation@kw} \newtheorem{STassumptionAssEnv}[STtheoremAssEnv]{\st@assumption@kw} \newtheorem{STobservationAssEnv}[STtheoremAssEnv]{\st@observation@kw} % % \end{macrocode} % \end{environment} % % \begin{environment}{example} % \begin{macrocode} %<*package> \def\st@example@initialize{}\def\st@example@terminate{} \define@statement@env{example} \def\st@example@kw{Example} \theorembodyfont{\upshape} \newtheorem{STexampleEnv}[STtheoremAssEnv]{\st@example@kw} % %<*ltxml> DefEnvironment('{example} OptionalKeyVals:omtext', "" . "?&KeyVal(#1,'title')(&KeyVal(#1,'title'))()" . "#body" . "\n"); % % \end{macrocode} % \end{environment} % % \begin{environment}{axiom} % \begin{macrocode} %<*package> \def\st@axiom@initialize{}\def\st@axiom@terminate{} \define@statement@env{axiom} \def\st@axiom@kw{Axiom} \theorembodyfont{\upshape} \newtheorem{STaxiomEnv}[STtheoremAssEnv]{\st@axiom@kw} % %<*ltxml> DefEnvironment('{axiom} OptionalKeyVals:omtext', "" . "?&KeyVal(#1,'title')(&KeyVal(#1,'title'))()" . "#body" . "\n"); % % \end{macrocode} % \end{environment} % % \begin{environment}{symboldec} % \begin{macrocode} %<*package> \srefaddidkey{symboldec} \addmetakey{symboldec}{functions} \addmetakey{symboldec}{role} \addmetakey*{symboldec}{title} \addmetakey{symboldec}{name} \addmetakey{symboldec}{subject} \addmetakey*{symboldec}{display} \def\symboldec@type{Symbol} \newenvironment{symboldec}[1][]{\metasetkeys{symboldec}{#1}\sref@target\st@indeftrue% \ifx\symboldec@display\st@flow\else{\stDMemph{\symboldec@type} \symboldec@name:}\fi% \ifx\symboldec@title\@empty~\else~(\stDMemph{\symboldec@title})\par\fi}{} % %<*ltxml> DefEnvironment('{symboldec} OptionalKeyVals:symboldec', "" . "?&KeyVal(#1,'title')(&KeyVal(#1,'title'))()" . "#body" ."\n"); % % \end{macrocode} % \end{environment} % % \begin{macro}{\symtype} % \begin{macrocode} %<*package> \newcommand{\symtype}[2]{Type (#1): $#2$} % %<*ltxml> DefConstructor('\symtype{}{}', "#2"); % % \end{macrocode} % \end{macro} % % \begin{environment}{definition} % The |definition| environment itself is quite similar to the other's but we need to set % the |\st@indef| switch to suppress warnings from |\st@def@target|. % \begin{macrocode} %<*package> \newif\ifst@indef\st@indeffalse \newenvironment{definition}[1][]{\metasetkeys{omtext}{#1}\sref@target\st@indeftrue% \ifx\omtext@display\st@flow\else% \ifx\omtext@title\@empty\begin{STdefinitionEnv}\else\begin{STdefinitionEnv}[\omtext@title]\fi\fi% \ifx\sref@id\@empty\sref@label@id{here}\else% \sref@label@id{\STpresent{\csname STdefinitionEnvKeyword\endcsname}~\@currentlabel}\fi} {\ifx\omtext@display\st@flow\else\end{STdefinitionEnv}\fi} \def\st@definition@kw{Definition} \theorembodyfont{\upshape} \newtheorem{STdefinitionEnv}[STtheoremAssEnv]{\st@definition@kw} % %<*ltxml> sub definitionBody { my ($doc, $keyvals, %props) = @_; my $for = $keyvals->getValue('for') if $keyvals; my $type = $keyvals->getValue('type') if $keyvals; my %for_attr=(); if (ToString($for)) { $for = ToString($for); $for =~ s/^{(.+)}$/$1/eg; foreach (split(/,\s*/,$for)) { $for_attr{$_}=1; }} if ($props{theory}) { my @symbols = @{$props{defs} || []}; foreach my $symb(@symbols) { next if $for_attr{$symb}; $for_attr{$symb}=1; $doc->insertElement('omdoc:symbol', undef, (name=>$symb, "xml:id"=>makeNCName("$symb.def.sym"))); } } my %attrs = (); $for = join(" ",(keys %for_attr)); $attrs{'for'} = $for if $for; my $id = $keyvals->getValue('id') if $keyvals; $attrs{'xml:id'} = $id if $id; $attrs{'type'} = $type if $type; if ($props{theory}) { $doc->openElement('omdoc:definition', %attrs); } else { $attrs{'type'}='definition'; $doc->openElement('omdoc:omtext', %attrs); } my $title = $keyvals->getValue('title') if $keyvals; if ($title) { $doc->openElement('omdoc:metadata'); $doc->openElement('dc:title'); $doc->absorb($title); $doc->closeElement('dc:title');} $doc->openElement('omdoc:CMP'); $doc->absorb($props{body}) if $props{body}; $doc->maybeCloseElement('omdoc:CMP'); if ($props{theory}) { $doc->closeElement('omdoc:definition'); } else { $doc->closeElement('omdoc:omtext'); } return; } DefEnvironment('{definition} OptionalKeyVals:omtext', sub{definitionBody(@_)}, afterDigestBegin=>sub { my ($stomach, $whatsit) = @_; my @symbols = (); $whatsit->setProperty(theory=>LookupValue('current_module')); $whatsit->setProperty(defs=>\@symbols); AssignValue('defs', \@symbols); return; }, afterDigest => sub { AssignValue('defs', undef); return; });#$ % % \end{macrocode} % \end{environment} % % \begin{environment}{notation} % We initialize the |\def\st@notation@initialize{}| here, and extend it with % functionality below. % \begin{macrocode} %<*package> \def\notemph#1{{\bf{#1}}} \def\st@notation@terminate{} \def\st@notation@initialize{} \define@statement@env{notation} \def\st@notation@kw{Notation} \theorembodyfont{\upshape} \newtheorem{STnotationEnv}[STtheoremAssEnv]{\st@notation@kw} % %<*ltxml> DefEnvironment('{notation} OptionalKeyVals:omtext', "" . "?&KeyVal(#1,'title')(&KeyVal(#1,'title'))()" . "#body" . "\n"); DefConstructor('\notatiendum OptionalKeyVals:notation {}', "#2"); % % \end{macrocode} % \end{environment} % % \begin{macro}{\st@def@target} % the next macro is a variant of the |\sref@target| macro provided by the |sref| package % specialized for the use in the |\definiendum|, |\defi|, |\defii|, and |\defiii| % macros. |\st@def@target{|\meta{opt}|}{|\meta{name}|}| makes a target with label % |sref@|\meta{opt}|@|\meta{modulename}|@target|, if \meta{opt} is non-empty, else with % the label |sref@|\meta{name}|@|\meta{modulename}|@target|. Also it generates the % necessary warnings for a definiendum-like macro. % \begin{macrocode} %<*package> \def\st@def@target#1#2{\def\@test{#1}% \ifst@indef% if we are in a definition or such \ifx\omtext@theory\@empty% if there is no theory attribute \@ifundefined{mod@id}% if we are not in a module {\PackageWarning{statements}{definiendum in unidentified module\MessageBreak \protect\definiendum, \protect\defi, \protect\defii, \protect\defiii\MessageBreak can only be referenced when called in a module with id key}}% {\ifx\@test\@empty% \expandafter\sref@target@ifh{sref@#2@\mod@id @target}{}\else% \expandafter\sref@target@ifh{sref@#1@\mod@id @target}{}\fi}% \else\expandafter\sref@target@ifh{sref@#1@\omtext@theory @target}{}\fi% \else\PackageError{statements}% {definiendum outside definition context\MessageBreak \protect\definiendum, \protect\defi, \protect\defii, \protect\defiii\MessageBreak do not make sense semantically outside a definition.\MessageBreak Consider wrapping the defining phrase in a \protect\inlinedef}% \fi} % % \end{macrocode} % \end{macro} % % The |\definiendum| and |\notatiendum| macros are very simple. % % \begin{macro}{\@termdef} % This macro is experimental, it is supposed to be invoked in |\definiendum| to define a % macro with the definiendum text, so that can be re-used later in term assignments (see % the |modules| package). But in the current context, where we rely on {\TeX} groupings % for visibility, this does not work, since the invocations of |\definiendum| are in % |definition| environments and thus one group level too low. Keeping this for future % reference. % \begin{macrocode} %<*package> \newcommand\@termdef[2][]{\def\@test{#1}% \@ifundefined{mod@id}{}{\ifx\@test\@empty\def\@@name{#2}\else\def\@@name{#1}\fi% \termdef{\mod@id @\@@name}{#2}}} % % \end{macrocode} % \end{macro} % % \begin{macro}{\definiendum} % \begin{macrocode} %<*package> %\newcommand\definiendum[2][]{\st@def@target{#1}{#2}\@termdef[#1]{#2}\defemph{#2}} \newcommand\definiendum[2][]{\st@def@target{#1}{#2}\defemph{#2}} % %<*ltxml> DefConstructor('\definiendum [] {}', "#2", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $whatsit->getArg(2) unless $name; $whatsit->setProperty(name=>$name->toString); push(@$addr, $name->toString) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module')); return; });#$ % % \end{macrocode} % \end{macro} % % \begin{macro}{\notatiendum} % the |notatiendum| macro also needs to be visible in the |notation| and |definition| % environments % \begin{macrocode} %<*package> \newcommand{\notatiendum}[2][]{\notemph{#2}} % % \end{macrocode} % \end{macro} % % We expand the {\latexml} bindings for |\defi|, |\defii| and |\defiii| into two % instances one will be used for the definition and the other for indexing. % % \begin{macro}{\defi} % \begin{macrocode} %<*package> \newcommand{\defi}[2][]{\definiendum[#1]{#2}\omdoc@index[#1]{#2}} % %<*ltxml> DefConstructor('\defi[]{}', "" . "" . "#2" . "" . "#2" ."", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $whatsit->getArg(2) unless $name; push(@$addr, $name->toString) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module'));#$ return; }, alias=>'\defi'); % % \end{macrocode} % \end{macro} % % \begin{macro}{\adefi} % \begin{macrocode} %<*package> \newcommand{\adefi}[3][]{\def\@test{#1}% \ifx\@test\@empty\definiendum[#3]{#2}% \else\definiendum[#1]{#2}\omdoc@index[#1]{#3}\fi} % %<*ltxml> DefConstructor('\adefi[]{}{}', "" . "" . "#2" . "" . "#3" ."", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $whatsit->getArg(3) unless $name; push(@$addr, $name->toString) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module'));#$ return; }, alias=>'\adefi'); % % \end{macrocode} % \end{macro} % % \begin{macro}{\defii} % \begin{macrocode} %<*package> \newcommand{\defii}[3][]{\st@def@target{#1}{#2-#3}\defemph{#2 #3}\@twin[#1]{#2}{#3}} % %<*ltxml> DefConstructor('\defii[]{}{}', "" . "" . "" . "#2 #3" . "" . "" . "" . "#2" . "#3" . "" ."", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $name->toString if $name; $name = $whatsit->getArg(2)->toString.'-'.$whatsit->getArg(3)->toString unless $name; push(@$addr, $name) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module')); return; }, alias=>'\defii');#$ % % \end{macrocode} % \end{macro} % % \begin{macro}{\adefii} % \begin{macrocode} %<*package> \newcommand{\adefii}[4][]{\def\@test{#1}% \ifx\@test\@empty\definiendum[#3-#4]{#2}% \else\definiendum[#1]{#2}\@twin[#1]{#3}{#4}\fi} % %<*ltxml> DefConstructor('\adefii[]{}{}{}', "" . "" . "" . "#2" . "" . "" . "" . "#3" . "#4" . "" ."", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $name->toString if $name; $name = $whatsit->getArg(3)->toString.'-'.$whatsit->getArg(4)->toString unless $name; push(@$addr, $name) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module')); return; }, alias=>'\defii');#$ % % \end{macrocode} % \end{macro} % % \begin{macro}{\defiii} % \begin{macrocode} %<*package> \newcommand{\defiii}[4][]{\st@def@target{#1}{#2-#3-#4}\defemph{#2 #3 #4}\@atwin[#1]{#2}{#3}{#4}} % %<*ltxml> DefConstructor('\defiii[]{}{}{}', "" . "" . "#2 #3 #4" . "" . "" . "#2" . "#3" . "#4" . "" . "", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $name->toString if $name; $name = $whatsit->getArg(2)->toString.'-'.$whatsit->getArg(3)->toString.'-'.$whatsit->getArg(4)->toString unless $name; push(@$addr, $name) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module')); return; }, alias=>'\defiii'); % % \end{macrocode} % \end{macro} % % \begin{macro}{\adefiii} % \begin{macrocode} %<*package> \newcommand{\adefiii}[5][]{\def\@test{#1}% \ifx\@test\@empty\definiendum[#3-#4-#5]{#2}% \else\definiendum[#1]{#2}\@atwin[#1]{#3}{#4}{#5}\fi} % %<*ltxml> DefConstructor('\adefiii[]{}{}{}{}', "" . "" . "#2" . "" . "" . "#3" . "#4" . "#5" . "" . "", afterDigest => sub { my ($stomach, $whatsit) = @_; my $addr = LookupValue('defs'); my $name = $whatsit->getArg(1); $name = $name->toString if $name; $name = $whatsit->getArg(3)->toString.'-'.$whatsit->getArg(4)->toString.'-'.$whatsit->getArg(5)->toString unless $name; push(@$addr, $name) if ($addr and $name); $whatsit->setProperty(theory=>LookupValue('current_module')); return; }, alias=>'\defiii'); % % \end{macrocode} % \end{macro} % % \begin{macro}{\inlineex} % \begin{macrocode} %<*package> \newcommand{\inlineex}[2][]{\metasetkeys{omtext}{#1}\sref@target\sref@label@id{here}#2} % %<*ltxml> DefConstructor('\inlineex OptionalKeyVals:omtext {}', "#2"); % % \end{macrocode} % \end{macro} % \begin{macro}{\inlinedef} % \begin{macrocode} %<*package> \newcommand{\inlinedef}[2][]{\metasetkeys{omtext}{#1}\sref@target\sref@label@id{here}\st@indeftrue #2} % %<*ltxml> DefConstructor('\inlinedef OptionalKeyVals:omtext {}', sub { my ($document, $keyvals, $body, %props) = @_; my $for = $keyvals->getValue('for') if $keyvals; my %for_attr=(); if (ToString($for)) { $for = ToString($for); $for =~ s/^{(.+)}$/$1/eg; foreach (split(/,\s*/,$for)) { $for_attr{$_}=1; }} my @symbols = @{$props{defs} || []}; #Prepare for symbol insertion -insert before the parent of the closest ancestor CMP element my $original_node = $document->getNode; my $xc = XML::LibXML::XPathContext->new( $original_node ); $xc->registerNs('omdoc', 'http://omdoc.org/ns'); my ($statement_ancestor) = $xc->findnodes('./ancestor::omdoc:CMP/..'); foreach my $symb(@symbols) { next if $for_attr{$symb}; $for_attr{$symb}=1; my $symbolnode = XML::LibXML::Element->new('symbol'); $symbolnode->setAttribute(name=>$symb); $symbolnode->setAttribute("xml:id"=>makeNCName("$symb.def.sym")); $statement_ancestor->parentNode->insertBefore($symbolnode,$statement_ancestor); } #Restore the insertion point $document->setNode($original_node); my %attrs = (); $for = join(" ",(keys %for_attr)); $attrs{'for'} = $for if $for; my $id = $keyvals->getValue('id') if $keyvals; $attrs{'xml:id'} = $id if $id; $attrs{'class'} = 'inlinedef'; $document->openElement('ltx:text',%attrs); $document->absorb($body); $document->closeElement('ltx:text'); }, #Prepare 'defs' hooks for \defi and \definiendum symbol names beforeDigest=>sub { my @symbols = (); AssignValue('defs', \@symbols); return; }, #Adopt collected names as 'defs' property, remove hooks afterDigest=>sub { my ($stomach, $whatsit) = @_; my $defsref = LookupValue('defs'); my @defs = @$defsref; $whatsit->setProperty('defs',\@defs); AssignValue('defs',undef); return; }); % % \end{macrocode} % \end{macro} % % \subsection{Cross-Referencing Symbols and Concepts}\label{sec:impl:crossref} % % \begin{macro}{\termref@set} % The |term| macro uses the |cd| and |name| keys for hyperlinking to create hyper-refs, % if the |hyperref| package is loaded: We first see if the |cd| key was given, if not we % define it as the local module identifier. % \begin{macrocode} %<*package> \addmetakey[\mod@id]{termref}{cd} \addmetakey{termref}{cdbase} \addmetakey{termref}{name} \addmetakey{termref}{role} \def\termref@set#1#2{\def\termref@name{#2}\metasetkeys{termref}{#1}} % \end{macrocode} % \end{macro} % % \begin{macro}{\termref} % \begin{macrocode} \newcommand{\termref}[2][]{\metasetkeys{termref}{#1}\st@termref{#2}} % %<*ltxml> DefConstructor('\termref OptionalKeyVals:termref {}', "" . "#2" ."", afterDigest=>sub{$_[1]->setProperty(module=>LookupValue('current_module'))}); %%$ % \end{macrocode} % \end{macro} % The next macro is where the actual work is done. % \begin{macro}{\st@termref} % If the |cdbase| is given, then we make a hyper-reference, otherwise we punt to % |\mod@termref|, which can deal with the case where the cdbase is given by the imported % cd. % \begin{macrocode} %<*package> \def\st@termref#1{\ifx\termref@name\@empty\def\termref@name{#1}\fi% \ifx\termref@cdbase\@empty\mod@termref\termref@cd\termref@name{#1}% \else\sref@href@ifh\termref@cdbase{#1}\fi} % % \end{macrocode} % \end{macro} % % \begin{macro}{\tref*} % \begin{macrocode} %RawTeX(' %<*package|ltxml> \newcommand\atrefi[3][]{\def\@test{#1}\ifx\@test\@empty\termref[name=#3]{#2}\else\termref[cd=#1,name=#3]{#2}\fi} \newcommand\atrefii[4][]{\atrefi[#1]{#2}{#3-#4}} \newcommand\atrefiii[5][]{\atrefi[#1]{#2}{#3-#4-#5}} % \end{macrocode} % \end{macro} % % \begin{macro}{\tref*} % \begin{macrocode} \newcommand{\trefi}[2][]{\atrefi[#1]{#2}{#2}} \newcommand{\trefii}[3][]{\atrefi[#1]{#2 #3}{#2-#3}} \newcommand{\trefiii}[4][]{\atrefi[#1]{#2 #3 #4}{#2-#3-#4}} % %'); % \end{macrocode} % \end{macro} % % Now we care about the configuration switches, they are set to sensible values, if they % are not defined already. These are just configuration parameters, which should not % appear in documents, therefore we do not provide {\latexml} bindings for them. % \begin{macro}{\*emph} % \begin{macrocode} %<*package> \providecommand{\termemph}[1]{#1} \providecommand{\defemph}[1]{{\textbf{#1}}} \providecommand{\stDMemph}[1]{{\textbf{#1}}} % % \end{macrocode} % \end{macro} % % \begin{macro}{\symref} % The |\symref| macros is quite simple, since we have done all the heavy lifting in the % |modules| package: we simply apply |\mod@symref@|\meta{arg1} to % \meta{arg2}. % \begin{macrocode} %<*package> \newcommand{\symref}[2]{\@nameuse{mod@symref@#1}{#2}} % %<*ltxml> DefConstructor('\symref{}{}', "" . "#2" .""); % % \end{macrocode} % \end{macro} % % \subsection{Providing IDs for {\omdoc} Elements}\label{sec:impl:ids} % % To provide default identifiers, we tag all {\omdoc} % elements that allow |xml:id| attributes by executing the |numberIt| procedure from |omdoc.sty.ltxml|. % % \begin{macrocode} %<*ltxml> Tag('omdoc:assertion',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:definition',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:example',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:requation',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:axiom',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:symbol',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:type',afterOpen=>\&numberIt,afterClose=>\&locateIt); Tag('omdoc:term',afterOpen=>\&numberIt,afterClose=>\&locateIt); % % \end{macrocode} % % \subsection{Deprecated Functionality}\label{sec:deprecated} % % In this section we centralize old interfaces that are only partially supported any % more. % \begin{macro}{\*def*} % \begin{macrocode} %RawTeX(' %<*package|ltxml> \newcommand\defin[2][]{\defi[#1]{#2}% \PackageWarning{statements}{\protect\defin\space is deprecated, use \protect\defi\space instead}} \newcommand\twindef[3][]{\defii[#1]{#2}{#3}% \PackageWarning{statements}{\protect\twindef\space is deprecated, use \protect\defii\space instead}} \newcommand\atwindef[4][]{\defiii[#1]{#2}{#3}{#4}% \PackageWarning{statements}{\protect\atwindef\space is deprecated, use \protect\defiii\space instead}} \newcommand\definalt[3][]{\adefi[#1]{#2}{#3}% \PackageWarning{statements}{\protect\definalt\space is deprecated, use \protect\adefi\space instead}} \newcommand\twindefalt[4][]{\adefii[#1]{#2}{#3}{#4}% \PackageWarning{statements}{\protect\twindefalt\space is deprecated, use \protect\adefii\space instead}} \newcommand\atwindefalt[5][]{\adefiii[#1]{#2}{#3}{#4}{#5}% \PackageWarning{statements}{\protect\atwindefalt\space is deprecated, use \protect\adefiii\space instead}} % \end{macrocode} % \end{macro} % % \begin{macro}{\*def*} % \begin{macrocode} \newcommand\twinref[3][]{\trefii[#1]{#2}{#3}% \PackageWarning{statements}{\protect\twinref\space is deprecated, use \protect\trefii\space instead}} \newcommand\atwinref[4][]{\atrefiii[#1]{#2}{#3}{#4}% \PackageWarning{statements}{\protect\atwindef\space is deprecated, use \protect\trefiii\space instead}} % %'); % \end{macrocode} % \end{macro} % % \subsection{Finale} % % Finally, we need to terminate the file with a success mark for perl. % \begin{macrocode} %1; % \end{macrocode} % % \Finale % \endinput % \iffalse % LocalWords: GPL structuresharing STR dtx keyval env envfalse idfalse idtrue % LocalWords: displayfalse envtrue displaytrue forfalse typefalse titlefalse % LocalWords: continuesfalse fortrue fromtrue typetrue titletrue CPERL omdoc % LocalWords: continuestrue symboldec omtext RequirePackage lowcase lc ToString % LocalWords: foreach hyperref href hlink DefEnvironment OptionalKeyVals ne % LocalWords: KeyVal xml CMP simpleDef PatternDef DefEnvironment PatternRule % LocalWords: requation PatternCMP RecDef DefConstructor keyvals defs psymbols % LocalWords: openElement symb closeElement ffor getValue attrs metadata undef % LocalWords: afterDigestBegin setProperty AssignValue afterDigest definiendum % LocalWords: cd addr LookupValue getArg toString idx idt definiendum ide idp % LocalWords: DefMacro args unlist inlinedef uri pdf afterOpen numberIt texttt % LocalWords: iffalse consymb ntheorem textbackslash symref def scsys sc sc kw % LocalWords: mathml openmath latexml activemath fileversion maketitle stex % LocalWords: setcounter tocdepth tableofcontents newpage sproofs ulsmf08 sref % LocalWords: MaySch eltte09 twintoo sref subsubsection exfig vspace vspace % LocalWords: noindent renewtheorem hline textbf textbf footnotesize ple peano % LocalWords: STaxiomEnv symdef medskip succ mathbb ldots stepcounter ednote % LocalWords: STtheoremAssEnv stepcounter STtheoremAssEnv stepcounter defin % LocalWords: STtheoremAssEnv notatiendum defin smomdl biblatex twindef cdbase % LocalWords: twindef atwindef atwindef adjectivized varaiants twindefalt cseq % LocalWords: twindefalt atwindefalt atwindefalt csymbol definalt termref emph % LocalWords: termref compactdesc KohAmb smmssl twinref atwinref newpart impl % LocalWords: termdef defemph defemph renewcommand termemph termenph stDMemph % LocalWords: stDMemph STpresent STpresent makeatletter STlemmaAssEnv textsf % LocalWords: STpropositionAssEnv STcorollaryAssEnv STconjectureAssEnv langle % LocalWords: STfalseconjectureAssEnv STpostulateAssEnv STobligationAssEnv foo % LocalWords: STassumptionAssEnv STobservationAssEnv STexampleEnv textsf ltxml % LocalWords: STdefinitionEnv STnotationEnv printbibliography langle ncname % LocalWords: theoremstyle sym newenvironment ifx csname endcsname % LocalWords: currentlabel theorembodyfont itshape theoremheaderfont bfseries % LocalWords: normalfont newtheorem upshape srefaddidkey % LocalWords: newcommand indef newif ifst indeffalse indeftrue attr whatsit % LocalWords: STdefinitionEnvKeyword notemph modulename ifundefined atwin % LocalWords: expandafter providecommand nameuse doctex ctancite funval %%% Local Variables: %%% mode: doctex %%% TeX-master: t %%% End: % \fi % LocalWords: funsymbs findnodes symbolnode defsref