% \iffalse meta-comment
% A LaTeX Class and Package for Semantic Cross-Referencing
% Copyright (c) 2009 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/sref/sref.dtx $
% \fi
%
% \iffalse
%<*package>
\NeedsTeXFormat{LaTeX2e}[1999/12/01]
\ProvidesPackage{sref}[2012/01/28 v1.0 Semantic Cross-References]
%
%<*driver>
\documentclass{ltxdoc}
\usepackage{url,array,float}
\usepackage[show]{ed}
\usepackage[hyperref=auto,style=alphabetic]{biblatex}
\bibliography{kwarc}
\usepackage{stex-logo,sref}
\usepackage{../ctansvn}
\usepackage{hyperref}
\usepackage[eso-foot,today]{svninfo}
\svnInfo $Id: sref.dtx 1999 2012-01-28 07:32:11Z kohlhase $
\svnKeyword $HeadURL: https://svn.kwarc.info/repos/stex/trunk/sty/sref/sref.dtx $
\makeindex
\floatstyle{boxed}
\newfloat{exfig}{thp}{lop}
\floatname{exfig}{Example}
\newcommand\tracissue[1]{\cite{sTeX:online}, \hyperlink{http://trac.kwarc.info/sTeX/ticket/#1}{issue #1}}
\begin{document}\DocInput{sref.dtx}\end{document}
%
% \fi
%
%\CheckSum{316}
%
% \changes{v0.5}{2008/03/28}{split off from omdoc.sty}
% \changes{v0.6}{2009/12/07}{introducing sequation}
% \changes{v0.9}{2009/07/14}{using omd for metadata}
% \changes{v1.0}{2011/12/20}{adding \texttt{\textbackslash sreflabel}}
%
% \GetFileInfo{sref.sty}
%
% \MakeShortVerb{\|}
%
% \def\omdoc{OMDoc}
% \def\latexml{{\LaTeX}ML}
% \title{{\texttt{sref.sty}}: Semantic Cross-Referencing in {\LaTeX}\thanks{Version {\fileversion} (last revised
% {\filedate})}}
% \author{Michael Kohlhase\\
% Jacobs University, Bremen\\
% \url{http://kwarc.info/kohlhase}}
% \maketitle
%
% \begin{abstract}
% The |sref| 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).
%
% The |sref| package supplies an for semantic cross-referencing over multiple documents.
% \end{abstract}
%
%\tableofcontents\newpage
%
% \section{Introduction}\label{sec:intro}
%
% The automatic computation of cross-references is one of the traditional strong points of
% {\LaTeX}. However, cross-referencing is limited to labels in the current document
% only. Cross-referencing between multiple documents in a jointly developed document
% collection is not easy to achieve in the {\LaTeX} processing model, which reads files
% sequentially and lacks a path concept.
%
% The |sref| package is mainly aimed at package developers. It supplies the internal
% macros that can be used to make document structuring elements cross-referencable. The
% general strategy here is to equip the document structuring macros with an
% \DescribeMacro{id}|id| key, so that the author can specify meaningful ones, but to let
% the transformation give default ones if the author did not. The value of the |id| key
% can also be used for cross-referencing like the |\label|/|\ref| mechanism in
% {\LaTeX}. We implement an independent referencing mechanism, since the referencing model
% is geared more towards referencing text fragments than text fragment labels like section
% numbers. Therefore we let the referenced fragments define the reference text much like
% the |\autoref| macro from |\hpyerref|.
%
% \section{The User Interface}\label{sec:user}
%
% This package is currently mainly meaningful in the context of the {\sTeX} collection,
% since all cross-referencable macros and environments must be extended to know about their
% referencing mechanism. We explain the user interface in \sref{sucrossref}. To
% port the functionality to other {\LaTeX} classes and packages, they have to be upgraded
% via the API in \sref{supackage-authors}.
%
% \subsection{Package Options}\label{sec:user:options}
%
% The |sref| package has the \DescribeMacro{extrefs}|extrefs| package option, which can be
% set to activate multifile support (see \sref{suinterdoc}). If the
% \DescribeMacro{showmeta}|showmeta| is set, then the metadata keys are shown
% (see~\cite{Kohlhase:metakeys:ctan} for details and customization options).
%
% \subsection{Cross-Referencing}\sreflabel{Section}{sucrossref}
%
% The \DescribeMacro{\sref}|\sref{|\meta{id}|}| macro is the main cross-referencing macro,
% see Figure~\ref{fig:mysection} for an example. Depending on the whether macro or
% environment marking up the respective document fragment carries the key/value pair
% |id=|\meta{id} the cross-reference will expand to ``Section 2.1'' or ``this remark'',
% both carrying hyper-references. The |\sref| macro takes an optional argument that allows
% to specify a link text that overrides the auto-generated one.
%
% \begin{exfig}
% \begin{verbatim}
% \mysection[id=foo]{#2}
% ... \sref{foo} ...
% \end{verbatim}
% \vspace*{-1.5em}
% \caption{Semantic Crossreferencing}\label{fig:mysection}
% \end{exfig}
%
% The \DescribeMacro{\sreflabel}|\sreflabel|\footnote{It would have been more natural to
% name the macro \texttt{slabel}, but this is overwritten by other packages without
% warning.} macro is a variant to the |\label| macro provided by {\LaTeX} proper. It takes
% two arguments, the first one is a classification (used in |\sref|) and the second one
% the identifier.
%
% The
% \DescribeMacro{\srefs}|\srefl{|\meta{id\textsuperscript{1}}|}{|\meta{id\textsuperscript{2}}|}|
% is a variant it |\sref|, only that it allows to reference two semantic objects and
% expands to ``\meta{reference\textsuperscript{1}} and
% \meta{reference\textsuperscript{2}}''. \DescribeMacro{\srefl}|\srefl{|\meta{id\textsuperscript{1}}|}{|\meta{id\textsuperscript{n}}|}|
% is similar, but for ranges; it expands to ``\meta{reference\textsuperscript{1}} to
% \meta{reference\textsuperscript{n}}''. Its use should be restricted to cases, where the
% types of objects references are homogenous.
%
% Finally, there is a variant \DescribeMacro{\spageref}|\spageref| that only outputs the
% page number of the referenced object. It can be used in cases where no hyper-referencing
% is present. It uses the macro \DescribeMacro{\sref@page@label}|\sref@page@label| for
% styling the page reference. Redefining this will allows to customize this. The default
% setting is
% \begin{verbatim}
% \newcommand{\sref@page@label}[1]{p.~{#1}}
% \end{verbatim}
%
% \subsection{An API for Package Authors}\sreflabel{Section}{supackage-authors}
%
% To make use of the |sref| package, the package must define the document structuring
% infrastructure using the |sref| internal macros. The {\sTeX} packages already does this,
% so we make an example here for a slightly upgraded sectioning command in
% Figure~\ref{fig:mysection:setup}. The first three lines define the keys for the keyval
% attribute of the |\mysection| command using the infrastructure supplied by the |omd|
% package~\ctancite{Kohlhase:metakeys} (remember the |\RequirePackage{metakeys}|). The first two just
% initialize the keys to save the key values in internal macros, and the |\metasetkeys|
% activates the keys when reading the keyval argument. The
% \DescribeMacro{\srefaddidkey}|\srefaddidkey| macro is a variant of |\addmetakey| macro
% supplied by the |sref| package that sets up the keys to set the
% \DescribeMacro{\sref@id}|\sref@id| register for later use by the |sref|
% infrastructure. Note that the |\srefaddidkey| macro uses the |prefix| key to
% systematically construct prefixed identifiers. This can be useful in particular for
% sectioning commands.
%
% \begin{exfig}
% \begin{verbatim}
% \addmetakey{sec}{short}
% \addmetakey[black]{sec}{color}
% \srefaddidkey[prefix=sec.]{sec}
% \newcommand{\mysection}[2][]{\metasetkeys{#1}\sref@target\color{\sec@color}
% \section[\sec@short]{#2}\sref@label@id{Section \thesection}}
% \end{verbatim}
% \vspace*{-1.5em}
% \caption{A slightly upgraded sectioning command}\label{fig:mysection:setup}
% \end{exfig}
%
% In this situation, the |\mysection| macro processes the optional argument with
% |\metasetkeys| and then sets the color of the section. The
% \DescribeMacro{\sref@target}|\sref@target| sets up the hypertarget for the |hyperref|
% package to use. Then we use the regular |\section| command, and we use the
% \DescribeMacro{\sref@label@id}|\sref@label@id| macro to define the label that the
% |\sref| macro will use for cross-referencing.
%
% Note that the use of the straight use of the label ``Section'', which will be written
% into the auxiliary files is bad practice since it is not configurable. It would be much
% better to make it configurable via a presentation macro like |\my@section@label| in
% Figure~\ref{fig:mysection:configurable}. Then translators or even the user could redefine
% the |\my@section@label| to adapt them to their needs.
%
% \begin{exfig}
% \begin{verbatim}
% \newcommand{\my@section@label}[1]{Section~{#1}}
% \newcommand{\mysection}[2][]{\metasetkeys{#1}\sref@target\color{\sec@color}
% \section[\sec@short]{#2}\sref@label@id{\my@section@label\thesection}}
% \end{verbatim}
% \vspace*{-1.5em}
% \caption{A Sectioning Command with Configurable Label}\label{fig:mysection:configurable}
% \end{exfig}
%
% \subsection{Inter-Document Cross-Referencing}\sreflabel{Section}{suinterdoc}
%
% |sref.sty| provides inter-document cross-referencing. The use case is simple: we want to
% have a document collection (e.g. a book with conference proceedings), but also want to
% be able format the individual documents separately, and still have meaningful
% cross-references. To show off the possibilities, let us assume that we have a book with
% two separate papers, which we put into separate directories |idc| and |scr| to minimize
% interference between the authors Jane Doe and John Bull. To achieve this, we would set
% up paper driver files |main.tex| like the one in Figure~\ref{fig:paper-driver} in the
% two directories. These use the \DescribeMacro{\makeextrefs}|\makeextrefs| macro, which
% causes the |sref| package to generate a {\emph{external references file}}
% |main.refs|. Note that the |\makeextrefs| macros reads the previous |main.refs| file so
% that forward-referencing is possible (in the pass after a reference was labeled).
%
% \begin{exfig}
% \begin{verbatim}
% \documentclass{article}
% \usepackage[extrefs]{sref}
% \makeextrefs{idc}
% \inputrefs{scr}{../scr/main}
% \extrefstyle{scr}{\cite[\protect{\theextref}]{Doe09}}
% \title{Inter-Document Crossreferencing}
% \author{John Bull\\...}
% \begin{document}\maketitle\input{paper}\end{document}
% \end{verbatim}
% \vspace*{-2em}
% \caption{A document driver {\texttt{idc/main.tex}} for a paper}\label{fig:paper-driver}
% \end{exfig}
%
% The external references file can be read by other documents; in
% Figure~\ref{fig:paper-driver}, we read the references file of Jane Doe's paper via the
% \DescribeMacro{\inputrefs}|\inputrefs| macro. This allows John Bull to use\footnote{Note
% that the external references file is updated every time {\LaTeX} is run, so that
% references may be off by one version.} references like
% \DescribeMacro{\extref}|\extref{scr}{foo}| to reference document fragments in Jane Doe's
% paper she has labeled with the {\emph{reference prefix}} |\sreflabel{foo}| (assuming that
% she has added |\makeextrefs{scr}| in the preamble of her paper). Note that just as the
% |\sref| macro |\extref| takes an optional first argument that allows to specify the link
% text. Here, John Bull uses the \DescribeMacro{\extrefstyle}|\extrefstyle| macro to
% specify how the externa references are to be formatted, in this case he decided to use a
% {\LaTeX} citation. Generally, first argument of the |\extrefstyle| macro is the
% reference prefix which should be configured, and the second is the format, where the
% \DescribeMacro{\theextref}|\theextref| macro expands to the cross-reference. In this
% case, John chose to use a bib{\TeX} citation (he has an entry |Doe09| in his database)
% for the reference to the external paper.
%
% As the content of the respective paper is input from a file |paper.tex| in the
% individual papers, we can re-use these in the book. To do this we set up a book driver
% file like the one in Figure~\ref{fig:book-driver}. This one does not use the |extrefs|
% option, so the references are written to the |.aux| file. Furthermore |\extref| is
% redefined to act like |\sref| disregarding the first required argument. Thus all
% references work like they should.
% \begin{exfig}
% \begin{verbatim}
% \documentclass{book}
% \usepackage{sref}
% \title{Cross-Referencing in {\LaTeX}}
% \author{Elder Reseacher}
% \begin{document}
% \maketitle
% \chapter{Semantic Crossreferencing (Jane Doe, ...)}
% \input{scr/paper}\newpage
% ...
% \chapter{Inter-Document Crossreferencing (John Bull, ...)}
% \input{idc/paper}\newpage
% \end{document}
% \end{verbatim}
% \vspace*{-2em}
% \caption{A document driver for the book assembling the papers}\label{fig:book-driver}
% \end{exfig}
%
% This example has been carried through (without the separation of chapters in to
% subdirectories) in the files accompanying the source distribution of the |sref|
% package. They are used for testing the package.
%
% \subsection{Semantic Versions of Commonly used Referencing Commands}\label{sec:user:common}
%
% The |sref| package defines semantically referencable versions of commonly used {\LaTeX}
% environments and command sequences.\footnote{This section will be extended by need, so
% if you miss some semantic environment, please contact the package author, or (better)
% file an issue at~\cite{sTeX:online})}
%
% The \DescribeEnv{sequation}|sequation| environment takes an optional key/value argument
% that allows to specify an identifier and unifies the behavior of the |equation| (if an
% |id| key is given) and |displaymath| (else) environments. So the markup
% \begin{exfig}
% \begin{verbatim}
% A semantic equation with id
% \begin{sequation}[id=foo]
% e^{mc}=-1
% \end{sequation}
% and another one without id
% \begin{sequation}
% e^{mc}=-1
% \end{sequation}
% now, we reference the first equation: {\sref{foo}}
% \end{verbatim}
% \vspace*{-1.5em}\hrule
% yields the result:\hrule
% A semantic equation with id
% \begin{sequation}[id=foo]
% e^{mc}=-1
% \end{sequation}
% and another one without id
% \begin{sequation}
% e^{mc}=-1
% \end{sequation}
% now, we reference the first equation: {\sref{foo}}
% \caption{Semantic Equation}\label{fig:sequation}
% \end{exfig}
%
% \subsection{Semantic Citations}\label{sec:user:citations}
%
% \withcite{Patashnik:b88}{bib\TeX} and \withcite{Lehmann:biblatex10}{bib\LaTeX} provide a
% semi-semantic way of referencing literature. If we look at the
% \begin{withcitation}{LasSwi:rdf99}
% current practice of citing from an RDF standpoint~\citeit which views links as
% subject/predicate/object triples,
% \end{withcitation}
% then the treatment of the predicate and object are semantic, but the subject is hinted
% at by mere juxtaposition in the text. The |sref| package helps out here via the
% \DescribeMacro{\withcite} macro for short subjects (in the second argument) that are
% postfixed by the citation (key in the first argument). For instance the occurrence at
% the beginning of this paragraph was created by
% \begin{verbatim}
% \withcite{Patashnik:b88}{bib\TeX}
% \end{verbatim}
% The general case is covered by the \DescribeEnv{withcitation}|withcitation| environment
% for long subjects. In the latter, the citation can be placed by the
% \DescribeMacro{\citeit}. For instance, the second sentence was marked up as
% \begin{verbatim}
% If we look at the
% \begin{withcitation}{LasSwi:rdf99}
% current practice of citing from an RDF standpoint which views links as
% subject/predicate/object triples,
% \end{withcitation}
% then the treatment of the predicate ...
% \end{verbatim}
% The advantage of this treatment is that the meaning of the reference is fully marked up
% and can be taken advantage of in the \omdoc transformation, from which RDF triples can
% then be harvested for a linked open data treatment.
%
% \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}
% \newpage
%
% \section{Implementation}\label{sec:impl}
%
% The |sref| 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.
%
% We first set up header information for the {\latexml} binding file.
% \begin{macrocode}
%<*ltxml>
package LaTeXML::Package::Pool;
use strict;
use LaTeXML::Package;
%
% \end{macrocode}
%
% \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).\ednote{need an implementation for {\latexml}}
%
% \begin{macrocode}
%<*package>
\DeclareOption{showmeta}{\PassOptionsToPackage{\CurrentOption}{metakeys}}
\newif\ifextrefs\extrefsfalse
\DeclareOption{extrefs}{\extrefstrue}
\ProcessOptions
%
%<*ltxml>
DeclareOption('extrefs','');
%
% \end{macrocode}
%
% Then we need to set up the packages by requiring the |metakeys| package~\ctancite{Kohlhase:metakeys}
% to be loaded (in the right version).
%
% \begin{macrocode}
%<*package>
\RequirePackage{metakeys}
%
%RequirePackage('metakeys');
% \end{macrocode}
%
% \subsection{Crossreferencing}\label{sec:impl:crossref}
%
% The following user-level macros just use the |\sref@hlink| macros in various ways for
% internal referencing.\ednote{they need implementation in LaTeXML, the ones here only are
% stubs to make the error messages shut up.}
%
% \begin{macro}{\sref}
% \begin{macrocode}
%<*package>
\newcommand{\sref}[2][]{%
\@ifundefined{sref@part}{\sref@hlink[#1]{#2}}{\sref@hlink[#1]{\sref@part @#2}}}
%
%<*ltxml>
sub withhash {'#';}
DefConstructor('\sref[]{}',
"");
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\srefs}
% \begin{macrocode}
%<*package>
\newcommand{\srefs}[3][]{%
\def\@test{#1}\ifx\@test\@empty\sref{#2} and \sref{#3}\else #1\fi}
%
%<*ltxml>
DefConstructor('\srefs[]{}',
"");
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\srefl}
% \begin{macrocode}
%<*package>
\newcommand{\srefl}[3][]{%
\def\@test{#1}\ifx\@test\@empty\sref{#2} to \sref{#3}\else #1\fi}
%
%<*ltxml>
DefConstructor('\srefl[]{}',
"");
%
% \end{macrocode}
% \end{macro}
% \ednote{it is not clear what we want in the LaTeXML implementation of spageref}
% \begin{macro}{\spageref}
% \begin{macrocode}
%<*package>
\newcommand{\spageref}[1]{%
\@ifundefined{sref@part}{\sref@pageref{#1}}{\sref@pageref{\sref@part @#1}}}
%
%<*ltxml>
DefConstructor('\spageref{}',
"");
%
% \end{macrocode}
% \end{macro}
%
% \subsection{An API for Package Authors}\label{sec:impl:package-authors}
%
% We find out whether the |hyperref| package is loaded, since we may want to use it for
% cross-references, for which we set up some internal macros that gracefully degrade if
% |hyperref| is not loaded.
%
% \begin{macro}{\sref@*@ifh}
% \begin{macrocode}
%<*package>
\newif\ifhref\hreffalse
\AtBeginDocument{\@ifpackageloaded{hyperref}{\hreftrue}{\hreffalse}}
\newcommand\sref@href@ifh[2]{\ifhref\href{#1}{#2}\else#2\fi}
\newcommand\sref@hlink@ifh[2]{\ifhref\hyperlink{#1}{#2}\else#2\fi}
\newcommand\sref@target@ifh[2]{\ifhref\hypertarget{#1}{#2}\else#2\fi}
% \end{macrocode}
% \end{macro}
%
% Then we provide some macros for {\sTeX}-specific crossreferencing
%
% \begin{macro}{\sref@target}
% The next macro uses this and makes an target from the current |sref@id| declared by
% a |id| key.
% \begin{macrocode}
\def\sref@target%
{\ifx\sref@id\@empty\else%
\edef\@target{sref@\@ifundefined{sref@part}{}{\sref@part @}\sref@id @target}
\sref@target@ifh\@target{}\fi}
% \end{macrocode}
% \end{macro}
%
% The next two macros are used for setting labels, it is mainly used for enabling forward
% references, to do this, it is written into \meta{jobname}|.aux| or \meta{jobname}|.refs|.
%
% \begin{macro}{\@sref@def}
% This macro stores the value of its last argument in a custom macro for reference.
% \begin{macrocode}
\newcommand\@sref@def[3]{\expandafter\gdef\csname sref@#1@#2\endcsname{#3}}
% \end{macrocode}
% \end{macro}
%
% The next step is to set up a file to which the references are written, this is normally
% the |.aux| file, but if the |extref| option is set, we have to use an |.ref| file.
% \begin{macrocode}
\ifextrefs\newwrite\refs@file\else\def\refs@file{\@auxout}\fi
% \end{macrocode}
%
% \begin{macro}{\sref@def}
% This macro writes an |\@sref@def| command to the current aux file and also executes it.
% \begin{macrocode}
\newcommand\sref@def[3]{%\@sref@def{#1}{#2}{#3}%
\protected@write\refs@file{}{\string\@sref@def{#1}{#2}{#3}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\srefaddidkey}
% |\srefaddidkey[|\meta{keyval}|]{|\meta{group}|}| extends the metadata keys of the
% group \meta{group} with an |id| key. In the optional key/value pairs in \meta{keyval}
% the |prefix| key can be used to specify a prefix. Note that the |id| key defined by
% |\srefaddidkey[|\meta{keyval}|]{|\meta{group}|}| not only defines |\sref@id|, which is
% used for referencing by the |sref| package, but also |\|\meta{group}|@id|, which is
% used for showing metadata via the |showmeta| option of the |metakeys| package.
% \begin{macrocode}
\addmetakey{srefaddidkey}{prefix}
\newcommand\srefaddidkey[2][]{\metasetkeys{srefaddidkey}{#1}%
\@metakeys@ext@clear@keys{#2}{sref@id}{}% id cannot have a default
\metakeys@ext@clear@keys{#2}{id}{}%
\metakeys@ext@showkeys{#2}{id}%
\define@key{#2}{id}{\edef\sref@id{\srefaddidkey@prefix ##1}%
\expandafter\edef\csname #2@id\endcsname{\srefaddidkey@prefix ##1}}}
%
% \end{macrocode}
% \end{macro}
%
% \subsection{Inter-Document Crossreferencing}\label{sec:impl:interdoc}
%
% \begin{macro}{\makeextrefs}
% \begin{macrocode}
%<*package>
\newcommand\makeextrefs[1]{\gdef\sref@part{#1}%
\makeatletter
\IfFileExists{\jobname.refs}{\input{\jobname.refs}}{}%
\immediate\openout\refs@file=\jobname.refs
\makeatother}
%
%DefConstructor('\makeextrefs{}','');
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sref@label}
% The |\sref@label| macro writes a label definition to the auxfile.
% \begin{macrocode}
%<*package>
\newcommand\sref@label[2]{%
\sref@def{\@ifundefined{sref@part}{}{\sref@part @}#2}{page}{\thepage}%
\sref@def{\@ifundefined{sref@part}{}{\sref@part @}#2}{label}{#1}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sreflabel}
% The |\sreflabel| macro is a semantic version of |\label|, it combines the categorization
% given in the first argument with {\LaTeX}'s |\@currentlabel|.
% \begin{macrocode}
%<*package>
\newcommand\sreflabel[2]{\message{sreflabel: #1, #2}\sref@label{#1 \@currentlabel}{#2}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sref@label@id}
% The |\sref@label@id| writes a label definition for the current |\sref@id| if it is
% defined.
% \begin{macrocode}
%<*package>
\newcommand\sref@label@id[1]{\ifx\sref@id\@empty\else\sref@label{#1}{\sref@id}\fi}
%
% \end{macrocode}
% \end{macro}
%
% Finally we come to the user visible macro |\sref| which is used for
% referencing.\ednote{The {\latexml} does not take into account the optional argument
% yet.}
%
% \begin{macro}{\sref@hlink}
% |\sref@hlink[|\meta{alt}|]{|\meta{label}|}|creates an error message if the target
% specified by \meta{label} is not defined, and otherwise generates a hyperlinked
% reference whose link text is \meta{alt} (if the optional argument is given) and the
% label generated by object specified by \meta{label} otherwise.
% \begin{macrocode}
%<*package>
\newcommand{\sref@hlink}[2][]{\def\@test{#1}%
\@ifundefined{sref@#2@label}%
{\protect\G@refundefinedtrue\@latex@warning{reference #2 undefined}??}%
{\sref@hlink@ifh{sref@#2@target}{\ifx\@test\@empty\@nameuse{sref@#2@label}\else #1\fi}}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sref@page@label}
% This macro styles a page reference.
% \begin{macrocode}
%<*package>
\newcommand{\sref@page@label}[1]{p.~{#1}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sref@pageref}
% The next macro creates an error message if the target is not defined, and otherwise
% generates a page reference.
% \begin{macrocode}
%<*package>
\newcommand{\sref@pageref}[1]{\@ifundefined{sref@#1@page}%
{\protect\G@refundefinedtrue\@latex@warning{reference #1 undefined}\sref@page@label{??}}%
{\sref@hlink@ifh{sref@#1@target}{\sref@page@label{\@nameuse{sref@#1@page}}}}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\sref@href}
% The next macro creates an error message if the target is not defined, and otherwise
% generates a hyperlinked reference.
% \begin{macrocode}
%<*package>
\newcommand{\sref@href}[3][]{\def\@test{#1}%
\@ifundefined{sref@#2@label}%
{\protect\G@refundefinedtrue\@latex@warning{reference #2 undefined}??}%
{\@ifundefined{sref@#3@URI}%
{\protect\G@refundefinedtrue\@latex@warning{external refs of type #3 undefined}??}%
{\edef\@uri{\@nameuse{sref@#3@URI}.pdf\#sref@#2@target}
\edef\@label{\ifx\@test\@empty\@nameuse{sref@#2@label}\else #1\fi}
\sref@href@ifh\@uri\@label}}}
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\extref}
% The next macros use |\sref@hlink| with the respective prefix for external referencing
% if external references are used as indicated by the |extrefs| option; otherwise it
% disregards the first required macro and uses internal referencing.\ednote{This needs
% to be implemented on the LaTeXML side.}
% \begin{macrocode}
%<*package>
\ifextrefs
\newcommand{\extref}[3][]{\def\theextref{\sref@href[#1]{#2@#3}{#2}}%
\csname doextref@#2\endcsname}
\else
\newcommand{\extref}[3][]{\sref[#1]{#3}}
\fi
%
%<*ltxml>
DefConstructor('\extref[]{}{}',
"");
DefConstructor('\theextref','');
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\extpageref}
% The next macros use |\sref@hlink| with the respective prefix for external referencing
% if external references are used as indicated by the |extrefs| option; otherwise it
% disregards the first required macro and uses internal referencing.\ednote{This needs
% to be implemented on the LaTeXML side.}
% \begin{macrocode}
%<*package>
\ifextrefs
\newcommand{\extpageref}[3][]{\def\theextref{\sref@pageref[#1]{#2@#3}{#2}}%
\csname doextpageref@#2\endcsname}
\else
\newcommand{\extpageref}[3][]{\spageref[#1]{#3}}
\fi
%
%<*ltxml>
DefConstructor('\extpageref[]{}{}',
"");
DefConstructor('\theextref','');
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\extrefstyle}
% This user macro defines an internal macro that is used for internal styling; for
% instance |\extrefstyle{foo}{\theextref in bar}| defines the macro |\doextref@foo|
% which evaluates to \meta{the reference} |in bar|. This is used in the |\extref| macro.
% \begin{macrocode}
%<*package>
\newcommand\extrefstyle[2]{\expandafter\gdef\csname doextref@#1\endcsname{#2}}
%
%<*ltxml>
DefConstructor('\extrefstyle{}{}',"");
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\extpagerefstyle}
% This is analogous to |\extrefstyle|
% \begin{macrocode}
%<*package>
\newcommand\extpagerefstyle[2]{\expandafter\gdef\csname doextpageref@#1\endcsname{#2}}
%
%<*ltxml>
DefConstructor('\extrefstyle{}{}',"");
%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\inputrefs}
% If the external references file exists, it is read (under the protection of
% |\makeatother|) otherwise an error message is displayed.
% \begin{macrocode}
%<*package>
\newcommand{\inputrefs}[2]{%
\@namedef{sref@#1@URI}{#2}
\makeatletter%
\IfFileExists{#2.refs}{\input{#2.refs}}
{\PackageError{sref}{Reference file #1.refs does not exist}
{Maybe you have to run LaTeX on #2.tex first}}
\makeatother}
%
%<*ltxml>
DefConstructor('\inputrefs{}{}','');
%
% \end{macrocode}
% \end{macro}
%
% \subsection{Semantic Versions of Commonly used Referencing Commands}\label{sec:impl:common}
%
% \begin{environment}{sequation}
% \begin{macrocode}
%<*package>
\srefaddidkey{sequation}
\def\sref@sequation@heading{equation}
\newenvironment{sequation}[1][]{\metasetkeys{sequation}{#1}%
\ifx\sref@id\@empty\begin{displaymath}\else% no id, using equation*
\begin{equation}\sref@target\sref@label@id{\sref@sequation@heading~(\theequation)}\fi}
{\ifx\sref@id\@empty\end{displaymath}\else\end{equation}\fi}
%
%<*ltxml>
DefEnvironment('{sequation} OptionalKeyVals',
""
. ""
. "#body"
. ""
. "",
mode=>'display_math',
properties=> sub { RefStepCounter('equation') },
locked=>1);
%
% \end{macrocode}
% \end{environment}
%
% \begin{environment}{seqnarray}
% \begin{macrocode}
%<*package>
\newenvironment{seqnarray}[1][]%
{\metasetkeys{sequation}{#1}\begin{eqnarray*}\sref@target%
\sref@label@id{\sref@sequation@heading~(\theequation)}}
{\end{eqnarray*}}
%
%<*ltxml>
DefMacro('\seqnarray OptionalKeyVals','\begin{eqnarray*}');
DefMacro('\endseqnarray','\end{eqnarray*}');
%
% \end{macrocode}
% \end{environment}
%
% \subsection{Semantic Citations}\label{sec:impl:citations}
%
% \begin{macro}{withcite}
% \begin{macrocode}
%<*package>
\newcommand\withcite[2]{#2~\cite{#1}}
%
%<*ltxml>
DefMacro('\withcite{}{}','\begin{withcitation}{#1}#2\citeit\end{withcitation}');
%
% \end{macrocode}
% \end{macro}
%
% \begin{environment}{withcitation}
% \begin{macrocode}
%<*package>
\newenvironment{withcitation}[1]{\def\citeit{\cite{#1}}}{}
%
%<*ltxml>
DefConstructor('\citeit'," ",
afterConstruct => sub {
my ($document,$whatsit) = @_;
# LibXML acrobatics, since we can't talk about the xml:id prior to construction's end
# (and please do correct me if this is inaccurate)
my $node = $document->getNode;
my ($citenode) = $document->findnodes('preceding-sibling::omdoc:citation',$node);
my ($phrase_parent) = $document->findnodes('ancestor::ltx:text[@xml:id]',$node);
return unless (defined $phrase_parent) && (defined $citenode);
my $id = $phrase_parent->getAttribute('xml:id');
my $refs = $phrase_parent->getAttribute('citeit-refs');
$phrase_parent->removeAttribute('citeit-refs');
$citenode->setAttribute('for',$id);
$citenode->setAttribute('refs',$refs);
});#$
DefEnvironment('{withcitation}{}',
"#body");
%
% \end{macrocode}
% \end{environment}
%
% \subsection{Finale}\label{sec:common}
%
% Finally, we need to terminate the file with a success mark for perl.
% \begin{macrocode}
%<*ltxml>
1;
%
% \end{macrocode}
% \Finale
\endinput
% \iffalse
%%% Local Variables:
%%% mode: doctex
%%% TeX-master: t
%%% End:
% \fi
% LocalWords: GPL structuresharing STR omdoc dtx stex CPERL LoadClass url dc
% LocalWords: RequirePackage RegisterNamespace namespace xsl DocType ltxml dtd
% LocalWords: ltx DefEnvironment beforeDigest AssignValue inPreamble getGullet
% LocalWords: afterDigest keyval omgroup DefKeyVal Semiverbatim KeyVal iffalse
% LocalWords: OptionalKeyVals DefParameterType IfBeginFollows skipSpaces CMP
% LocalWords: ifNext DefMacro needwrapper unlist DefConstructor omtext bgroup
% LocalWords: useCMPItemizations RefStepItemCounter egroup beginItemize li di
% LocalWords: beforeDigestEnd useTheoryItemizations dt autoclose ul ol dl env
% LocalWords: afterOpen LastSeenCMP autoClose proto ToString textsuperscript
% LocalWords: addAttribute nlex nlcex omdocColorMacro args tok MergeFont qw
% LocalWords: TokenizeInternal toString isMath foreach maybeCloseElement id'd
% LocalWords: autoOpen minipage footnotesize scriptsize numberIt whatsit href
% LocalWords: getAttribute setAttribute OMDoc RelaxNGSchema noindex xml lec
% LocalWords: Subsubsection useDefaultItemizations refundefinedtrue blockquote
% LocalWords: DefCMPConstructor inlinequote idx idt ide idp emph sref extrefs
% LocalWords: flushleft flushright DeclareOption hyperref LaTeX tex pdf hlink
% LocalWords: sequation omd def texorpdfstring raisebox latexml texttt newpage
% LocalWords: fileversion maketitle tableofcontents autoref hpyerref mysection
% LocalWords: exfig vspacesrefaddidkey srefaddidkey scr vspace withcite LasSwi
% LocalWords: makeextrefs inputrefs extref foo Patashnik withcite biblatex10
% LocalWords: extrefstyle theextref theextref displaymath hrule impl ednote
% LocalWords: printbibliography newif ifextrefs extrefsfalse extrefstrue srefs
% LocalWords: Crossreferencing newcommand ifundefined ifx srefl xref ifh gdef
% LocalWords: ifhref hreffalse ifpackageloaded hreftrue expandafter jobname
% LocalWords: jobname csname endcsname newwrite auxout makeatletter openout
% LocalWords: makeatother auxfile nameuse doextref namedef newenvironment
% LocalWords: theequation refnum refnum seqnarray eqnarray endseqnarray doctex
% LocalWords: textsuperscript spageref spageref thepage pageref ctancite rdf99
% LocalWords: cross-referencable showmeta showmeta metakeys metasetkeys textsf
% LocalWords: addmetakey referencable langle textsf langle withcitation citeit
% LocalWords: compactenum