% \iffalse meta-comment % % % COPYRIGHT NOTICE AND LICENSE % % % COPYRIGHT % ========= % % Copyright Gianfranco Boggio-Togna 2006 % % % DEFINITIONS % =========== % % In this document the following terms are used: % % `Work' % The files TEXNIKA.dtx, poetry.dtx, drama.dtx, technica.ins and % the derived files TEXNIKA.sty, poetry.sty, drama.sty % % 'Copyright Holder' % Gianfranco Boggio-Togna % % `Derived Work' % Any work that under any applicable law is derived from the Work. % % `Modification' % Any procedure that produces a Derived Work under any applicable % law -- for example, the production of a file containing an % original file associated with the Work or a significant portion of % such a file, either verbatim or with modifications and/or % translated into another language. % % `Modify' % To apply any procedure that produces a Derived Work under any % applicable law. % % `Distribution' % Making copies of the Work available from one person to another, in % whole or in part. Distribution includes (but is not limited to) % making any electronic components of the Work accessible by % file transfer protocols such as FTP or HTTP or by shared file % systems such as Sun's Network File System (NFS). % % % CONDITIONS ON DISTRIBUTION AND MODIFICATION % =========================================== % % 1. You may distribute a complete, unmodified copy of the Work as you % received it. Distribution of only part of the Work is considered % modification of the Work, and no right to distribute such a Derived % Work may be assumed under the terms of this clause. % % 2. The Copyright Holder may, without restriction, modify the Work, % thus creating a Derived Work. The Copyright Holder may also distribute % the Derived Work without restriction. Derived Works distributed in % this manner by the Copyright Holder are considered to be updated % versions of the Work. % % 3. If you are not the Copyright Holder, you are not allowed % to modify the Work. % % 4. The conditions above are not intended to prohibit, and hence do % not apply to, the modification, by any method, of any component so that it % becomes identical to an updated version of that component of the Work as % it is distributed by the Copyright Holder under Clause 2, above. % % 5. Distribution of the Work in an alternative format, where the Work % is then produced by applying some process to that format, does not % relax or nullify any sections of this license as they pertain to the % results of applying that process. % % 6. This license places no restrictions on works that are unrelated to % the Work, nor does this license place any restrictions on aggregating % such works with the Work by any means. % % 7. Nothing in this license is intended to, or may be used to, prevent % complete compliance by all parties with all applicable laws. % % % CONDITIONS ON USE % ================= % % The Work may be used without charge for non-commercial private % or academic purposes. Use of the Work for commercial purposes is % prohibited. To use the Work for commercial purposes you must obtain a % license for commercial use from the Copyright Holder. % % % NO WARRANTY % =========== % % There is no warranty for the Work. Except when otherwise stated in % writing, the Copyright Holder provides the Work `as is', without % warranty of any kind, either expressed or implied, including, but not % limited to, the implied warranties of merchantability and fitness for % a particular purpose. The entire risk as to the quality and performance % of the Work is with you. Should the Work prove defective, you % assume the cost of all necessary servicing, repair, or correction. % % In no event unless agreed to in writing will the Copyright Holder or % any other party who may distribute the Work as permitted above, be % liable to you for damages, including any general, special, incidental % or consequential damages arising out of any use of the Work or out % of inability to use the Work (including, but not limited to, loss of % data, data being rendered inaccurate, or losses sustained by anyone % as a result of any failure of the Work to operate with any other % programs), even if the Copyright Holder or said other party has been % advised of the possibility of such damages. % %<*driver> \documentclass{ltxdoc} \setlength{\parindent}{0pt} \setlength{\textwidth}{5.5in} \setlength{\textheight}{8.5in} \setlength{\parskip}{\smallskipamount} \usepackage[ibycus,english]{babel} \usepackage[pagestyles]{titlesec} \newpagestyle {POETRY@page} { \sethead {} {\large {\itshape The} \texttt{poetry} {\itshape package}} {\textup{\thepage}} \setfoot {} {Copyright \copyright\ Gianfranco Boggio--Togna 2006} {}% \setmarks {section}{subsection} } \MakeShortVerb{|} \AlsoImplementation \begin{document} \DocInput{poetry.dtx} \end{document} %</driver> % % \fi % \iftrue \CheckSum{4592} \fi % % \def\fileversion{0.9} % \def\filedate{2006/11/11} % \def\TEXNIKA {% \expandafter \ifx \csname l@polutonikogreek\endcsname \relax \expandafter \ifx \csname l@ibycus\endcsname \relax $\tau\kern-.05em\epsilon\chi\nu\kern-.05em\iota \kappa\kern.04em\acute\alpha$% \else \foreignlanguage{ibycus}{texnika'}% \fi \else \foreignlanguage{polutonikogreek}{teqnik'a}% \fi } \def \TeXbook {\textit{The \TeX{}book}{}} \def \TXN@cmd#1{\texttt{\protect\bslash #1}}% % % % \thispagestyle{empty} % \begin{centering} % {\large \textsc{Gianfranco Boggio\,--Togna}}\par % \vspace*{1in} % {\Huge \TEXNIKA}\par % \vspace*{.15in} % {\LARGE Typesetting for the Humanities}\par % \vspace*{.5in} % {\Large The \textbf{poetry} package}\par % \vfill % {\Large Version 0.9}\par % \end{centering} % \newpage % \thispagestyle{empty} % \vspace{6ex} % \section*{Copyright notice} % \noindent Copyright \copyright\ Gianfranco Boggio--Togna 2006\par % Author's address: C.P. 14021, I-20140 Milano\\ % Email: \textsl{gbt\kern .08em @\kern .1em acm.org} % \vspace{6ex} % \section*{License} % \noindent This program is distributed under the terms of the license % that appears at the start of the file \texttt{poetry.dtx} (this file) % and in file \texttt{license.txt} % % This program consists of the files \texttt{poetry.dtx} and % \texttt{technica.ins} % % \newpage % \pagenumbering{roman} % \tableofcontents % \newpage % \pagenumbering{arabic} % \pagestyle {POETRY@page} % % \StopEventually{} % % \newpage % \section{External dependencies} % \begin{macrocode} \def \TXN@temp {LaTeX2e} \def \TXN@temp@bis {2003/12/01} \@tempswafalse \ifx \fmtname \TXN@temp \ifx \fmtversion \TXN@temp@bis \else \def \TXN@temp@bis {2005/12/01} \ifx \fmtversion \TXN@temp@bis \else \@tempswatrue \fi \fi \else \@tempswatrue \fi \if@tempswa \PackageError {POETRY} {The Technica suite requires the LaTex\MessageBreak release dated `2003/12/01' or `2005/12/01'} {} \def\recurse{(\recurse)}\recurse \fi % \end{macrocode} % % \begin{macrocode} \ProvidesPackage{poetry}% [2006/11/11 v. 0.9 A package for typesetting poetry] \DeclareOption {repeat} {\PassOptionsToPackage{repeat}{TEXNIKA}} \DeclareOption {lineno} {\PassOptionsToPackage{lineno}{TEXNIKA}} \DeclareOption {nowarnings} {\PassOptionsToPackage{nowarnings}{TEXNIKA}} \DeclareOption {inplacewarnings} {\PassOptionsToPackage{inplacewarnings}{TEXNIKA}} \ProcessOptions \RequirePackage{TEXNIKA} % \end{macrocode} % % \section{The main program} % \subsection{Initialize} % % Create the structures for |\excessus|. % \begin{macrocode} \TXN@internaltrue \Novus \textus[\TXN@e] \excessus \TXN@internalfalse \TXN@def {TXN@textus[\TXN@e]text}{\unhbox \PTR@box@excessus} % \end{macrocode} % Define the indentation unit. % \begin{macrocode} \gdef \PTR@stropha@unit {1em}% % \end{macrocode} % % \begin{macrocode} \AtBeginDocument {% % \end{macrocode} % Initialize the variables required for handling multi-split lines. % \begin{macrocode} \xdef \PTR@SpatiumEscEsc@corr {\the\maxdimen}% \gdef \PTR@multisplit@cs {0}% \ifnum \TXN@pass = \tw@ \PTR@multisplit@next \fi } % \end{macrocode} % \subsection{Enter \textit{versus}} % \begin{macrocode} \newif \ifPTR@first@line \newif \ifPTR@suspend \def \versus {\TXN@domain@enter 1} \def \PTR@versus {% %<debug> \TXN@trace \PTR@versus \TXN@withinVersustrue \ifTXN@folio@set \else \xdef \TXN@theFolio {\ifodd \c@page recto\else verso\fi}% \global \TXN@folio@settrue \fi \ifTXN@lineating \TXNl@lineate \TXN@process@line \fi \let \PTR@versus@esc@esc = \\\relax % \end{macrocode} % All paragraph spacing is suppressed: |\parskip| has an % infinitesimal amount of stretchability to compensate for % (equally infinitesimal) rounding errors in computing the page height. % \begin{macrocode} \edef \PTR@versus@parindent {\the\parindent}% \edef \PTR@versus@parskip {\the\parskip}% \parindent = \z@ \parskip = \z@ plus 1sp minus 1sp\relax \endgraf \xdef \PTR@lastskip {\maxdimen}% % \end{macrocode} % If suspended, do not initialize the domain info % \begin{macrocode} \ifPTR@suspend \else \xdef \MaxLineWidth {-\maxdimen}% \xdef \MinLineWidth {\maxdimen}% \xdef \MaxLineShift {-\maxdimen}% \xdef \MinLineShift {\maxdimen}% \fi % \end{macrocode} % Set up for auto |\Locus|. % \begin{macrocode} \ifPTR@auto@no \let \PTR@save@auto@def = \auto \def \auto {}% \else \ifx \empty \PTR@auto@mode \else \ifPTR@suspend \PTR@suspendfalse \else \let \PTR@save@auto@def = \auto \PTR@auto@setup \fi \fi \fi % \end{macrocode} % If suspended, resume % \begin{macrocode} \ifPTR@suspend \PTR@suspendfalse \fi % \end{macrocode} % Start fetching lines. % \begin{macrocode} \global \PTR@first@linetrue \PTR@fetch@line } \newcommand {\NotFirstLine}{\global \PTR@first@linefalse} \newcommand {\FirstLine}{\global \PTR@first@linetrue} \let \Versus = \versus % \end{macrocode} % \subsection{Fetch a line} % The mechanism for fetching a line is basically that of the dirty trick % with tabs on page 391 of \TeXbook: |\everypar| traps the start of a line % and opens an hbox; end-of-line, made active, closes the box. In most cases, % the whole line fits in a single box, but the |\\| command and the commands % in \textsl{drama} put parts of the line into separate boxes. % % The boxes come from this set. Reserving ten boxes is something of % an overkill, as no more than three or four are usually needed; but % pathological lines of drama may contain several embedded stage directions. % The boxes are assumed to be in a continuous range; we do not bother % to check this, as it is inconceivable that \LaTeX{} should start % allocating boxes non contiguously. % \begin{macrocode} \newbox \PTR@box@line \newbox \PTR@box@line@ii \newbox \PTR@box@line@iii \newbox \PTR@box@line@iv \newbox \PTR@box@line@v \newbox \PTR@box@line@vi \newbox \PTR@box@line@vii \newbox \PTR@box@line@viii \newbox \PTR@box@line@ix % \end{macrocode} % We need an index to keep track of where we are in the set. % \begin{macrocode} \newcount \PTR@box@ind % \end{macrocode} % There are five types of boxes: (\textit{Caution} These values are used in an % |\ifcase|). % \begin{macrocode} \chardef \PTR@box@text = 0 \chardef \PTR@box@persona = 1 \chardef \PTR@box@bracketSD = 2 \chardef \PTR@box@persona@bracketSD = 3 \chardef \PTR@box@split = 4 % \end{macrocode} % The box flags (only used by \textsl{Drama}) are stored in:\\ % |\@namedef{PTR@box@flags\the\PTR@box@ind}| % % \halign {\quad\tt#&\kern 4em#\hfill\cr % l& align left (persona and bracket) \cr % r& align right (bracket) \cr % c& center (bracket) \cr % b& bracket at beginning of speech \cr % m& bracket in the middle of a speech \cr % d& detached bracket \cr % a& suppress SpatiumAnte bracket \cr % p& suppress SpatiumPost bracket \cr % } % The box type is stored in: |\@namedef{PTR@box@type\the\PTR@box@ind}| % % The box contents, (only used by \textsl{Drama} for b-SDs) % are stored in:\\ % |\@namedef{PTR@box@toks\the\PTR@box@ind}| % % Two boxes (always use globally) for assembling and disassembling % a set of lines % \begin{macrocode} \newbox \PTR@vbox \newbox \PTR@hbox % \end{macrocode} % % This sets the machine in motion. % \begin{macrocode} \def \PTR@fetch@line {% \PTR@box@ind = \PTR@box@line \xdef \TXN@line@length {}% \global \PTR@explicit@indent = \z@skip \let \PTR@save@esc@esc = \\\relax \def \\{\leavevmode\PTR@esc@esc}% \everypar = {\PTR@start@box}% \PTR@obeylines } % \end{macrocode} % At the end of the line, we need to know if any text was found. % \begin{macrocode} \newif \ifPTR@par@started % \end{macrocode} % This macros is usually empty. It is set to |\ignorespaces| % before and after a b-SD. % \begin{macrocode} \gdef \PTR@ignorespaces {}% % \end{macrocode} % Start a box. % \begin{macrocode} \def \PTR@start@box {% %<debug> \TXN@trace \PTR@start@box \global \PTR@par@startedtrue \TXN@edef {PTR@box@type\the\PTR@box@ind}{\PTR@box@text}% \TXN@def {PTR@box@flags\the\PTR@box@ind}{}% \TXN@def {PTR@box@toks\the\PTR@box@ind}{}% \def \\{\leavevmode\PTR@esc@esc}% \setbox \PTR@box@ind = \hbox \bgroup \csname TXN@textus[\TXN@theTextus]Facies\endcsname \relax \ifnum \PTR@box@ind = \PTR@box@line \global \PTR@em = 1em\relax \xdef \PTR@strut@ht {\the\ht\strutbox}% \fi \strut \PTR@ignorespaces \TXN@check@incipit } % \end{macrocode} % The definition of end-of-line when active. % \begin{macrocode} \def \PTR@atendofline {% %<debug> \TXN@trace \PTR@atendofline \ifPTR@par@started \egroup \let \\= \PTR@save@esc@esc \everypar = {}\TXN@normalCR \ifdim \wd\PTR@box@ind = \z@ \advance \PTR@box@ind by \m@ne \fi %<debug> \PTR@showboxes \PTR@process@line \else \dimen@ = \lastskip \xdef \PTR@lastskip {\the\dimen@}% \ifTXN@after@Spatium \else \global \TXN@blank@linetrue \fi \fi \global \TXN@after@Spatiumfalse \global \PTR@par@startedfalse } % \end{macrocode} % Make end-of-line active. % \begin{macrocode} \begingroup \TXN@activeCR % CR is active! \gdef \PTR@obeylines {% \TXN@activeCR \let^^M=\PTR@atendofline}% \endgroup % \end{macrocode} % Close a box, setting type and flags. % \begin{macrocode} \def \PTR@close@box #1#2{% %<debug> \TXN@trace \PTR@close@box \egroup \gdef \PTR@ignorespaces {}% \TXN@edef {PTR@box@type\the\PTR@box@ind}{#1}% \TXN@edef {PTR@box@flags\the\PTR@box@ind}{#2}% } % \end{macrocode} % Advance to next box. % \begin{macrocode} \def \PTR@next@box {% %<debug> \TXN@trace \PTR@next@box \advance \PTR@box@ind by \@ne \PTR@start@box } % \end{macrocode} % Outside \textsl{drama} only |\\| can cause the line to be split % over two or three boxes. |\\| generates an empty box, whose width % is not zero if the optional parameter is present. % \begin{macrocode} \newif \ifPTR@initial@esc@esc \newif \ifPTR@esc@esc@star % \end{macrocode} % % \begin{macrocode} \def \PTR@esc@esc {% %<debug> \TXN@trace \PTR@esc@esc \ifPTR@par@started \unskip \egroup \fi \PTR@initial@esc@escfalse \ifdim \wd\PTR@box@ind = \z@ \ifnum \PTR@box@ind = \PTR@box@line \PTR@initial@esc@esctrue \fi \fi \@ifstar {\PTR@esc@esc@startrue\PTR@esc@esc@bis} {\PTR@esc@esc@starfalse\PTR@esc@esc@bis}% } % \end{macrocode} % % \begin{macrocode} \newcommand {\PTR@esc@esc@bis}[1][\relax]{% %<debug> \TXN@trace \PTR@esc@esc@bis \def \TXN@parameter {#1}% \dimen@@ = \maxdimen \ifPTR@initial@esc@esc \dimen@ = \PTR@stropha@unit \TXN@safe \else \setbox\z@ = \hbox {\TXN@SpatiumPostEscEsc}% \dimen@ = \wd\z@ \fi \ifPTR@esc@esc@star \multiply \dimen@ by \ifx \TXN@parameter \TXN@safe \tw@ \else #1\fi \else \ifx \TXN@parameter \TXN@safe \else \PTR@esc@esc@width #1\TXN@nil \fi \fi \ifPTR@initial@esc@esc \ifdim \dimen@@ < \maxdimen \dimen@ = \dimen@@ \fi \global \PTR@explicit@indent = \dimen@ \TXN@safe \expandafter \PTR@start@box \else \ifdim \wd\PTR@box@ind > \z@ \advance \PTR@box@ind by \@ne \fi \setbox \PTR@box@ind = \null \TXN@edef {PTR@box@type\the\PTR@box@ind}{\PTR@box@split}% \TXN@def {PTR@box@flags\the\PTR@box@ind}{}% \ifdim \dimen@@ < \maxdimen \advance \dimen@ by \dimen@@ \wd\PTR@box@ind = -\dimen@ \else \wd\PTR@box@ind = \dimen@ \fi \expandafter \PTR@next@box \fi } % \end{macrocode} % % \begin{macrocode} \def \PTR@esc@esc@width #1#2\TXN@nil{% %<debug> \TXN@trace \PTR@esc@esc@width \ifx -#1\relax \setbox \z@ = \hbox {#2}% \wd\z@ = -\wd\z@ \else \setbox \z@ = \hbox {% \csname TXN@textus[\TXN@theTextus]Facies\endcsname \relax #1#2}% \fi \dimen@@ = \wd\z@ } % \end{macrocode} % \newpage % \subsection{Process a line} % The line is assembled in this box: % \begin{macrocode} \newbox \PTR@box@full@line % \end{macrocode} % Two macros for adding stuff to the box: % \begin{macrocode} \def \PTR@append #1{\setbox \PTR@box@full@line = \hbox {\unhbox \PTR@box@full@line#1}} \def \PTR@prepend #1{\setbox \PTR@box@full@line = \hbox {#1\unhbox \PTR@box@full@line}} % \end{macrocode} % A box for the part of the text being moved to another line: % \begin{macrocode} \newbox \PTR@box@excessus % \end{macrocode} % \texttt{1em} for |\textus| % \begin{macrocode} \newdimen \PTR@em % \end{macrocode} % Though the values are actually \meta{dimen}, we allocate \meta{skip} % registers, as more of these are available. % % The indentation set by |\Forma \strophae|: % \begin{macrocode} \newskip \PTR@stropha@indent % \end{macrocode} % The explicit indentation set by |\\|: % \begin{macrocode} \newskip \PTR@explicit@indent % \end{macrocode} % The indentation for a speech, set by |\Forma \personae|: % \begin{macrocode} \newskip \PTR@speech@indent % \end{macrocode} % The |\textus| shift: % \begin{macrocode} \newskip \PTR@textus@shift % \end{macrocode} % The total indentation for text: % \begin{macrocode} \newskip \PTR@text@indent % \end{macrocode} % The length of the fragment on the previous line: % \begin{macrocode} \newskip \PTR@split@skip % \end{macrocode} % The length of the fragment on this line: % \begin{macrocode} \newskip \PTR@next@split@skip \global \PTR@next@split@skip = \z@skip % \end{macrocode} % The total size of text on the line: % \begin{macrocode} \newskip \PTR@text@width % \end{macrocode} % Counting the line in a strophe. % \begin{macrocode} \newcount \PTR@stropha@counter % \end{macrocode} % True at the end of a strophe. % \begin{macrocode} \newif \ifPTR@after@stropha % \end{macrocode} % True is the box cannot be typeset properly. % \begin{macrocode} \newif \ifPTR@overfull@box % \end{macrocode} % Process the line just fetched. % \begin{macrocode} \def \PTR@process@line {% %<debug> \TXN@trace \PTR@process@line %<debug> \TXN@trace@mode [process line]% % \end{macrocode} % Housekeeping. % \begin{macrocode} \setbox \PTR@box@full@line = \copy\voidb@x \PTR@text@width = \z@skip \setbox \TXN@marginalia = \copy\voidb@x \setbox \PTR@box@excessus = \null \def \PTR@r@bracketSD@ind {}% \def \TXN@line@class {}% % \end{macrocode} % % \begin{macrocode} \PTR@after@strophafalse \PTR@overfull@boxfalse \def \PTR@folded@line {}% % \end{macrocode} % % \begin{macrocode} \TXN@assign \TXN@measure = {TXN@textus[\TXN@theTextus]measure}% \PTR@text@width = \z@skip \global \TXN@leading@space = \maxdimen \PTR@stropha@indent = \maxdimen \TXN@safe \PTR@speech@indent = \z@skip \TXN@assign \PTR@textus@shift = {TXN@textus[\TXN@theTextus]shift}% \PTR@text@indent = \maxdimen \TXN@safe \TXN@get@Locus {textus[\TXN@e]}{t}% \edef \PTR@locus@excessus {\the\dimen@}% % \end{macrocode} % % \begin{macrocode} \gdef \PTR@SpatiumInfra@line {}% \gdef \PTR@SpatiumSupra@line {}% \def \PTR@hfill@right {\z@}% \def \PTR@hfill@left {\z@}% % \end{macrocode} % If the previous line ended with |\\|, this is the width of the % text before |\\|, otherwise zero. % \begin{macrocode} \global \PTR@split@skip = \PTR@next@split@skip % \end{macrocode} % Set the parameters defining the shape of a speech. % \begin{macrocode} \ifTXN@withinDrama \begingroup \DRM@FormaPersonae \xdef \PTR@parindent {\the\parindent}% \xdef \PTR@hangindent {\the\hangindent}% \xdef \PTR@hangafter {\the\hangafter}% \endgroup \PTR@get@speech@indent \@ne \edef \PTR@speech@indent@one {\the\PTR@speech@indent}% \PTR@get@speech@indent \tw@ \edef \PTR@speech@indent@two {\the\PTR@speech@indent}% \fi % \end{macrocode} % Save the initial value of the stropha counter. % \begin{macrocode} \edef \PTR@save@stropha@counter {\the\PTR@stropha@counter}% % \end{macrocode} % Join the pieces and typeset the complete line. % \begin{macrocode} \PTR@assemble@line \ifvoid \PTR@box@full@line \ifx \empty \PTR@r@bracketSD@ind \else \PTR@typeset@line \fi \else \PTR@typeset@line \fi % \end{macrocode} % Final clean up. % \begin{macrocode} \global \TXN@blank@linefalse \ifTXN@withinDrama \TXN@gincr \DRM@speech@lines \fi % \end{macrocode} % Go fetch the next line. % \begin{macrocode} \PTR@fetch@line } % \end{macrocode} % \subsection{Leave \textit{versus}} % \begin{macrocode} \def \endversus {\TXN@domain@leave 1} \let \endVersus = \endversus \def \PTR@endversus {% %<debug> \TXN@trace \PTR@endversus \ifPTR@par@started \egroup \fi \endgraf \TXN@withinVersusfalse \ifTXN@lineating \TXNl@lineate \relax \fi \parindent = \PTR@versus@parindent \TXN@safe \parskip = \PTR@versus@parskip \TXN@safe \let \\= \PTR@versus@esc@esc \ifPTR@suspend \PTR@suspendfalse \else \PTR@auto@record \fi \everypar = {}\TXN@normalCR \ifnum \TXN@numerus@pending > \z@ \TXN@Warning* {One or more line numbers could not be printed\MessageBreak (there is not enough room in the line)}% \def \TXN@numerus@pending {0}% {\parskip \z@ \par}% \fi } % \end{macrocode} % \newpage % \section{The \texttt{\char`\\stropha} class} % \subsection{The \texttt{\char`\\stropha} command} % % Initialize the attributes. % \begin{macrocode} \def \PTR@FormaStrophae {} \def \PTR@FaciesStrophae {} \def \PTR@SpatiumSupraStropham {} \def \PTR@SpatiumInfraStropham {} % \end{macrocode} % % \begin{macrocode} \newcommand {\stropha} {% \ifx \empty \TXN@attribute@name \expandafter \PTR@stropha \else \def \TXN@subclass@name {stropha}% \def \TXN@subclass@number {}% \def \TXN@temp {PTR}% \expandafter \TXN@attribute@set \fi } % \end{macrocode} % Some synonyms. % \begin{macrocode} \let \strophae = \stropha \let \stropham = \stropha % \end{macrocode} % % The variable is set to 2 by an explicit |\stropha| command. It changes to 1 % after the start of stropha has been processed (to prevent activation of % the normal mechanism) and is cleared by |\stropha*|, or by exiting a group % if |\stropha| appeared within a group. % % \begin{macrocode} \def \PTR@explicit@stropha {0} % \end{macrocode} % % \begin{macrocode} \def \PTR@stropha {% %<debug> \TXN@trace \PTR@stropha \global \PTR@stropha@counter = \z@ \def \PTR@explicit@stropha {0}% \@ifstar {}{\PTR@stropha@bis}% } % \end{macrocode} % The normal form (explicit or phantom strophe). % \begin{macrocode} \newcommand {\PTR@stropha@bis}[1][\relax]{% %<debug> \TXN@trace \PTR@stropha@bis \def \TXN@parameter {#1}% \ifx \TXN@parameter \TXN@safe \def \PTR@explicit@stropha {2}% \else \toks@ = {#1}% \expandafter \PTR@phantom@stropha \fi } % \end{macrocode} % A `phantom' stropha. % \begin{macrocode} \newif \ifPTR@phantom@text \def \PTR@phantom@stropha #1{ %<debug> \TXN@trace \PTR@phantom@stropha \def \TXN@parameter {#1}% \PTR@phantom@texttrue \ifx \empty \TXN@parameter \PTR@phantom@textfalse \fi \TXN@counter = \PTR@stropha@start \TXN@safe \TXN@counter@a = \PTR@stropha@length \TXN@safe \ifnum \TXN@counter < \z@ \TXN@counter = -\TXN@counter \fi \advance \TXN@counter@a by -\TXN@counter \ifPTR@phantom@text \advance \TXN@counter by \m@ne \advance \TXN@counter@a by \m@ne \fi \global \PTR@stropha@counter = \TXN@counter \TXN@toks@a = {}% \TXN@toks@b = {}% \expandafter \PTR@phantom@stropha@bis \the\toks@\TXN@nil \ifPTR@phantom@text \TXN@spatium@vertical \PTR@SpatiumSupraStropham \fi \the\TXN@toks@b#1\the\TXN@toks@a } % \end{macrocode} % Update the |\numerus| counters % \begin{macrocode} \def \PTR@phantom@stropha@bis #1{% \ifx \TXN@nil #1\relax \else \edef \TXN@temp {\the\TXN@toks@a \noexpand#1{+\the\TXN@counter@a}}% \TXN@toks@a = \expandafter {\TXN@temp}% \TXN@toks@b = \expandafter {\the\TXN@toks@b #1*{}}% \expandafter \PTR@phantom@stropha@bis \fi } % \end{macrocode} % \subsection{The \texttt{\char`\\Forma} attribute} % \begin{macrocode} \newif \ifPTR@stropha@skip@pending \newif \ifPTR@stropha@dup@pending % \end{macrocode} % % \begin{macrocode} \newcommand {\PTR@setForma@stropha} [1][0] {% %<debug> \TXN@trace \PTR@setForma@stropha \let \PTR@save@stropha@esc@esc = \\\relax \edef \PTR@stropha@length {#1}% % \end{macrocode} % Restore normal end-of-line while the parameter is read. % \begin{macrocode} \ifTXN@withinVersus \TXN@normalCR \fi \PTR@setForma@stropha@bis } % \end{macrocode} % % \begin{macrocode} \def \PTR@setForma@stropha@bis #1{% \ifTXN@withinVersus \TXN@activeCR \fi \TXN@SimpleList \TXN@SimpleList@work \z@ \global \PTR@stropha@counter = \z@ \def \PTR@stropha@break {\z@}% \def \PTR@stropha@start {\z@}% \PTR@stropha@skip@pendingfalse \PTR@stropha@dup@pendingfalse \PTR@setForma@stropha@ter #1\TXN@nil } % \end{macrocode} % % \begin{macrocode} \def \PTR@setForma@stropha@ter #1{% \let \\= \relax \let \PTR@stropha@next = \PTR@setForma@stropha@ter \ifx \TXN@nil#1\relax \let \PTR@stropha@next = \PTR@setForma@stropha@extend \else \ifx /#1\relax \edef \PTR@stropha@break {\the\PTR@stropha@counter}% \else \ifx (#1\relax \edef \PTR@stropha@start {\the\PTR@stropha@counter}% \else \ifx )#1\relax \relax \else \ifx *#1\relax \PTR@stropha@dup@pendingtrue \else \ifx \\#1\relax \let \PTR@stropha@next = \PTR@get@stropha@unit \else \ifPTR@stropha@dup@pending \PTR@stropha@dup@pendingfalse \TXN@counter = \@ne \loop \ifnum \TXN@counter < #1\relax \TXN@SimpleList@append \TXN@SimpleList@work {\the\TXN@toks@a}% \global \advance \PTR@stropha@counter by \@ne \advance \TXN@counter by \@ne \repeat \else \TXN@sw@false \ifx c#1\relax \else \ifx C#1\relax \else \ifx z#1\relax \else \ifx Z#1\relax \else \PTR@stropha@check@spatium {#1}% \ifTXN@sw \TXN@build@spatium@list {#1}% \fi \fi\fi\fi\fi \ifTXN@sw \PTR@stropha@skip@pendingtrue \expandafter \TXN@toks@b \expandafter {\TXN@L@spatium}% \else \ifPTR@stropha@skip@pending \TXN@SimpleList@append \TXN@SimpleList@work {\the\TXN@toks@b}% \PTR@stropha@skip@pendingfalse \fi \global \advance \PTR@stropha@counter by \@ne \TXN@toks@a = {#1}% \ifx c#1\relax \TXN@toks@a = {-10000}% \fi \ifx C#1\relax \TXN@toks@a = {-10000}% \fi \ifx z#1\relax \TXN@toks@a = {-9999}% \fi \ifx Z#1\relax \TXN@toks@a = {-9999}% \fi \TXN@SimpleList@append \TXN@SimpleList@work {\the\TXN@toks@a}% \fi \fi\fi\fi\fi\fi\fi\fi \PTR@stropha@next } % \end{macrocode} % Check whether the value is a |\spatium| specification (i.e. contains % at least a letter or a control sequence) % \begin{macrocode} \def \PTR@stropha@check@spatium #1{% \PTR@stropha@check@spatium@bis #1\TXN@nil } \def \PTR@stropha@check@spatium@bis #1{% \let \next = \PTR@stropha@check@spatium@ter \ifx \TXN@nil #1\relax \let \next = \relax \else \ifcat \relax \noexpand#1\relax \TXN@sw@true \else \ifcat a\noexpand#1\relax \TXN@sw@true \else \let \next = \PTR@stropha@check@spatium@bis \fi \fi \fi \next } \def \PTR@stropha@check@spatium@ter #1\TXN@nil{}% % \end{macrocode} % Extend the list to the length given in the optional parameter (if any) % by replicating the last entry as necessary.\\ % |\TXN@toks@a| contains the last value\\ % |\TXN@toks@b| may contain the pending skip (which can be inserted % only after the list has been extended). % \begin{macrocode} \def \PTR@setForma@stropha@extend {% \ifnum \PTR@stropha@counter = \z@ \else \TXN@counter@a = \PTR@stropha@length \TXN@safe \advance \TXN@counter@a by \PTR@stropha@start \TXN@safe \loop \ifnum \PTR@stropha@counter < \TXN@counter@a \TXN@SimpleList@append \TXN@SimpleList@work {\the\TXN@toks@a}% \global \advance \PTR@stropha@counter by \@ne \repeat \ifPTR@stropha@skip@pending \TXN@SimpleList@append \TXN@SimpleList@work {\the\TXN@toks@b}% \fi \edef \PTR@stropha@length {\the\PTR@stropha@counter}% \TXN@SimpleList@append \TXN@SimpleList@work {10000}% \fi \global \PTR@stropha@counter = \z@ \edef \PTR@FormaStrophae {\TXN@SimpleList@work}% \let \\= \PTR@save@stropha@esc@esc } % \end{macrocode} % Set the stropha indent unit. % \begin{macrocode} \def \PTR@get@stropha@unit #1\TXN@nil{% \TXN@check@if@glue #1\TXN@nil \ifTXN@sw \xdef \PTR@stropha@unit {#1}% \else \PackageError {POETRY} {The value you have specified for the \MessageBreak indentation unit is not a legal TeX dimension.}% {You may have forgotten the unit of measure\MessageBreak or mispelled its name.}% \fi \PTR@setForma@stropha@extend } % \end{macrocode} % \subsection{The other attributes} % \begin{macrocode} \def \PTR@setFacies@stropha #1{% \def \TXN@parameter {#1}% \ifx \empty \TXN@parameter \def \PTR@FaciesStrophae {}% \else \def \PTR@FaciesStrophae {#1\relax\vskip \z@}% \fi } % \end{macrocode} % % \begin{macrocode} \def \PTR@setSpatiumSupra@stropha #1{% \def \TXN@parameter {#1}% \ifx \empty \TXN@parameter \def \PTR@SpatiumSupraStropham {}% \else \TXN@build@spatium@list {#1}% \edef \PTR@SpatiumSupraStropham {\TXN@L@spatium}% \fi } % \end{macrocode} % % \begin{macrocode} \def \PTR@setSpatiumInfra@stropha #1{% \def \TXN@parameter {#1}% \ifx \empty \TXN@parameter \def \PTR@SpatiumInfraStropham {}% \else \TXN@build@spatium@list {#1}% \edef \PTR@SpatiumInfraStropham {\TXN@L@spatium}% \fi } % \end{macrocode} % \section{\textit{Processing the line}} % \subsection{Assemble the line} % % This is a fragment (other than the first) of a split line. % \begin{macrocode} \newif \ifPTR@is@fragment % \end{macrocode} % % The first box is \texttt{persona} or \texttt{persona} + \texttt{b-SD}. % \begin{macrocode} \newif \ifPTR@speech@heading % \end{macrocode} % % The line contains a SD. % \begin{macrocode} \newif \ifPTR@has@SD % \end{macrocode} % % \begin{macrocode} \def \PTR@cannot@typeset@properly {% \TXN@Warning* {The line cannot be typeset properly.\MessageBreak Manual intervention is necessary}% } \def \PTR@assemble@line {% %<debug> \TXN@trace \PTR@assemble@line %<debug> \TXN@trace@mode [assemble line]% \PTR@is@fragmentfalse \PTR@speech@headingfalse \PTR@has@SDfalse % \end{macrocode} % Loop through the boxes. % \begin{macrocode} \advance \PTR@box@ind by \@ne \edef \PTR@box@ind@afterlast {\the\PTR@box@ind}% \PTR@box@ind = \PTR@box@line \TXN@assign \count@ = {PTR@box@type\the\PTR@box@line}% \ifodd \count@ % persona or persona + b-SD \PTR@speech@headingtrue \fi \@whilenum \PTR@box@ind < \PTR@box@ind@afterlast \do{% \edef \PTR@box@flags {\@nameuse {PTR@box@flags\the\PTR@box@ind}}% \TXN@assign \TXN@counter = {PTR@box@type\the\PTR@box@ind}% \ifcase \TXN@counter % \end{macrocode} % Text % \begin{macrocode} \ifdim \wd\PTR@box@ind > \z@ \let \PTR@next = \PTR@process@text@box \fi % \end{macrocode} % Persona % \begin{macrocode} \or \let \PTR@next = \PTR@process@persona@box % \end{macrocode} % b-SD % \begin{macrocode} \or \ifdim \wd\PTR@box@ind > \z@ \let \PTR@next = \PTR@process@bracketSD@box \ifnum \PTR@box@ind = \PTR@box@line \if \TXN@option \TXN@o@DetachedSD \PTR@box@flags \let \PTR@next = \PTR@process@detached@bracketSD@box \else \ifTXN@blank@line \PTR@count@text@boxes \ifnum \TXN@counter@a = \z@ \if \TXN@option \TXN@o@EmbeddedSD \PTR@box@flags \else \let \PTR@next = \PTR@process@detached@bracketSD@box \fi \fi \fi \fi \fi \fi % \end{macrocode} % Persona + b-SD % \begin{macrocode} \or \let \PTR@next = \PTR@process@persona@bracketSD@box % \end{macrocode} % Split % \begin{macrocode} \or \let \PTR@next = \PTR@process@split@box \else \PackageError {POETRY} {This can't happen (3)} {Please report the error to the author}% \fi \PTR@next \advance \PTR@box@ind by \@ne }% } % \end{macrocode} % \subsection{Typeset the line} % % \begin{macrocode} % \end{macrocode} % Do not normalize line height % \begin{macrocode} \newif \ifTXN@true@line@height \newcommand {\TrueLineHeight}{\TXN@true@line@heighttrue} % \end{macrocode} % True if the line overlaps the next line. % \begin{macrocode} \newif \ifPTR@backup % \end{macrocode} % % \begin{macrocode} \def \PTR@typeset@line {% %<debug> \TXN@trace \PTR@typeset@line % \end{macrocode} % Check for a multisplit line % \begin{macrocode} \ifTXN@SpatiumEscEsc@noauto \else \PTR@check@multisplit \fi % \end{macrocode} % Process |\auto| information. % \begin{macrocode} \PTR@auto@update % \end{macrocode} % Insert SpatiumSupra, if any. % \begin{macrocode} \ifx \empty \PTR@SpatiumSupra@line \else \endgraf \vskip -\baselineskip \vskip \z@ \TXN@spatium@vertical \PTR@SpatiumSupra@line \fi % \end{macrocode} % Save the position of the text. % \begin{macrocode} \TXN@assign \dimen@ = {TXN@textus[\TXN@theTextus]shift}% \xdef \PTR@previous@shift {\the\dimen@}% % \end{macrocode} % Check if this the start of a strophe. % \begin{macrocode} \ifdim \PTR@text@width > \z@ \PTR@check@start@of@stropha \xdef \PTR@lastskip {\z@}% \fi % \end{macrocode} % % \begin{macrocode} \ifPTR@first@line \global \PTR@first@linefalse \ifTXN@CollectingIndexesData \ifnum \TXN@pass = \tw@ \TXN@sw@false \ifTXN@index@first@lines \TXN@sw@true \else \ifTXN@index@next@first@line \TXN@sw@true \fi \fi \ifTXN@sw \PTR@process@first@line \fi \fi \fi \fi % \end{macrocode} % Update statistics % \begin{macrocode} \ifPTR@is@fragment \else \ifdim \PTR@text@width > \z@ \TXN@gincr \TXN@stats@versus@lines \fi \fi \ifdim \TXN@stats@versus@longest < \wd\PTR@box@full@line \xdef \TXN@stats@versus@longest {\the\wd\PTR@box@full@line}% \fi % \end{macrocode} % Check if line needs folding % \begin{macrocode} \PTR@check@folding % \end{macrocode} % Check for a pending [r] b-SD % \begin{macrocode} \ifx \empty \PTR@r@bracketSD@ind \else \TXN@counter = \PTR@r@bracketSD@ind \TXN@safe \dimen@ = \wd\TXN@counter \advance \dimen@ by \wd\PTR@box@full@line \setbox \z@ = \hbox {\DRM@SpatiumAnteBracketSD}% \advance \dimen@ by \wd\z@ \ifdim \dimen@ > \TXN@measure \else %<debug> \TXN@trace \PTR@process@R \advance \dimen@ by -\wd\z@ \dimen@@ = \TXN@measure \advance \dimen@@ by -\dimen@ \edef \PTR@hfill@right {\the\dimen@@}% \setbox \PTR@box@full@line = \hbox {% \hbox {\unhbox \PTR@box@full@line}% \kern \dimen@@ \hbox {\unhbox \TXN@counter}}% \def \PTR@r@bracketSD@ind {}% \ifdim \PTR@text@width = \z@ \def \TXN@line@class {[}% \else \PTR@has@SDtrue \fi \fi \fi % \end{macrocode} % Update statistics. % \begin{macrocode} \ifdim \wd\PTR@box@excessus > \z@ \TXN@gincr \TXN@stats@versus@excessus@count \ifdim \TXN@stats@versus@excessus@longest < \wd\PTR@box@excessus \xdef \TXN@stats@versus@excessus@longest {\the\wd\PTR@box@excessus}% \fi \ifdim \TXN@stats@versus@excessus@shortest > \wd\PTR@box@excessus \xdef \TXN@stats@versus@excessus@shortest {\the\wd\PTR@box@excessus}% \fi \ifdim \wd\PTR@box@excessus < .75\PTR@em % \TXN@Warning {The folded part of the line\MessageBreak is less than .75em in width}% \fi \fi \dimen@ = \the\wd\PTR@box@full@line \advance \dimen@ by -\PTR@textus@shift \xdef \PreviousLineWidth {\the\dimen@}% \ifdim \PreviousLineWidth > \MaxLineWidth \xdef \MaxLineWidth {\PreviousLineWidth}% \fi \ifdim \PreviousLineWidth < \MinLineWidth \xdef \MinLineWidth {\PreviousLineWidth}% \fi \ifdim \TXN@stats@versus@longest@print < \wd\PTR@box@full@line \xdef \TXN@stats@versus@longest@print {\the \wd\PTR@box@full@line}% \fi \xdef \PreviousLineShift {\the\PTR@textus@shift}% \ifdim \PreviousLineShift > \MaxLineShift \TXN@safe \xdef \MaxLineShift {\PreviousLineShift}% \fi \ifdim \PreviousLineShift < \MinLineShift \TXN@safe \xdef \MinLineShift {\PreviousLineShift}% \fi % \end{macrocode} % Set the line margins. % \begin{macrocode} \PTR@set@line@margins \PTR@box@full@line % \end{macrocode} % Generate the |\excessus| % \begin{macrocode} \ifdim \wd\PTR@box@excessus > \z@ \TXN@attach@textus{\TXN@e}% \ifTXN@leaders \PTR@append {\kern \TXN@excessus@leaders\relax}% \fi \def \PTR@folded@line {0}% \fi % \end{macrocode} % This is necessary because uppercase letters carrying an accent have % a height greater than the design height for the font: they would stretch % the inter-line spacing, making the page \texttt{Underfull}. % \begin{macrocode} \ifdim \PTR@text@width > \z@ \ifTXN@true@line@height \else \ht\PTR@box@full@line = \PTR@strut@ht \TXN@safe \fi \fi %<*debug> \ifPTR@showline \showbox \PTR@box@full@line \fi %</debug> \ifPTR@has@SD \ifdim \PTR@text@width = \z@ \def \TXN@line@class {[}% \fi \fi % \end{macrocode} % Attach |\textus| and |\numerus| objects % \begin{macrocode} \TXN@attach@textus{\z@}% \TXN@process@line@numbers \def \PTR@folded@line {}% % \end{macrocode} % At last, we are ready to print the line. % \begin{macrocode} \ifvoid \PTR@box@full@line \else \leavevmode \PTR@line@to@page \PTR@box@full@line \par \fi \def \TXN@line@class {}% % \end{macrocode} % If |\\| after |\persona| back up a line % \begin{macrocode} \ifPTR@backup \PTR@backupfalse \vskip -\baselineskip \fi % \end{macrocode} % Add any requested space below this line. % \begin{macrocode} \TXN@spatium@vertical \PTR@SpatiumInfra@line \ifPTR@after@stropha \ifnum \TXN@active@areas > \z@ \expandafter \global \expandafter \let \csname TXN@area[\TXN@area@count]stropha\endcsname = \PTR@SpatiumInfraStropham \else \TXN@spatium@vertical \PTR@SpatiumInfraStropham \fi \fi % \end{macrocode} % Check for a (still) pending [r] b-SD % \begin{macrocode} \ifx \empty \PTR@r@bracketSD@ind \else \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \hfill \unhbox \PTR@r@bracketSD@ind}% \def \TXN@line@class {[}% \PTR@line@to@page \PTR@hbox \def \TXN@line@class {}% \fi } % \end{macrocode} % Set the line margins. % \begin{macrocode} \def \PTR@set@line@margins #1{% \TXN@SimpleList \TXN@line@fields \z@ \TXN@assign \dimen@@ = {TXN@textus[\TXN@theTextus]offset@\TXN@theFolio}% \dimen@ = \TXN@leading@space \TXN@safe \advance \dimen@ by \dimen@@ \setbox \z@ = \hbox {\unhcopy#1\unskip}% \advance \dimen@@ by \wd\z@ \edef \TXN@temp {\the\dimen@,\the\dimen@@}% \TXN@SimpleList@append \TXN@line@fields \TXN@temp } % \end{macrocode} % \section{\textit{Assembling the line}} % \subsection{Process a text box} % \begin{macrocode} \def \PTR@process@text@box {% %<debug> \TXN@trace \PTR@process@text@box \ifdim \PTR@text@indent = \maxdimen \PTR@set@text@indent %<debug> \TXN@trace@dim \PTR@textus@shift %<debug> \TXN@trace@dim \PTR@text@indent %<debug> \TXN@trace@macro \DRM@speech@lines \ifPTR@speech@heading \ifdim \PTR@textus@shift = \z@ \else \dimen@ = \PTR@text@indent \TXN@safe \PTR@get@speech@indent \tw@ \advance \dimen@ by \PTR@speech@indent \TXN@safe \setbox \z@ = \hbox {\unhcopy \PTR@box@full@line\unskip}% \ifdim \dimen@ < \wd\z@ \TXN@Warning* {The text overlaps the speech heading}% \fi \advance \dimen@ by -\wd\PTR@box@full@line \PTR@append {\kern \dimen@}% \fi \else \PTR@append {\kern \PTR@text@indent}% \fi \fi \ifdim \PTR@split@skip > \z@ \PTR@process@text@box@split \else \PTR@append {\unhbox \PTR@box@ind}% \fi \PTR@text@width = \wd\PTR@box@full@line } \def \PTR@process@text@box@split {% % \end{macrocode} % This is a fragment (not the first) of a split line. % \begin{macrocode} \PTR@is@fragmenttrue \ifdim \PTR@SpatiumEscEsc@corr < \maxdimen % \end{macrocode} % The correction for a multi-split line is available; apply it. % \begin{macrocode} \dimen@ = \PTR@split@skip \advance \dimen@ by -\wd\PTR@box@full@line \advance \dimen@ by \PTR@SpatiumEscEsc@corr \PTR@append {\kern \dimen@ \unhbox \PTR@box@ind}% \else \ifdim \PTR@split@skip > \wd\PTR@box@full@line % \end{macrocode} % The first pass: collect information for a (possibly) multi-split line. % \begin{macrocode} \setbox\z@ = \hbox {\TXN@SpatiumPostEscEsc}% \dimen@ = \PTR@split@skip \advance \dimen@ by \wd\z@ \advance \dimen@ by \wd\PTR@box@ind \ifdim \dimen@ > \TXN@measure \advance \dimen@ by -\TXN@measure \dimen@@ = \dimen@ \advance \dimen@@ by -\wd\z@ \dimen@ = \PTR@split@skip \advance \dimen@ by -\wd\PTR@box@full@line \advance \dimen@ by -\dimen@@ \else \dimen@ = \PTR@split@skip \advance \dimen@ by -\wd\PTR@box@full@line \dimen@@ = \wd\z@ \advance \dimen@ by \dimen@@ \fi \PTR@append {\kern \dimen@ \unhbox \PTR@box@ind}% \ifnum \PTR@split@count > \z@ \advance \dimen@@ by \PTR@multisplit@spacing \xdef \PTR@multisplit@spacing {\the\dimen@@}% \fi \else % \end{macrocode} % We are already beyond the point at which the fragment should start % \begin{macrocode} \PTR@append {\unhbox \PTR@box@ind}% \ifnum \TXN@pass = \tw@ \else \ifnum \PTR@multisplit@line > \z@ % \end{macrocode} % This cannot be a multipslit line % \begin{macrocode} \xdef \PTR@multisplit@line {\z@}% \gdef \PTR@split@count {\z@}% \fi \fi \fi \fi \global \PTR@next@split@skip = \z@skip } % \end{macrocode} % \subsection{Process a persona box} % \begin{macrocode} \def \PTR@process@persona@box {% %<debug> \TXN@trace \PTR@process@persona@box \PTR@process@persona@vertical@spacing \xdef \DRM@speech@lines {\@ne}% % \end{macrocode} % For |\00| we use the indentation for text. % \begin{macrocode} \ifx \DRM@persona@first \DRM@persona@zero@zero \xdef \DRM@speech@lines {\tw@}% \setbox \PTR@box@ind = \null \fi \PTR@count@text@boxes \ifnum \TXN@counter@a = \z@ \def \TXN@line@class {p}% \fi \PTR@get@speech@indent \empty \PTR@append {\kern \PTR@speech@indent \unhbox \PTR@box@ind}% \ifdim \TXN@leading@space = \maxdimen \global \TXN@leading@space = \PTR@speech@indent \TXN@safe \fi \if \TXN@option \TXN@o@PersonaLeft \PTR@box@flags \expandafter \PTR@process@persona@left \fi } % \end{macrocode} % \subsection{Process a persona+b-SD box} % \begin{macrocode} \def \PTR@process@persona@bracketSD@box {% %<debug> \TXN@trace \PTR@process@persona@bracketSD@box \PTR@process@persona@vertical@spacing \PTR@get@speech@indent \@ne \ifdim \TXN@leading@space = \maxdimen \global \TXN@leading@space = \PTR@speech@indent \TXN@safe \fi \dimen@ = \wd\PTR@box@full@line \advance \dimen@ by \wd\PTR@box@ind \ifdim \dimen@ > \TXN@measure \PTR@process@persona@bracketSD@box@overflow \else \PTR@has@SDtrue \PTR@append {\kern \PTR@speech@indent\unhbox \PTR@box@ind}% \ifdim \wd\PTR@box@full@line > \TXN@measure \PTR@reset@line \fi \if \TXN@option \TXN@o@PersonaLeft \PTR@box@flags \PTR@process@persona@left \fi \fi } % \end{macrocode} % The SD does not fit in the line. % \begin{macrocode} \def \PTR@process@persona@bracketSD@box@overflow {% %<debug> \TXN@trace \PTR@process@persona@bracketSD@box@overflow \setbox \PTR@vbox = \vbox {% \hsize = \TXN@measure \hbadness = \@M \hfuzz = \maxdimen \parindent = \z@ \topskip = \z@ \DRM@FormaPersonae \begingroup \def \\{\hskip \z@ plus 1fil\penalty -10000\relax}% \def \TXN@parm@ii {% \DRM@SpatiumAnteBracketSD \DRM@FaciesBracketSD {% \strut \@nameuse {PTR@box@toks\the\PTR@box@ind}\strut}% }% \DRM@FaciesPersonae@first {\DRM@persona@first}{\TXN@parm@ii}% \endgroup \global \TXN@baselineskip = \baselineskip \xdef \TXN@badness {\the\badness}% \endgraf \xdef \TXN@prevgraf {\the\prevgraf}% \ifnum \TXN@badness < \badness \xdef \TXN@badness {\the\badness}% \fi }% \ifnum \TXN@badness < \@M \else \PTR@cannot@typeset@properly \fi \def \TXN@line@class {[}% \TXN@counter = \@ne \@whilenum \TXN@counter < \TXN@prevgraf \do{% \setbox \tw@ = \vbox {% \vbadness = \@M \splittopskip = \z@ \global \setbox \@ne = \vsplit \PTR@vbox to \TXN@baselineskip \global \setbox \PTR@vbox = \box \PTR@vbox \unvbox \@ne \global \setbox \PTR@hbox = \lastbox \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \kern \ifnum \TXN@counter = \@ne \PTR@speech@indent@one \else \PTR@speech@indent@two\fi \unhbox \PTR@hbox}% }% \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \leavevmode \PTR@line@to@page \PTR@hbox \advance \TXN@counter by \@ne }% \unvbox \PTR@vbox \setbox \z@ = \lastbox \setbox \PTR@box@full@line = \hbox {% \kern \ifnum \TXN@counter = \@ne \PTR@speech@indent@one \else \PTR@speech@indent@two \fi \unhbox \z@}% \ifnum \TXN@prevgraf = \@ne \PTR@line@to@page \PTR@box@full@line \setbox \PTR@box@full@line = \copy \voidb@x \PTR@text@width = \z@skip \else \PTR@setSpatiumPostBracketSD \fi \PTR@has@SDtrue \def \TXN@line@class {}% } % \end{macrocode} % Set the spacing around persona. % \begin{macrocode} \def \PTR@process@persona@vertical@spacing {% %<debug> \TXN@trace \PTR@process@persona@vertical@spacing \TXN@spatium@vertical \DRM@SpatiumSupraPersonam % \end{macrocode} % Any text on the line? % \begin{macrocode} \PTR@count@text@boxes % \end{macrocode} % No. % \begin{macrocode} \ifnum \TXN@counter@a = \z@ \global \let \PTR@SpatiumInfra@line = \DRM@SpatiumInfraPersonam \fi } \def \PTR@process@persona@left {% \ifdim \PTR@split@skip > \z@ \else % \end{macrocode} % Any text on the line? % \begin{macrocode} \PTR@count@text@boxes % \end{macrocode} % Yes. % \begin{macrocode} \ifnum \TXN@counter@a > \z@ \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \unhbox \PTR@box@full@line \hss}% \PTR@line@to@page \PTR@hbox \endgraf \PTR@get@speech@indent \tw@ \PTR@prepend {\kern \PTR@speech@indent}% \fi \TXN@spatium@vertical \DRM@SpatiumInfraPersonam \fi } % \end{macrocode} % \subsection{Process a b-SD box} % \begin{macrocode} \def \PTR@process@bracketSD@box {% %<debug> \TXN@trace \PTR@process@bracketSD@box % \end{macrocode} % For a [r] b-SD we delay processing until the whole line has % been assembled: there may not be room for it in the line and % it may have to be moved to a line of its own. % \begin{macrocode} \if \TXN@option \TXN@o@RightSD \PTR@box@flags \edef \PTR@r@bracketSD@ind {\number \PTR@box@ind}% \else \expandafter \PTR@process@bracketSD@box@bis \fi } \def \PTR@process@bracketSD@box@bis {% \ifnum \PTR@box@ind = \PTR@box@line \ifdim \PTR@text@indent = \maxdimen \PTR@set@text@indent \fi \PTR@append {\kern \PTR@text@indent}% \fi \dimen@ = \TXN@measure \advance \dimen@ by -\wd\PTR@box@full@line \advance \dimen@ by -\wd\PTR@box@ind \ifdim \dimen@ < \z@ \expandafter \PTR@process@bracketSD@overflow \else \expandafter \PTR@process@bracketSD@normal \fi } % \end{macrocode} % The normal case: a SD that fits in the line. % \begin{macrocode} \def \PTR@process@bracketSD@normal {% %<debug> \TXN@trace \PTR@process@bracketSD@normal \PTR@has@SDtrue % \end{macrocode} % If at the start of the line, do not generate the \textit{SpatiumAnte}. % \begin{macrocode} \if \TXN@option \TXN@o@LeftSD \PTR@box@flags \count@ = \PTR@box@ind \advance \count@ by \@ne \TXN@sw@true \ifnum \count@ = \PTR@box@ind@afterlast \TXN@sw@false \else \if \TXN@num {PTR@box@type\the\count@} = \PTR@box@text \else \TXN@sw@false \fi \fi \ifTXN@sw \setbox \z@ = \hbox {\unhbox \PTR@box@ind\DRM@SpatiumPostBracketSD}% \setbox \count@ = \hbox {\kern -\wd\z@ \box \z@ \box \count@}% \else \PackageError {POETRY} {A b-SD with the 'l' option must be immediately followed by text} {}% \fi \else \ifnum \PTR@box@ind = \PTR@box@line \else \if \TXN@option \TXN@o@NoSpatiumAnte \PTR@box@flags \else \PTR@append {\unskip \DRM@SpatiumAnteBracketSD}% \fi \fi \PTR@append {\unhbox \PTR@box@ind}% \PTR@has@SDtrue \PTR@setSpatiumPostBracketSD \fi } % \end{macrocode} % A SD that does not fit in the line. % % \begin{macrocode} \def \PTR@process@bracketSD@overflow {% %<debug> \TXN@trace \PTR@process@bracketSD@overflow \global \setbox \PTR@vbox = \vbox {% \parindent = \z@skip \hsize = \TXN@measure \hbadness = \@M \hfuzz = \maxdimen \topskip = \z@ \leavevmode \ifPTR@speech@heading \DRM@FormaPersonae \kern -\TXN@leading@space \xdef \TXN@gtemp {\PTR@speech@indent@one}% \xdef \TXN@gtemp@bis {\PTR@speech@indent@two}% \else \hangafter \@ne \hangindent = \PTR@text@indent \gdef \TXN@gtemp {0pt}% \xdef \TXN@gtemp@bis {\the\PTR@text@indent}% \fi \unhbox \PTR@box@full@line \ifnum \PTR@box@ind > \PTR@box@line \DRM@SpatiumAnteBracketSD \fi \begingroup \def \\{\hskip \z@ plus 1fil\penalty -10000\relax}% \DRM@FaciesBracketSD {% \strut \@nameuse {PTR@box@toks\the\PTR@box@ind}\strut}% \endgroup \global \TXN@baselineskip = \baselineskip \xdef \TXN@badness {\the\badness}% \endgraf \ifnum \TXN@badness < \badness \xdef \TXN@badness {\the\badness}% \fi \xdef \TXN@prevgraf {\the\prevgraf}% }% \ifnum \TXN@badness < \@M \else \PTR@cannot@typeset@properly \fi \def \TXN@line@class {[}% \TXN@counter = \@ne \@whilenum \TXN@counter < \TXN@prevgraf \do{% \setbox\tw@ = \vbox{% \vbadness = \@M \splittopskip = \z@ \global \setbox \@ne = \vsplit \PTR@vbox to \TXN@baselineskip \global \setbox \PTR@vbox = \box \PTR@vbox \unvbox \@ne \global \setbox \PTR@hbox = \lastbox \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \kern \ifnum \TXN@counter = \@ne \TXN@gtemp \else \TXN@gtemp@bis\fi \unhbox \PTR@hbox}% }% \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \leavevmode \PTR@line@to@page \PTR@hbox \advance \TXN@counter by \@ne }% \unvbox \PTR@vbox \setbox \z@ = \lastbox \setbox \PTR@box@full@line = \hbox {% \kern \ifnum \TXN@counter = \@ne \TXN@gtemp \else \TXN@gtemp@bis\fi \unhbox \z@ }% \PTR@setSpatiumPostBracketSD \PTR@has@SDtrue \def \TXN@line@class {}% } % \end{macrocode} % \subsection{Process a detached b-SD} % \begin{macrocode} \def \PTR@process@detached@bracketSD@box {% %<debug> \TXN@trace \PTR@process@detached@bracketSD@box \def \TXN@entity@code {[}% \def \TXN@line@class {[}% \edef \DRM@options@SD {\PTR@box@flags}% \DRM@standalone@pre \DRM@FaciesBracketSD {% \@nameuse {PTR@box@toks\the\PTR@box@ind}}% \DRM@standalone@post \def \TXN@line@class {}% \setbox \PTR@box@full@line = \copy \voidb@x \PTR@text@width = \z@skip } % \end{macrocode} % % \begin{macrocode} \def \PTR@setSpatiumPostBracketSD {% %<debug> \TXN@trace \PTR@setSpatiumPostBracketSD \if \TXN@option \TXN@o@NoSpatiumPost \PTR@box@flags \else \setbox \z@ = \hbox {\DRM@SpatiumPostBracketSD}% \dimen@ = \wd\PTR@box@full@line \advance \dimen@ by \wd\z@ \ifdim \dimen@ > \TXN@measure \else \PTR@append {\DRM@SpatiumPostBracketSD}% \fi \fi } % \end{macrocode} % \subsection{Process a `line split' box} % \begin{macrocode} \def \PTR@process@split@box {% % \end{macrocode} % Any more text on the line? % \begin{macrocode} \PTR@count@text@boxes \ifnum \TXN@counter@a > \z@ % \end{macrocode} % Yes: this is an explicit text split. % \begin{macrocode} \advance \PTR@box@ind by \@ne \TXN@sw@false \ifnum \TXN@counter@a > \@ne \TXN@sw@true \else \if \TXN@num {PTR@box@type\the\PTR@box@ind} = \PTR@box@text \else \TXN@sw@true \fi \fi \ifTXN@sw \PackageError {POETRY} {Extraneous material after \protect\\} {Only a single \protect\textus\space object may follow \protect\\}% \fi % \end{macrocode} % Advancing the index terminates the main loop. % \begin{macrocode} \setbox \PTR@box@excessus = \copy \PTR@box@ind \else % \end{macrocode} % No: this is a verse fragment or a stand-alone |\persona|. % \begin{macrocode} % \end{macrocode} % Any text before the split? % % Yes: this is a verse fragment. % \begin{macrocode} \ifnum \TXN@counter@b > \z@ \setbox \z@ = \hbox {\unhcopy \PTR@box@full@line}% \global \PTR@next@split@skip = \wd\z@ \global \advance \PTR@next@split@skip by \wd\PTR@box@ind \else % \end{macrocode} % No: this is split after a stand-alone |\persona|. % \begin{macrocode} \PTR@backuptrue \fi \fi } % \end{macrocode} % \subsection{Count the text boxes} % Returns: in |\TXN@counter@a| the number of text boxes in the part % of the line starting at the current box (|\PTR@box@ind|), in % |\TXN@counter@b| the number of text boxes in the part of the line % before the current box. % \begin{macrocode} \def \PTR@count@text@boxes {% \TXN@counter = \PTR@box@line \TXN@counter@a = \z@ \TXN@counter@b = \z@ \@whilenum \TXN@counter < \PTR@box@ind@afterlast \do{% \if \TXN@num {PTR@box@type\the\TXN@counter} = \PTR@box@text \advance \ifnum \TXN@counter > \PTR@box@ind \TXN@counter@a \else \TXN@counter@b \fi by \@ne \fi \advance \TXN@counter by \@ne }% } % \end{macrocode} % \subsection{Get the hanging indentation} % \begin{macrocode} \def \PTR@get@speech@indent #1{% %<debug> \TXN@trace \PTR@get@speech@indent \PTR@speech@indent = \z@skip \ifTXN@withinDrama \ifx \empty #1\relax \TXN@counter = \DRM@speech@lines \TXN@safe \else \TXN@counter = #1\relax \fi \ifdim \PTR@hangindent = \z@ \ifdim \PTR@parindent = \z@ \else \ifnum \TXN@counter = \@ne \PTR@speech@indent = \PTR@parindent \TXN@safe \fi \fi \else \ifdim \PTR@hangindent < \z@ \PackageError {POETRY} {The package does not support\MessageBreak negative values for \protect\hangindent} {}% \else \ifnum \PTR@hangafter < \z@ \count@ = \PTR@hangafter \TXN@safe \advance \count@ by \m@ne \count@ = -\count@ \ifnum \TXN@counter < \count@ \PTR@speech@indent = \PTR@hangindent \TXN@safe \fi \else \ifnum \TXN@counter > \PTR@hangafter \TXN@safe \PTR@speech@indent = \PTR@hangindent \TXN@safe \fi \fi \fi \fi \fi %<debug> \TXN@trace@dim \PTR@speech@indent } % \end{macrocode} % \subsection{Get the stropha indentation} % \begin{macrocode} \def \PTR@get@stropha@indent {% %<debug> \TXN@trace \PTR@get@stropha@indent \PTR@stropha@indent = \z@skip \ifx \empty \PTR@FormaStrophae \else \ifnum \PTR@stropha@break > \z@ \global \PTR@stropha@counter = \PTR@stropha@break \TXN@safe \def \PTR@stropha@break {\z@}% \fi \ifdim \PTR@split@skip = \z@ \global \advance \PTR@stropha@counter by \@ne \fi \fi \ifx \empty \PTR@FormaStrophae \PTR@stropha@indent = \PTR@explicit@indent \TXN@safe \else \ifnum \PTR@explicit@stropha = \z@ % \end{macrocode} % After |\stropha [...]| the counter may be -1 on entry and 0 now. % \begin{macrocode} \ifnum \PTR@stropha@counter > \z@ \PTR@get@stropha@indent@bis \fi \else \PTR@get@stropha@indent@bis % \end{macrocode} % Ignore the indentation except for `z' % \begin{macrocode} \ifnum -9999 = \TXN@indent \TXN@safe \else \PTR@stropha@indent = \z@ \fi \fi \advance \PTR@stropha@indent by \PTR@explicit@indent \TXN@safe \fi % \end{macrocode} % Account from the indentation forced by a Drop Cap. % \begin{macrocode} \ifnum \TXN@DropCap@lines = \z@ \else \TXN@dim@a = \z@ \count@ = \TXN@DropCap@lines \TXN@safe \ifnum \count@ < \z@ \count@ = -\count@ \xdef \PTR@DropCap@first@indent {\the\PTR@stropha@indent}% \else \advance \count@ by \m@ne \TXN@get \TXN@DropCap@indent.\count@ \TXN@temp \ifx \empty \PTR@FormaStrophae \TXN@dim@a = \TXN@temp \TXN@safe \advance \TXN@dim@a by \PTR@DropCap@first@indent \TXN@safe \else \ifnum -\@M = \TXN@indent \TXN@safe \else \TXN@dim@a = \TXN@temp \TXN@safe \advance \TXN@dim@a by \PTR@DropCap@first@indent \TXN@safe \fi \fi \fi \xdef \TXN@DropCap@lines {\the\count@}% \ifdim \PTR@stropha@indent < \TXN@dim@a \PTR@stropha@indent = \TXN@dim@a \TXN@safe \fi \fi % \end{macrocode} % Check if final line of a stropha. % \begin{macrocode} \ifx \empty \PTR@FormaStrophae \else \ifnum \PTR@stropha@counter = \PTR@stropha@length \TXN@safe \ifnum \PTR@explicit@stropha > \z@ \global \advance \PTR@stropha@counter by \m@ne \else \ifnum \PTR@stropha@start > \z@ \global \PTR@stropha@counter = \PTR@stropha@start \edef \PTR@stropha@start {-\PTR@stropha@start}% \else \count@ = \PTR@stropha@start \TXN@safe \ifnum \count@ < \z@ \count@ = -\count@ \fi \global \PTR@stropha@counter = \count@ \fi \PTR@after@strophatrue \fi \fi \fi %<debug> \TXN@trace@dim \PTR@stropha@indent } \def \PTR@get@stropha@indent@bis {% %<debug> \TXN@trace \PTR@get@stropha@indent@bis \PTR@after@strophafalse %<debug> \TXN@trace@count [counter before]\PTR@stropha@counter \@tempcnta = \PTR@stropha@counter \begingroup \gdef \TXN@indent{}% \long \def \\##1{% \TXN@NameList@check {##1}{\TXN@NameList@spatium}% \ifTXN@sw \ifnum \@tempcnta = \z@ \ifnum \PTR@stropha@counter = \PTR@stropha@length \TXN@safe \xdef \PTR@SpatiumInfra@line {##1}% \fi \else \ifnum \@tempcnta = \@ne \xdef \PTR@SpatiumSupra@line {##1}% \fi \fi \else \advance \@tempcnta by \m@ne \ifnum \@tempcnta = \z@ \gdef \TXN@indent {##1}% \fi \fi }% \PTR@FormaStrophae \endgroup \ifx \TXN@indent \TXN@safe \PackageError {POETRY} {This can't happen (4).} {Please report the error to the author}% \else \ifx \empty \TXN@indent \PackageError {POETRY} {This can't happen (5).} {Please report the error to the author}% \fi \ifnum -\@M = \TXN@indent \TXN@safe \PTR@stropha@indent = \TXN@measure \advance \PTR@stropha@indent by -\wd\PTR@box@ind \divide \PTR@stropha@indent by \tw@ \else \dimen@ = \PTR@stropha@unit \TXN@safe \ifnum -9999 = \TXN@indent \TXN@safe \PTR@stropha@indent = \z@ \ifNewPage \PTR@stropha@indent = \dimen@ \TXN@safe \fi \else \PTR@stropha@indent = \TXN@indent \dimen@ \TXN@safe \fi \fi \fi } % \end{macrocode} % \section{\textit{Typesetting the line}} % % \subsection{Check for the start of a strophe} % \begin{macrocode} \def \PTR@check@start@of@stropha {% %<debug> \TXN@trace \PTR@check@start@of@stropha \TXN@sw@false \ifnum \PTR@explicit@stropha > \z@ \ifnum \PTR@explicit@stropha = \tw@ \def \PTR@explicit@stropha {1}% \TXN@sw@true \fi \else \ifx \empty \PTR@FormaStrophae \else \count@ = \PTR@stropha@start \TXN@safe \ifnum \count@ < \z@ \count@ = -\count@ \fi \ifnum \PTR@save@stropha@counter = \count@ \TXN@sw@true \fi \fi \fi \ifTXN@sw % \end{macrocode} % The null |\vskip| prevents the preceding |\vskip| being removed % by |\addvspace|. % \begin{macrocode} \ifx \empty \PTR@FaciesStrophae \ifdim \PTR@lastskip = \z@ \ifhmode \endgraf \vskip \prevdepth \vskip -\baselineskip \vskip \z@skip \fi \ifx \empty \PTR@SpatiumSupraStropham \else \TXN@spatium@vertical \PTR@SpatiumSupraStropham \fi \fi \else \endgraf \vskip \prevdepth \vskip -\baselineskip \vskip \z@skip \begingroup \TXN@withinFaciesStrophaetrue \PTR@FaciesStrophae \endgroup \fi \fi } % \end{macrocode} % \subsection{Check for line folding} % \begin{macrocode} \def \PTR@check@folding {% %<debug> \TXN@trace \PTR@check@folding % \end{macrocode} % Get the maximum acceptable badness (if any) for the line after % folding % \begin{macrocode} \def \PTR@excessus@badness {}% \edef \TXN@temp {\@nameuse{TXN@textus[\TXN@e]flagsModus@\TXN@theFolio}}% \if \TXN@option \TXN@o@Justified \TXN@temp \edef \PTR@excessus@badness {\@nameuse {TXN@textus[\TXN@e]field@\TXN@theFolio}}% \fi % \end{macrocode} % Check if folding is requested / needed % \begin{macrocode} \ifdim \wd\PTR@box@excessus > \z@ \PTR@explicit@fold \else \ifdim \wd\PTR@box@full@line > \TXN@measure \ifdim \PTR@locus@excessus < \maxdimen \PTR@automatic@fold \else \ifPTR@overfull@box \else \setbox \z@ = \hbox {\unhcopy\PTR@box@full@line\unskip}% \ifdim \wd\z@ > \TXN@measure \dimen@ = \wd\PTR@box@full@line \advance \dimen@ by -\TXN@measure \TXN@Warning* {The line is too long (by \the\dimen@)\MessageBreak (and you have not defined \space \protect\Locus\space \protect\excessus)}% \fi \fi \fi \fi \fi % \end{macrocode} % % \begin{macrocode} \ifdim \wd\PTR@box@excessus > \z@ \setbox \PTR@box@full@line = \null \fi } % \end{macrocode} % Explicit folding. % \begin{macrocode} \def \PTR@explicit@fold {% %<debug> \TXN@trace \PTR@explicit@fold \ifdim \PTR@locus@excessus = \maxdimen \PackageError {POETRY} {You have requested line folding\MessageBreak but you have not defined \space \protect\Locus\space \protect\excessus} {}% \fi \xdef \TXN@line@length {\the\wd\PTR@box@full@line}% \TXN@sw@false \ifx \empty \PTR@excessus@badness \else \ifnum \PTR@excessus@badness = \m@ne \else \TXN@sw@true \fi \fi \def \PTR@folded@line {1}% \TXN@attach@textus{\z@}% \TXN@process@line@numbers \ifTXN@sw \begingroup \hbadness \@M \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \spaceskip .33\PTR@em plus 1fil\unhbox \PTR@box@full@line}% \endgroup \else \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \unhbox \PTR@box@full@line \hss}% \fi \PTR@line@to@page \PTR@hbox \endgraf \penalty 1000\relax } % \end{macrocode} % Automatic fold. % \begin{macrocode} \def \PTR@automatic@fold {% %<debug> \TXN@trace \PTR@automatic@fold \PTR@split@line \PTR@box@full@line \TXN@measure \xdef \TXN@line@length {\the\wd\@ne}% \TXN@sw@false \ifnum \TXN@prevgraf > \tw@ \TXN@sw@true \else \ifnum \TXN@prevgraf = \tw@ \TXN@dim@a = \ifdim \PTR@locus@excessus = \maxdimen \z@ \else \PTR@locus@excessus \TXN@safe \fi \advance \TXN@dim@a by \wd\tw@ \ifdim \TXN@dim@a > \TXN@measure \TXN@sw@true \fi \fi \fi \ifTXN@sw \PTR@loong@line \else \def \PTR@folded@line {1}% \leavevmode \ifx \empty \PTR@excessus@badness \xdef \PreviousLineWidth {\TXN@line@length}% \ifdim \PreviousLineWidth > \MaxLineWidth \xdef \MaxLineWidth {\PreviousLineWidth}% \fi \global \setbox \PTR@hbox = \hbox {\unhbox \@ne}% \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \begingroup \TXN@leadersfalse \PTR@line@to@page \PTR@hbox \endgroup \endgraf \else \begingroup \hbadness = \@M \hfuzz = \maxdimen \global \setbox \PTR@hbox = \hbox to \TXN@measure {% \spaceskip = .33\PTR@em plus 1fill minus .22\PTR@em\relax \unhcopy\@ne\unskip}% \xdef \PreviousLineWidth {\the\TXN@measure}% \ifdim \PreviousLineWidth > \MaxLineWidth \xdef \MaxLineWidth {\PreviousLineWidth}% \fi \xdef \PTR@line@badness {\the\badness}% \ifnum \PTR@excessus@badness = \m@ne \TXN@assign \dimen@ = {TXN@textus[\TXN@theTextus]offset@\TXN@theFolio}% \advance \dimen@ by \TXN@measure \setbox \TXN@marginalia = \hbox to \z@ {% \box \TXN@marginalia \kern \dimen@ \rlap{\ \tiny\upshape\PTR@line@badness}}% \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \PTR@line@to@page \PTR@hbox \else \ifnum \PTR@excessus@badness < \PTR@line@badness \TXN@Warning* {If justified, the line would have a badness of% \MessageBreak \PTR@line@badness, greater than the limit you have% set (\number\PTR@excessus@badness)}% \ifnum \TXN@warnings@level > \@ne \advance \dimen@ by \TXN@measure \setbox \TXN@marginalia = \hbox to \z@ {% \box \TXN@marginalia \kern \dimen@ \rlap{\ \tiny\upshape\PTR@line@badness}}% \fi \fi \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \PTR@line@to@page \PTR@hbox \fi \endgraf \endgroup \fi \penalty 1000\relax \setbox \PTR@box@excessus = \box \tw@ \fi } % \end{macrocode} % \subsection{Split a long line to be folded} % Split a line (in hbox |#1|) into two lines, the first of which has a width % not exceeding the value of |#2|. The two lines are in |\box1| and |\box2|. % On exit: % |\TXN@counter| the number of lines (may be \textgreater{} 2 for pathological lines) % \begin{macrocode} \def \PTR@split@line #1#2{% %<debug> \TXN@trace \PTR@split@line % \end{macrocode} % In |\TXN@dim@a| we put the offset of |\excessus| if the |\Locus| is % defined, otherwise |\z@|. % In |\TXN@@counter@a|, |\z@| if |\unhyphenated|. % \begin{macrocode} \TXN@dim@a = \ifdim \PTR@locus@excessus = \maxdimen \z@ \else \PTR@locus@excessus \TXN@safe \fi \TXN@counter@a = \@ne \if \TXN@empty {TXN@textus[\TXN@e]flagsModus@\TXN@theFolio}% \else \edef \TXN@flags {\@nameuse {TXN@textus[\TXN@e]flagsModus@\TXN@theFolio}}% \if \TXN@option \TXN@o@Unhyphenated \TXN@flags \TXN@counter@a = \z@ \fi \if \TXN@option \TXN@o@RangedRight \TXN@flags \TXN@dim@a = \z@ \fi \fi % \end{macrocode} % First we must achieve a split. % \begin{macrocode} \dimen@ = #2\relax \dimen@@ = .5\PTR@em % \xdef \TXN@prevgraf {\z@}% \loop \PTR@try@split@line #1\TXN@counter@a \ifnum \TXN@prevgraf < \tw@ \advance \dimen@ by -.5em\relax \repeat % \end{macrocode} % As overfull boxes cannot be detected, we must do all % checking ourselves and repeat the process until a satisfactory % spli is achieved. % \begin{macrocode} \loop \ifdim \wd\@ne > \dimen@ \advance \dimen@ by -.1em\relax \PTR@try@split@line #1\TXN@counter@a \repeat } % \end{macrocode} % To split the line, we typeset it a vbox with the width in |\dimen@| % \begin{macrocode} \def \PTR@try@split@line #1#2{% \setbox \z@ = \vbox {% \hsize \dimen@ \rightskip = \z@ plus \dimen@@ \parindent = \z@skip \hbadness = \@M \hfuzz = \maxdimen \widowpenalty = \z@ \clubpenalty = \z@ \hyphenpenalty = \z@ \finalhyphendemerits = \z@ \ifnum #2 = \@ne \pretolerance = 100\relax \else \pretolerance = \@M \fi \global \TXN@baselineskip = \baselineskip \unhcopy #1\relax \PTR@remove@hboxes \endgraf \xdef \TXN@prevgraf {\the \prevgraf}% }% \ifnum \TXN@prevgraf > \@ne \ifnum \TXN@prevgraf = \tw@ \splittopskip = \z@skip \dimen@ii = \ht\z@ \advance \dimen@ii by -\TXN@baselineskip \global \setbox \@ne = \vsplit\z@ to \dimen@ii % % \end{macrocode} % We do all unboxing inside a throw-away box, to trap any stray pieces % which would otherwise migrate to the page. % \begin{macrocode} \setbox \z@ = \vbox{% \unvbox \@ne \unskip \global \setbox \@ne = \lastbox \global \setbox \@ne = \hbox {\unhbox \@ne}% \unvbox \z@ \unskip \unskip \unpenalty \setbox \z@ = \lastbox \global \setbox \thr@@ = \hbox {\unhbox \z@}% \advance \TXN@dim@a by \wd\thr@@ \ifdim \TXN@dim@a > \TXN@measure % \end{macrocode} % We force the loop to stop (this is a loong line) and set the line % counter to a value > 2. % \begin{macrocode} \wd\@ne = \z@ \xdef \TXN@prevgraf {\thr@@}% \fi }% \setbox \tw@ = \box \thr@@ \else % \end{macrocode} % We force the loop to stop (this is a loong line). % \begin{macrocode} \wd \@ne = \z@ \fi \else % \end{macrocode} % We force the loop to continue. % \begin{macrocode} \global \setbox \@ne = \hbox to 2\dimen@ {}% \fi } \def \PTR@remove@hboxes {% \setbox \z@ = \lastbox \ifhbox \z@ {\PTR@remove@hboxes}\unhbox \z@ \fi } % \end{macrocode} % \subsection{Process a loong line} % We have a line of verse [sic] that will not fit in two physical lines. % We re-set it as a paragraph with hanging indentation. % \begin{macrocode} \def \PTR@loong@line {% %<debug> \TXN@trace \PTR@loong@line \ifdim \PTR@locus@excessus = \maxdimen \PackageError {POETRY} {A very long `line' cannot be typeset because\MessageBreak \protect\Locus\space \protect\excessus\space is not on the left side} {}% \else \TXN@dim@a = \PTR@locus@excessus \TXN@safe \fi \global \setbox \PTR@vbox = \vbox {% \hsize = \TXN@measure \hbadness = \@M \hfuzz = \maxdimen \parindent = \z@skip \parskip = \z@skip \topskip = \z@skip \widowpenalty = \z@ \clubpenalty = \z@ \global \TXN@baselineskip = \baselineskip \hangafter \@ne \hangindent \TXN@dim@a \unhbox \PTR@box@full@line \xdef \TXN@badness {\the \badness}% \endgraf \xdef \TXN@prevgraf {\the \prevgraf}% }% \ifnum \TXN@badness < \@M \xdef \PTR@loong@lines {\TXN@prevgraf}% \xdef \PTR@loong@counter {1}% \@whilenum \PTR@loong@lines > \@ne \do{% \setbox\tw@ = \vbox {% \vbadness = \@M \splittopskip = \z@ \global \setbox \@ne = \vsplit \PTR@vbox to \TXN@baselineskip \global \setbox \PTR@vbox = \box \PTR@vbox \unvbox \@ne \global \setbox \PTR@hbox = \lastbox }% \global \setbox \PTR@hbox = \hbox to \TXN@measure {\hss\box\PTR@hbox}% \edef \PTR@folded@line {\PTR@loong@counter}% \PTR@set@line@margins \PTR@hbox \TXN@attach@textus {\z@}% \TXN@process@line@numbers \PTR@line@to@page \PTR@hbox \TXN@gincr \PTR@loong@counter \TXN@gdecr \PTR@loong@lines \ifnum \PTR@loong@lines > \@ne \leavevmode \fi }% \def \PTR@folded@line {0}% \unvbox \PTR@vbox \setbox \PTR@box@excessus = \lastbox \else \PTR@cannot@typeset@properly \PTR@overfull@boxtrue \fi } % \end{macrocode} % \subsection{Re-set the line} % Try typesetting the line again to fit the measure: the inter-word % glue may shrink enough to make this possible. % \begin{macrocode} \def \PTR@reset@line {% %<debug> \TXN@trace \PTR@reset@line \TXN@dim@a = \wd\PTR@box@full@line \advance \TXN@dim@a by -\TXN@measure % \end{macrocode} % Prevent an \texttt{Overfull box} message % \begin{macrocode} \TXN@counter = \hbadness \TXN@dim@b = \hfuzz \hbadness = \@M \hfuzz = \maxdimen \setbox \PTR@box@full@line = \hbox to \TXN@measure {% \unhbox\PTR@box@full@line \unskip}% \hbadness = \TXN@counter \hfuzz = \TXN@dim@b \TXN@counter = \badness \setbox \z@ = \copy \PTR@box@full@line \ifnum \TXN@counter > \hbadness \TXN@dim@a = \wd\PTR@box@full@line \advance \TXN@dim@a by -\TXN@measure \ifdim \TXN@dim@a = \z@ \PTR@cannot@typeset@properly \setbox \PTR@box@full@line = \hbox to \TXN@measure {% \unhbox\PTR@box@full@line \unskip}% \else \PTR@cannot@typeset@properly \fi \PTR@overfull@boxtrue \fi \PTR@count@text@boxes \ifnum \TXN@counter@a > \z@ \PTR@line@to@page \PTR@box@full@line \setbox \PTR@box@full@line = \copy \voidb@x \PTR@text@width = \z@skip \fi } % \end{macrocode} % \subsection{Move a line to the page} % \begin{macrocode} \def \PTR@line@to@page #1{% %<debug> \TXN@trace \PTR@line@to@page \ifnum \TXN@theTextus = \z@ % \end{macrocode} % Update area info % \begin{macrocode} \ifnum \TXN@active@areas > \z@ \TXN@process@area@line@Versus {#1}% \fi \TXN@assign \dimen@ = {TXN@textus[\TXN@theTextus]offset@\TXN@theFolio}% \ifvbox #1\relax \PackageError {POETRY} {This can't happen (6).} {Please report the error to the author}% \unvbox#1\relax \else \ifTXN@leaders \dimen@@ = \TXN@leaders@width \TXN@safe \setbox \z@ = \hbox to \TXN@measure {\kern \dimen@\box#1% \leaders \hbox to \dimen@@ {\hss.\hss}\hfill}% \else \setbox \z@ = \hbox {\kern \dimen@\box#1}% \fi %<*debug> \ifPTR@showline \global \PTR@showlinefalse \showbox \z@ \fi %</debug> \begingroup \hsize \linewidth \ifvoid\TXN@marginalia \else \box \TXN@marginalia \fi \box\z@ \par \endgroup \fi \else \ifvoid\TXN@marginalia \else \box \TXN@marginalia \fi \box#1\relax \fi \ifx \PTR@box@full@line #1\relax \PTR@text@width = \z@skip \fi } % \end{macrocode} % % \begin{macrocode} \def \PTR@set@text@indent {% \ifPTR@speech@heading \PTR@speech@indent = \z@skip \else \PTR@get@speech@indent \empty \fi \PTR@text@indent = \PTR@textus@shift \advance \PTR@text@indent by \PTR@speech@indent \TXN@safe \PTR@get@stropha@indent \advance \PTR@text@indent by \PTR@stropha@indent \TXN@safe \ifdim \TXN@leading@space = \maxdimen \global \TXN@leading@space = \PTR@text@indent \TXN@safe \fi } % \end{macrocode} % \section{Multi-split lines} % % The number of splits (number of fragments - 1). % \begin{macrocode} \gdef \PTR@split@count {0}% % \end{macrocode} % The input line number for the line at which the first split occurs. % \begin{macrocode} \gdef \PTR@multisplit@line {0}% % \end{macrocode} % \subsection{Collect information about the multi-split} % \begin{macrocode} \def \PTR@check@multisplit {% %<debug> \TXN@trace \PTR@check@multisplit \ifnum \TXN@pass = \tw@ \ifnum \inputlineno = \PTR@multisplit@line \TXN@safe \xdef \PTR@SpatiumEscEsc@corr {-\PTR@multisplit@delta}% \fi \fi \ifPTR@is@fragment % \end{macrocode} % An intermediate (not the initial) fragment. % \begin{macrocode} \ifdim \PTR@next@split@skip > \z@ % \end{macrocode} % Not the last fragment. % \begin{macrocode} \ifnum \TXN@pass = \tw@ \else \ifnum \PTR@split@count = \z@ % \end{macrocode} % The first intermediate fragment. |\PTR@multisplit@spacing| will hold % the sum of all fragment lengths minus the text measure; % |\PTR@multisplit@line| records the position at which the multi-split % starts. |\PTR@split@count| counts the inter-fragment `holes'. % \begin{macrocode} \gdef \PTR@multisplit@spacing {\z@}% \ifnum \PTR@multisplit@line = \z@ \xdef \PTR@multisplit@line {\the\inputlineno}% \else \gdef \PTR@split@count {\@ne}% \fi \else % \end{macrocode} % Not the first intermediate fragment: just increment the count. % \begin{macrocode} \TXN@gincr \PTR@split@count \fi \fi \else % \end{macrocode} % The last fragment. % \begin{macrocode} \ifnum \PTR@split@count = \z@ \else \dimen@ = \wd\PTR@box@full@line \dimen@@ = \PTR@multisplit@spacing \TXN@safe \advance \dimen@ by \dimen@@ % \end{macrocode} % The line does not fit in the text measure. We write a line to % .aux containing the macro |\PTR@multisplit| with two arguments: % the input line number at which the multisplit starts and the % value that should be used for spacing between fragments. % \begin{macrocode} \ifdim \dimen@ > \TXN@measure \TXN@gincr \PTR@split@count \advance \dimen@ by -\TXN@measure \divide \dimen@ by \PTR@split@count \TXN@safe \advance \dimen@ by \ifdim \dimen@ < \z@ -\fi 1sp % \protected@write \@auxout {}{% \string\PTR@multisplit {\PTR@multisplit@line}{\the\dimen@}}% \TXN@run@LaTeX@again@reason \TXN@run@LaTeX@again@split \fi \gdef \PTR@split@count {0}% \fi \ifdim \PTR@SpatiumEscEsc@corr < \maxdimen \xdef \PTR@SpatiumEscEsc@corr {\the\maxdimen}% \PTR@multisplit@next \fi \fi \else % \end{macrocode} % Possibly the first fragment. % \begin{macrocode} \ifdim \PTR@text@width > \z@ \ifdim \PTR@next@split@skip > \z@ \ifnum \TXN@pass = \tw@ \else % \end{macrocode} % It is the first fragment. % \begin{macrocode} \xdef \PTR@multisplit@line {\the\inputlineno}% \fi \else % \end{macrocode} % Not a split line: clear the count. % \begin{macrocode} \gdef \PTR@split@count {0}% \fi \fi \fi } % \end{macrocode} % \subsection{Process the information about the multi-split} % % As the .aux file is read in, on the second pass, the information % (input line number/the excess length) is recorded in control % sequences of the form |\PTR@multisplit|\textit{nn} % \begin{macrocode} \gdef \PTR@multisplit@cs {0}% \def \PTR@multisplit #1#2{% \TXN@gincr \PTR@multisplit@cs \TXN@gdef {PTR@multisplit\PTR@multisplit@cs}{{#1}{#2}}% } % \end{macrocode} % For the run through .aux at the end of the first pass. % \begin{macrocode} \AtEndDocument{\let \PTR@multisplit \@gobbletwo} % \end{macrocode} % Fetch the next linenumber/spacing pair from the macro (if % any) created during the run through .aux at the start of the % second pass (|\PTR@multisplit|\textit{nn}). % \begin{macrocode} \def \PTR@multisplit@next {% %<debug> \TXN@trace \PTR@multisplit@next \TXN@gincr \PTR@multisplit@cs \if \TXN@relax {PTR@multisplit\PTR@multisplit@cs}% \gdef \PTR@multisplit@line {0}% \gdef \PTR@multisplit@delta {\z@}% \else \expandafter \PTR@multisplit@get \csname PTR@multisplit\PTR@multisplit@cs\endcsname \fi } % \end{macrocode} % % \begin{macrocode} \def \PTR@multisplit@get #1{% \expandafter \PTR@multisplit@get@bis #1\relax } \def \PTR@multisplit@get@bis #1#2{% \gdef \PTR@multisplit@line {#1}% \gdef \PTR@multisplit@delta {#2}% } % \end{macrocode} % \section{The \texttt{\char`\\auto} option} % \begin{macrocode} \newif \ifPTR@auto@no \newif \ifPTR@auto@explicit \newskip \PTR@auto@textwidth \def \PTR@auto@mode {}% \def \PTR@auto@count {0} % \end{macrocode} % Stepped up for each |\versus| |\endversus| pair. % \begin{macrocode} \gdef \PTR@versus@count {1} % \end{macrocode} % \subsection{On entry to \textit{Versus}} % \begin{macrocode} \def \PTR@auto@setup {% %<debug> \TXN@trace \PTR@auto@setup %<debug> \TXN@trace@macro \PTR@versus@count \ifnum \TXN@pass = \@ne % \end{macrocode} % First pass: start the mechanism. % \begin{macrocode} \TXN@run@LaTeX@again@reason \TXN@run@LaTeX@again@auto \PTR@auto@textwidth = \z@skip \def \PTR@auto@count {0}% \def \auto {\unskip \global \PTR@auto@explicittrue}% \fi \ifnum \TXN@pass = \tw@ % \end{macrocode} % Second pass: set the \texttt{textus} shift. % \begin{macrocode} \def \auto {}% \PTR@auto@fetch {\PTR@versus@count}% \TXN@dim@a = \dimen@ \TXN@dim@b = \dimen@@ \PTR@auto@check@delta \dimen@ = \TXN@measure \advance \dimen@ by -\TXN@dim@a \divide \dimen@ by \tw@ \ifdim \dimen@ < \z@ \dimen@ = \z@ \TXN@PackageWarningNoLine {POETRY} {Input line \number\inputlineno: \MessageBreak The \@backslashchar textus shift set by \@backslashchar Locus {\@backslashchar auto} (or {\@backslashchar Auto})\MessageBreak is negative. Replaced by a null shift of 0pt} \fi \TXN@edef {TXN@textus[\TXN@theTextus]shift}{\the\dimen@}% \fi } % \end{macrocode} % \subsection{Update \texttt{\char`\\auto} information} % \begin{macrocode} \def \PTR@auto@update {% %<debug> \TXN@trace \PTR@auto@update \ifx \empty \PTR@auto@mode \else \expandafter \PTR@auto@update@bis \fi } \def \PTR@auto@update@bis {% \ifPTR@auto@explicit \PTR@auto@textwidth = \PTR@text@width \global \PTR@auto@explicitfalse \if a\PTR@auto@mode \def \PTR@auto@mode {A}% \else \if m\PTR@auto@mode \def \PTR@auto@mode {M}% \fi \fi \fi \if m\PTR@auto@mode \ifdim \PTR@text@width > \PTR@auto@textwidth \PTR@auto@textwidth = \PTR@text@width \fi \fi \if a\PTR@auto@mode \count@ = \PTR@auto@count \TXN@safe \ifnum \count@ > \tw@ % \end{macrocode} % We ignore very short lines to avoid skewing the mean. % \begin{macrocode} \dimen@ = \PTR@auto@textwidth \divide \dimen@ by \count@ \dimen@ = .75\dimen@ \else \dimen@ = \z@ \fi % \end{macrocode} % The maximum legal dimensione is 5.7583 metres. % \begin{macrocode} \ifdim \PTR@auto@textwidth < 550cm\relax \ifdim \PTR@text@width > \dimen@ \advance \PTR@auto@textwidth by \PTR@text@width \advance \count@ by \@ne \edef \PTR@auto@count {\the\count@}% \fi \fi \fi } % \end{macrocode} % \subsection{On exit from \textit{Versus}} % % Record the information on .aux % \begin{macrocode} \def \PTR@auto@record {% \ifx \empty \PTR@auto@mode \else \expandafter \PTR@auto@record@bis \fi } \def \PTR@auto@record@bis {% \TXN@counter@a = \PTR@versus@count \if a\PTR@auto@mode \count@ = \PTR@auto@count \TXN@safe \ifnum \count@ = \z@ % \end{macrocode} % Someone wrote |\versus \endversus|. % \begin{macrocode} \else \divide \PTR@auto@textwidth by \count@ \fi \fi \let \auto = \PTR@save@auto@def \ifnum \TXN@pass = \@ne \TXN@dim@a = \TXN@auto@delta \TXN@safe \protected@write\@auxout{}{\string\PTR@auto {\the\TXN@counter@a}% {{\the\PTR@auto@textwidth}% {\the\TXN@dim@a}}% }% \fi \advance \TXN@counter@a by \@ne \xdef \PTR@versus@count {\the\TXN@counter@a}% % \end{macrocode} % Restore the standard values that were overwritten at an explicit % |\auto|. % \begin{macrocode} \if A \PTR@auto@mode \def \PTR@auto@mode {a}% \else \if M \PTR@auto@mode \def \PTR@auto@mode {m}% \fi \fi } % \end{macrocode} % \subsection{Process the \texttt{\char`\\auto} information} % % At the start of the second pass, as .aux is read in, a control % sequence of the form |\PTR@|\textit{n}|@| records, for the %\textit{n}-th \textit{Versus} domain, the following information:\\ % 1) The average (for |\auto|) or maximum (for |\Auto|) line length;\\ % 2) The `delta' value used for comparison with the alignment of % the previous two domains. % % \begin{macrocode} \def \PTR@auto #1#2{% \TXN@gdef {PTR@#1@}{#2}% } % \end{macrocode} % Get the auto information for the |#1|-th domain. % \begin{macrocode} \def \PTR@auto@fetch #1{% \edef \TXN@temp {\@nameuse{PTR@#1@}}% \expandafter \PTR@auto@fetch@bis \TXN@temp } \def \PTR@auto@fetch@bis #1#2{% \dimen@ = #1\relax \dimen@@ = #2\relax } % \end{macrocode} % Compare the \texttt{textus} shift for this domain to the shift for the % previous two domains; if the difference is less than `delta', use % the previous shift. % \begin{macrocode} \def \PTR@auto@check@delta {% \TXN@counter = \PTR@versus@count \TXN@safe \ifnum \TXN@counter > \@ne \TXN@counter@a = \tw@ \ifnum \TXN@counter = \tw@ \TXN@counter@a = \@ne \fi \loop \advance \TXN@counter@a by \m@ne \advance \TXN@counter by \m@ne \PTR@auto@fetch {\the\TXN@counter}% \dimen@@ = \dimen@ \advance \dimen@@ by -\TXN@dim@a \ifdim \dimen@@ < \z@ \dimen@@ = -\dimen@@ \fi \ifdim .5\dimen@@ < \TXN@dim@b \TXN@dim@a = \dimen@ \TXN@xdef {PTR@\PTR@versus@count @}% {{\the\TXN@dim@a}{\the\TXN@dim@b}}% \TXN@counter@a = \z@ \fi \ifnum \TXN@counter@a > \z@ \repeat \fi } % \end{macrocode} % \section{The index of first lines} % % The first line is fetched from the source file. Two streams % are opened on the file and are read in parallel: on the first % the line is read with all punctuation characters made inactive % (the line is used to build the sort key) while on the second % it is read with punctuation characters keeping their % current |\catcode|, which may be |\active| (the line is printed % `as is' in the index). % % On both files, the lines preceding the line to be fetched are % read after setting the |\catcode| for braces to `other'. This % is necessary because some lines almost certainly contain unbalanced % braces. % \begin{macrocode} \def \PTR@process@first@line {% %<debug> \TXN@trace \PTR@process@first@line \TXN@get@page@column {\TXNl@linenumber}% \TXN@toks@a = {}% \TXN@toks@b = {}% \ifTXN@index@next@first@line \TXN@toks@b = \expandafter {\TXN@index@pending@key}% \fi % \end{macrocode} % Skip preceding lines in the source file % \begin{macrocode} \TXN@counter = \inputlineno \advance \TXN@counter by \m@ne \loop \ifnum \PTR@fl@count < \TXN@counter \begingroup \catcode`\{=12 \catcode`\}=12 \catcode`\^^M=5 \def \^^M{}% \global \advance \PTR@fl@count by \@ne \global \read \PTR@fl to \PTR@fl@line \global \read \PTR@fl@bis to \PTR@fl@line@bis \endgroup \repeat \PTR@read@first@line } % \end{macrocode} % % \begin{macrocode} \def \PTR@read@first@line {% %<debug> \TXN@trace \PTR@read@first@line \def \TXN@flags {l}% \begingroup \catcode`!=12 \catcode`?=12 \catcode`;=12 \catcode`:=12 \catcode`.=12 \catcode`,=12 \catcode`"=12 \catcode``=12 \catcode`'=12 \catcode`\^^M=5 \def \^^M{}% \global \read \PTR@fl to \PTR@fl@line \endgroup \begingroup \catcode`\^^M=5 \def \^^M{}% \global \read \PTR@fl@bis to \PTR@fl@line@bis \endgroup \PTR@write@index@file } % \end{macrocode} % % \begin{macrocode} \def \PTR@write@index@file {% \global \advance \PTR@fl@count by \@ne \TXN@make@sort@key {\PTR@fl@line}% \toks@ = \expandafter {\PTR@fl@line@bis}% \PTR@check@line@fragment {\the\toks@}% % \end{macrocode} % % \begin{macrocode} \ifx \@undefined \TXN@index@numeri@l \xdef \TXN@index@numeri@l {}% \fi \ifTXN@index@first@lines \immediate \write \TXN@idy {% {\the\TXN@toks@a\the\toks@i}{\the\toks@}% {\TXN@flags}{\TXN@page@number}{\TXN@index@numeri@l}}% \fi \ifTXN@index@next@first@line \ifx \empty \TXN@index@pending \else \PTR@write@index@pending \edef \TXN@temp {\toks@ = {\hskip 1em\relax\the\toks@}}% \TXN@temp \fi \immediate \write \TXN@idy {% {\the\TXN@toks@b\the\toks@i}{\the\toks@}% {\TXN@flags+}{\TXN@page@number}% {\TXN@index@numeri@l}% }% \fi % \end{macrocode} % Write all line fragments % \begin{macrocode} \if \TXN@option *\TXN@flags \edef \TXN@temp {\TXN@toks@a = {\the\TXN@toks@a\the\toks@i}}% \TXN@temp \edef \TXN@temp {\TXN@toks@b = {\the\TXN@toks@b\the\toks@i}}% \TXN@temp \expandafter \PTR@read@first@line \else \global \TXN@index@next@first@linefalse \fi } \def \PTR@write@index@pending {% \expandafter \PTR@write@index@pending@bis \TXN@index@pending } \def \PTR@write@index@pending@bis #1#2#3#4#5{% \immediate \write \TXN@idy {% {\the\TXN@toks@b\the\toks@i}{#2}{#3}{#4}{#5}}% \gdef \TXN@index@pending {}% } % \end{macrocode} % Check for a line fragment (|\\| at the end of the line) % If so, set the '*' flag. % \begin{macrocode} \def \PTR@check@line@fragment #1{% %<debug> \TXN@trace \PTR@check@line@fragment \count@ = \z@ \@tempcnta = \z@ \expandafter \PTR@check@line@fragment@bis #1\TXN@nil } % \end{macrocode} % Is |\\| the last token ? % \begin{macrocode} \def \PTR@check@line@fragment@bis #1{% \let \next = \PTR@check@line@fragment@bis \ifx \TXN@nil #1\relax \ifnum \count@ > \z@ \ifnum \@tempcnta = \count@ \edef \TXN@flags {\TXN@flags*}% \fi \fi \let \next = \relax \else \ifx \\#1\relax \advance \@tempcnta by \@ne \count@ = \@tempcnta \else \advance \@tempcnta by \@ne \fi \fi \next } %<*debug> % \end{macrocode} % \section{Debugging code} % \begin{macrocode} \def \PTR@do@showboxes {% \begingroup \fontfamily{cmr}\selectfont \hbadness = \@M \hfuzz=\maxdimen \count@ = \PTR@box@line \advance \PTR@box@ind by \@ne \loop \ifnum \count@ < \PTR@box@ind [% \expandafter \ifcase \csname PTR@box@type\the\count@\endcsname t\or p\or b\or pb\or s\else ?\fi \if \TXN@empty {PTR@box@flags\the\count@}% \else \edef \TXN@temp {\csname PTR@box@flags\the\count@\endcsname}% \ \texttt{\TXN@temp}% \fi ] % (\the\wd\count@) % \if \TXN@num {PTR@box@type\the\count@} = \PTR@box@split \else /\copy\count@/% \fi \advance \count@ by \@ne \endgraf \repeat \endgroup } \newif \ifPTR@showline \def \PTRshowline {\global \PTR@showlinetrue} % \end{macrocode} % % \begin{macrocode} \global \let \PTR@showboxes = \relax \def \PTRshowboxes #1{% \ifx +#1\relax \global \let \PTR@showboxes = \PTR@do@showboxes \else \global \let \PTR@showboxes = \relax \fi } %</debug> % \end{macrocode} %% \Finale % \endinput