texlive[68224] Master: ucph-revy (9sep23)
commits+karl at tug.org
commits+karl at tug.org
Sat Sep 9 22:10:33 CEST 2023
Revision: 68224
http://tug.org/svn/texlive?view=revision&revision=68224
Author: karl
Date: 2023-09-09 22:10:33 +0200 (Sat, 09 Sep 2023)
Log Message:
-----------
ucph-revy (9sep23)
Modified Paths:
--------------
trunk/Master/tlpkg/bin/tlpkg-ctan-check
trunk/Master/tlpkg/tlpsrc/collection-publishers.tlpsrc
Added Paths:
-----------
trunk/Master/texmf-dist/doc/latex/ucph-revy/
trunk/Master/texmf-dist/doc/latex/ucph-revy/Eksempel.tex
trunk/Master/texmf-dist/doc/latex/ucph-revy/Example.tex
trunk/Master/texmf-dist/doc/latex/ucph-revy/README.md
trunk/Master/texmf-dist/doc/latex/ucph-revy/Thumbindex.tex
trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf
trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf
trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf
trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf
trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy.bib
trunk/Master/texmf-dist/source/latex/ucph-revy/
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-doc.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-man.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-doc.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-man.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-da.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-en.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-thumb.ins
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.dtx
trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.ins
trunk/Master/texmf-dist/tex/latex/ucph-revy/
trunk/Master/texmf-dist/tex/latex/ucph-revy/ucph-revy.cls
trunk/Master/tlpkg/tlpsrc/ucph-revy.tlpsrc
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/Eksempel.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/Eksempel.tex (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/Eksempel.tex 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,121 @@
+%%
+%% This is file `Eksempel.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% ucph-revy.dtx (with options: `ex-da')
+%%
+%% See the generating file for its conditions on distribution and reuse.
+%%
+%% Also, for this file by itself, to the extent possible under law,
+%% Kristoffer Levin Hansen has waived all copyright and related or
+%% neighboring rights to Example.tex. This work is published from:
+%% Denmark.
+%%
+%% http://creativecommons.org/publicdomain/zero/1.0/
+%%
+%% Note that this file probably contains text, characters and situations
+%% covered by copyright beloninging to other entities.
+%%
+\documentclass{ucph-revy}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage[danish]{babel}
+\usepackage{hyperref}
+\urlstyle{sf}
+
+\version{1.0}
+\revyname{FysikRevy\texttrademark}
+\revyyear{2019}
+\status{eksempel}
+\eta{$1$ minut, $47$ sekunder}
+\responsible{Dig}
+
+\title{Eksempel}
+\author{en eksempelsmed}
+\melody{Queen: „Bohemian Rhapsody`` (\url{https://youtu.be/fJ9rUzIMcZQ})}
+
+\begin{document}
+\maketitle
+
+\begin{roles}
+ \role{PH}[Jophiel] Per Hedegaard
+ \role{I} Vred instruktør
+ \role{A9}[A--ni] Anine
+\end{roles}
+\begin{props}
+ \prop{Hedegaard--hår}[Person, der skaffer]
+ \prop{Didgeridoo}[Anine]
+\end{props}
+
+\begin{sketch}
+ \scene{Lys op}
+ \says{PH} Hej venner. I den her sketch, der spiller jeg Per
+ Hedegaard. Det kan man se ud fra farven på mit hår. Men bare rolig,
+ jeg er ikke Per Hedegaard i virkeligheden, der er ikke nogen
+ regneøvelser, I har glemt at lave.
+
+ Se, hvis jeg tager håret af \act{fjerner parykken}, så er det helt
+ tydeligt, at jeg ikke er den rigtige Hedegaard.
+
+ \says{I}[Stormer ind på scenen] \emph{NEEEEEJ}, for helvede. Du må
+ ikke pille ved den fjerde væg. Det er simpelthen så uprofessionelt,
+ det der!
+
+ \says{PH} Se, venner, det var meningen, at der skulle have været en
+ anden replik der, men fordi der ikke er sat nogen på den rolle i
+ rollelisten, så kunne vi ikke høre nogen som helst kritik af min
+ performance.
+
+ \does{I} reagerer med åbenmundet vantro.
+
+ \says{PH} Det må også være svært at følge skuepil--instruktioner,
+ når man ikke eksisterer, kan jeg forestille mig.
+
+ \says{A9} Hej Jophiel.
+ \does{PH} tager sin paryk på igen.
+ \says{A9} Hej, Per Hedegaard.
+ \says{A9} Var det ikke meningen, at det her skulle være en sang?
+ \says{PH} Jo, for dælen. Har du en didgeridoo med?
+ \says{A9} Didgeridoo?
+ \says{PH} Ja. Der står i rekvisitlisten, at du skaffer en.
+ \says{A9} Jamen så må det jo passe.
+ \says{PH} Ja, ellers skriver vi "`Person, der skaffer,"' for at
+ minde os om at skrive et navn ind.
+ \says{A9} Nå, men så må jeg jo hellere begynde at lede. \act{Vender
+ sig mod Bandet} Bandet, har I...?
+ \scene{Hvert bandmedlem holder sin egen didgeridoo op.}
+ \says{A9}[Til PH] Den ser ud til at være i vinkel.
+ \says{PH} Sejt.
+ \says{PH}[Råber til Bandet] Og \emph{tre!} \emph{Fire!}
+\end{sketch}
+\begin{song}%
+ \scene{Bandet spiller ``Bohemian Rhapsody" af Queen, udelukkende på
+ didgeridoo.}
+
+ \sings{A9} Åh, Per Hede
+ Er den lede
+ Og han dumped' mig i kvant!
+
+ \sings{PH} Per Hedegaard har er reeksamenssæt til dig
+ \sings{A9} Til mig?
+ \sings{PH} Til dig!
+ \scene{Episk didgeridoo--solo, mens A9 løser reeksamenssæt.}
+
+ \scene ...
+
+ \does{A9} rækker hånden i vejret, og bandet stopper.
+\end{song}%
+\begin{sketch}
+ \says{PH}[Er et stykke tid om at lægge mærke til A9, men kommer til
+ sidst over] Ja, spørgsmål?
+ \says{A9} Det her eksamenssæt er jo trivielt...?
+ \scene{Lys ned}
+\end{sketch}
+
+\end{document}
+\endinput
+%%
+%% End of file `Eksempel.tex'.
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/Eksempel.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/Example.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/Example.tex (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/Example.tex 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,148 @@
+%%
+%% This is file `Example.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% ucph-revy.dtx (with options: `ex-en')
+%%
+%% See the generating file for its conditions on distribution and reuse.
+%%
+%% Also, for this file by itself, to the extent possible under law,
+%% Kristoffer Levin Hansen has waived all copyright and related or
+%% neighboring rights to Example.tex. This work is published from:
+%% Denmark.
+%%
+%% http://creativecommons.org/publicdomain/zero/1.0/
+%%
+%% Note that this file probably contains text, characters and situations
+%% covered by copyright beloninging to other entities.
+%%
+\documentclass{ucph-revy}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage{hyperref}
+\urlstyle{sf}
+
+\version{1.0}
+\revyname{The Meaning of Liff}
+\revyyear{3001}
+\title{Example}
+\author{an examplesmith}
+\status{example}
+\eta{$1$ minute, $47$ seconds}
+\responsible{Probably you}
+\melody{Monty Python: ``Always look on the bright side of life''
+ (\url{https://youtu.be/SJUhlRoBL8M})}
+
+\writtenbyname{written by}
+\melodyname{Melody:}
+\responsibletext{\TeX--responsible}
+
+\renewcommand{\pagessum}[1]{#1 page\ifnum#1=1\else s\fi}
+
+\begin{document}
+\maketitle
+
+\rolename{Roles:}
+\begin{roles}
+ \role{KA}[Graham] Arthur, king of all the Britons
+ \role{P}[Michael] Peasant
+ \role{RC}[John] Roman Centurion
+ \role{R1...?} Several Roman Soldiers
+ \role{CC}[Eric] Crucified Criminal
+ \role{B}[Graham] Brian
+\end{roles}
+\propname{Props:}
+\begin{props}
+ \prop{Large sign}
+ \prop{Field of crosses}
+\end{props}
+
+\begin{sketch}
+ \scene Lights up on a muddy field with a castle in the background.
+
+ \says{KA}[As he enters] Hello!
+
+ \says{KA} Now, by rights, you should all be kneeling, given that I
+ am Arthur, king of all the Britons. However, it has been brought to
+ my attention that the audence seating is not laid out to allow for
+ that. We had some considerable trouble during dress rehearsals. So I
+ will excuse you from that requirement.
+
+ Now, has anyone seen a particularly fancy cup? Perhaps out
+ in the bar? You see, I am on a quest given to me by God, to find the
+ holy... \act{Interrupted, as he steps in a hole.} Oh dear...
+
+ \says{P}[Shrieking, as he rears up from the ground] Oi! What do you
+ think you're doing!
+
+ \says{P} You broke my sign!
+
+ \says{KA} Sign? What sign?
+
+ \says{P} Well, look.
+
+ \does{P} raises up a sign that reads
+
+ \begin{center}\sc Romanes Eunt Dom[ ]\end{center}
+
+ The last bit of the sign has a foot--shaped hole in it.
+
+ \says{P} You can't read it anymore!
+
+ \says{KA} You certainly can! It says ``Romans go home.''
+
+ \says{RC}[Appears from offstage] No it doesn't.
+
+ \does{P \& KA} are startled.
+
+ \says{RC}[To KA] Did you write th... wait a minute. \act{Off stage}
+ It's him! \act{Back at KA} How did you get here?
+
+ \does{KA} attempts to sidle away.
+
+ \says{RC} Get him!
+
+ \scene Several Roman soldiers appear, and drag \role{KA} off stage,
+ while \role{KA} attempts to protest.
+
+ \says{KA}[As he is dragged off] I am not him! I am Arthur, King of
+ the Britons!
+
+ \scene The scene changes to a field of crosses, with several
+ crucified criminals and B.
+
+ \does{CC} is in the middle of singing to \role{B}.
+\end{sketch}
+\begin{song}%
+ \sings{CC} ...be silly chumps,
+ Just purse you're lips and whistle,
+ That's the thing.
+
+ And, always look on the bright side of life,
+ Always look on the right side of life,
+ For life is quite absurd,
+ An. death's the final word...
+\end{song}
+\begin{sketch}
+ \says{RC}[Shouting as he walks on stage] Right, you lanky reprobate!
+ Don't think that the mighty Roman bureaucracy doesn't keep track of
+ its inmates
+
+ \scene KA is dragged on stage by two Roman soldiers behind RA.
+
+ \says{RA} Look, we have your designated cross ready for you
+ right... \act{points to B'a cross, then falters when he notices
+ B.}
+
+ \scene Everyone looks back and forth between B and KA.
+
+ \scene End scene
+\end{sketch}
+\end{document}
+}
+\endinput
+%%
+%% End of file `Example.tex'.
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/Example.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/README.md
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/README.md (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/README.md 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,81 @@
+Package ucph-revy
+=================
+v1.0.0
+
+A class for typesetting scripts, containing both lyrics and prose, in
+the style used by the student revues (revy) at the Faculties of
+Science at the University of Copenhagen (uchp).
+
+Installation
+------------
+
+To install the class, you should run the file
+
+ ucph-revy.ins
+
+through LaTeX. This will create the file `ucph-revy.cls`, which you
+should place in a location searched by LaTeX. In the TeX Directory
+Structure, it belongs in the folder `tex/latex/ucph-revy/`.
+
+Generating documentation
+------------------------
+
+You may want to generate either the user manual (which will provide
+instructions and examples on how to use the class) or the full
+documentation (which will provide the user manual along with a full
+source listing), in either danish or english.
+
+For each of these options, there is an `.ins` file that can be run
+through LaTeX. To get the indexes and citations right, you will need
+to run some combination of `bibtex` and `makeindex`, and then run the
+`.ins` file through LaTeX a few more times, until the references
+settle down. The individual `.ins` files should output instructions on
+the specific commands that need to be run to get them right, in their
+console output.
+
+The `.ins` files are:
+
+#### `ucph-revy-man-da.ins` ####
+- Creates the user manual in danish.
+
+#### `ucph-revy-doc-da.ins` ####
+- Creates the full documentation in danish.
+
+#### `ucph-revy-man-en.ins` ####
+- Creates the user manual in english.
+
+#### `ucph-revy-doc-en.ins` ####
+- Creates the full documentation in english.
+
+There are a few more `.ins` files, that pull some example `.tex` files
+out of the main `.dtx` file:
+
+#### `ucph-revy-ex-da.ins` ####
+- Creates `Eksempel.tex`, an example usage file in danish.
+
+#### `ucph-revy-ex-en.ins` ####
+- Creates `Example.tex`, and example usage file in english.
+
+#### `ucph-revy-ex-thumb.ins` ####
+- Creates `Thumbindex.tex`, a file that demonstrates how to use the
+ thumb index feature to create a thumb index page.
+
+Contact the author
+------------------
+
+As of 2023:
+
+[Kristoffer Levin Hansen](mailto:kristoffer at levinhansen.dk)
+
+License
+-------
+
+This file may be distributed and/or modified under the conditions of
+the LaTeX Project Public License, either version 1.3 of this license
+or (at your option) any later version. The latest version of this
+license is in:
+
+ <http://www.latex-project.org/lppl.txt>
+
+and version 1.3 or later is part of all distributions of LaTeX version
+2005/12/01 or later.
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/README.md
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/Thumbindex.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/Thumbindex.tex (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/Thumbindex.tex 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,50 @@
+%%
+%% This is file `Thumbindex.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% ucph-revy.dtx (with options: `registerindex')
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+
+\documentclass[a4paper,11pt,thumbindex]{article}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage[danish]{babel}
+\usepackage{calc}
+\usepackage{tikz}
+
+\version{1.0}
+\title{Registerindeks}
+
+\begin{document}
+\thispagestyle{empty}
+\newlength{\torightside}
+\setlength{\torightside}{ \paperwidth - 1in - \hoffset %
+ - \oddsidemargin + .6cm}
+\newlength{\totop}
+\setlength{\totop}{ -\headsep - \headheight - \topmargin %
+ - \voffset - 1in - .5cm}
+
+\vbox to 0pt{\vskip \totop \hbox to \torightside{\hss%
+ \rectothumbindexwithtitles%
+ }}
+\vbox to 0pt{\tikz \path (0,0) -- (0, -.5\textheight)
+ node[rotate=90]{\parbox{\textheight}{\maketitle}}; }
+\end{document}
+\endinput
+%%
+%% End of file `Thumbindex.tex'.
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/Thumbindex.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf
===================================================================
(Binary files differ)
Index: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf 2023-09-09 20:10:33 UTC (rev 68224)
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-doc.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf
===================================================================
(Binary files differ)
Index: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf 2023-09-09 20:10:33 UTC (rev 68224)
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-da-man.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf
===================================================================
(Binary files differ)
Index: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf 2023-09-09 20:10:33 UTC (rev 68224)
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-doc.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf
===================================================================
(Binary files differ)
Index: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf 2023-09-09 20:10:33 UTC (rev 68224)
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy-en-man.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy.bib
===================================================================
--- trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy.bib (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy.bib 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,27 @@
+ at Booklet{tttikz,
+ title = {The {TikZ} and {PGF} Packages},
+ author = {Till Tantau},
+ howpublished = {\url{https://mirrors.dotsrc.org/ctan/graphics/pgf/base/doc/pgfmanual.pdf}}}
+ at Book{tikz,
+ author = {Till Tantau},
+ title = {The {TikZ} and {PGF} Packages},
+ publisher = {\url{https://mirrors.dotsrc.org/ctan/graphics/pgf/base/doc/pgfmanual.pdf}},
+ year = 2023}
+ at InBook{eijkhout:toksstack,
+ author = {Victor Eijkhout},
+ title = {{\TeX} by Topic},
+ chapter = {14.5.1},
+ publisher = {\url{https://github.com/VictorEijkhout/tex-by-topic/raw/main/TeXbyTopic.pdf}},
+ year = 2019}
+ at InBook{eijkhout:hop,
+ author = {Victor Eijkhout},
+ title = {{\TeX} by Topic},
+ chapter = {13.8.6},
+ publisher = {\url{https://github.com/VictorEijkhout/tex-by-topic/raw/main/TeXbyTopic.pdf}},
+ year = 2019}
+
+ at Misc{overleaf:classpackage,
+ author = {Overleaf},
+ title = {Understanding packages and class files},
+ howpublished = {\url{https://www.overleaf.com/learn/latex/Understanding_packages_and_class_files}}}
+
Property changes on: trunk/Master/texmf-dist/doc/latex/ucph-revy/ucph-revy.bib
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-doc.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-doc.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-doc.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,39 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\makeatletter
+\begingroup
+ \input docstrip.tex
+ \batchinput{ucph-revy-ex-da.ins}
+\endgroup
+\def\revy at doclang{danish}
+\input{ucph-revy.dtx}
+\hypersetup{pdftitle=Dokumentation til klassen ucph-revy}
+\begin{document}
+\DocInput{ucph-revy.dtx}
+ \typeout{**************************************************}
+ \typeout{*}
+ \typeout{* Hvis du ikke allerede har gjort det, så har du}
+ \typeout{* nok lyst til at køre de følgende kommandoer, for}
+ \typeout{* at generere bibliografien, versionshistorien}
+ \typeout{* og indekset:}
+ \typeout{*}
+ \typeout{* \space bibtex ucph-revy-da-doc}
+ \typeout{* \space makeindex -s gind.ist -o ucph-revy-da-doc.ind ucph-revy-da-doc.idx}
+ \typeout{* \space makeindex -s gglo.ist -o ucph-revy-da-doc.gls ucph-revy-da-doc.glo}
+ \typeout{*}
+ \typeout{* Kør så denne fil igennem LaTeX igen.}
+ \typeout{*}
+ \typeout{* Happy TeXing!}
+ \typeout{**************************************************}
+\end{document}
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-man.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-man.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-da-man.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,38 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\makeatletter
+\begingroup
+ \input docstrip.tex
+ \batchinput{ucph-revy-ex-da.ins}
+\endgroup
+\def\revy at doclang{danish}
+\AtBeginDocument{\OnlyDescription}
+\input{ucph-revy.dtx}
+\hypersetup{pdftitle=Manual til klassen ucph-revy}
+\begin{document}
+\DocInput{ucph-revy.dtx}
+ \typeout{**************************************************}
+ \typeout{*}
+ \typeout{* Hvis du ikke allerede har gjort det, så har du}
+ \typeout{* nok lyst til at køre de følgende kommandoer, for}
+ \typeout{* at generere bibliografien og versionshistorien:}
+ \typeout{*}
+ \typeout{* \space bibtex ucph-revy-da-man}
+ \typeout{* \space makeindex -s gglo.ist -o ucph-revy-da-man.gls ucph-revy-da-man.glo}
+ \typeout{*}
+ \typeout{* Kør så denne fil igennem LaTeX igen.}
+ \typeout{*}
+ \typeout{* Happy TeXing!}
+ \typeout{**************************************************}
+\end{document}
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-doc.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-doc.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-doc.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,38 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\makeatletter
+\begingroup
+ \input docstrip.tex
+ \batchinput{ucph-revy-ex-en.ins}
+\endgroup
+\def\revy at doclang{english}
+\input{ucph-revy.dtx}
+\hypersetup{pdftitle=Documentation for the class ucph-revy}
+\begin{document}
+\DocInput{ucph-revy.dtx}
+ \typeout{**************************************************}
+ \typeout{*}
+ \typeout{* If you haven't already done so, you will want to}
+ \typeout{* run the following commands to generate the}
+ \typeout{* bibliography and version history:}
+ \typeout{*}
+ \typeout{* \space bibtex ucph-revy-en-doc}
+ \typeout{* \space makeindex -s gind.ist -o ucph-revy-en-doc.ind ucph-revy-en-doc.idx}
+ \typeout{* \space makeindex -s gglo.ist -o ucph-revy-en-doc.gls ucph-revy-en-doc.glo}
+ \typeout{*}
+ \typeout{* Then run this file through LaTeX again.}
+ \typeout{*}
+ \typeout{* Happy TeXing!}
+ \typeout{**************************************************}
+\end{document}
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-man.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-man.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-en-man.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,38 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\makeatletter
+\begingroup
+ \input docstrip.tex
+ \batchinput{ucph-revy-ex-en.ins}
+\endgroup
+\def\revy at doclang{english}
+\AtBeginDocument{\OnlyDescription}
+\input{ucph-revy.dtx}
+\hypersetup{pdftitle=Manual for the class ucph-revy}
+\begin{document}
+\DocInput{ucph-revy.dtx}
+ \typeout{**************************************************}
+ \typeout{*}
+ \typeout{* If you haven't already done so, you will want to}
+ \typeout{* run the following commands to generate the}
+ \typeout{* bibliography and version history:}
+ \typeout{*}
+ \typeout{* \space bibtex ucph-revy-en-man}
+ \typeout{* \space makeindex -s gglo.ist -o ucph-revy-en-man.gls ucph-revy-en-man.glo}
+ \typeout{*}
+ \typeout{* Then run this file through LaTeX again.}
+ \typeout{*}
+ \typeout{* Happy TeXing!}
+ \typeout{**************************************************}
+\end{document}
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-da.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-da.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-da.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,34 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\input docstrip.tex
+\keepsilent
+\usedir{tex/latex/ucph-revy}
+\askforoverwritefalse
+\preamble
+
+See the generating file for its conditions on distribution and reuse.
+
+Also, for this file by itself, to the extent possible under law,
+Kristoffer Levin Hansen has waived all copyright and related or
+neighboring rights to Example.tex. This work is published from:
+Denmark.
+
+http://creativecommons.org/publicdomain/zero/1.0/
+
+Note that this file probably contains text, characters and situations
+covered by copyright beloninging to other entities.
+
+\endpreamble
+\generate{\file{Eksempel.tex}{\from{ucph-revy.dtx}{ex-da}}}
+\endbatchfile
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-en.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-en.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-en.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,34 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\input docstrip.tex
+\keepsilent
+\usedir{tex/latex/ucph-revy}
+\askforoverwritefalse
+\preamble
+
+See the generating file for its conditions on distribution and reuse.
+
+Also, for this file by itself, to the extent possible under law,
+Kristoffer Levin Hansen has waived all copyright and related or
+neighboring rights to Example.tex. This work is published from:
+Denmark.
+
+http://creativecommons.org/publicdomain/zero/1.0/
+
+Note that this file probably contains text, characters and situations
+covered by copyright beloninging to other entities.
+
+\endpreamble
+\generate{\file{Example.tex}{\from{ucph-revy.dtx}{ex-en}}}
+\endbatchfile
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-thumb.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-thumb.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy-ex-thumb.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,34 @@
+%%
+%% Copyright (C) 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+%%
+\input docstrip.tex
+\keepsilent
+\usedir{tex/latex/ucph-revy}
+\askforoverwritefalse
+\preamble
+
+Copyright (C) 2023 Kristoffer Levin Hansen
+
+This file may be distributed and/or modified under the
+conditions of the LaTeX Project Public License, either
+version 1.3 of this license or (at your option) any later
+version. The latest version of this license is in:
+
+http://www.latex-project.org/lppl.txt
+
+and version 1.3 or later is part of all distributions of
+LaTeX version 2005/12/01 or later.
+
+\endpreamble
+\generate{\file{Thumbindex.tex}{\from{ucph-revy.dtx}{registerindex}}}
+\endbatchfile
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.dtx
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.dtx (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.dtx 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,3339 @@
+% \iffalse meta-comment
+%
+% Copyright (C) 1995 Arne John Glenstrup
+% 2000 Uffe Friis Lichtenberg
+% 2023 Kristoffer Levin Hansen
+%
+% This file may be distributed and/or modified under the
+% conditions of the LaTeX Project Public License, either
+% version 1.3 of this license or (at your option) any later
+% version. The latest version of this license is in:
+%
+% http://www.latex-project.org/lppl.txt
+%
+% and version 1.3 or later is part of all distributions of
+% LaTeX version 2005/12/01 or later.
+%
+%<*driver>
+\ProvidesFile{ucph-revy.dtx}
+%</driver>
+%<class>\NeedsTeXFormat{LaTeX2e}[2005/12/01]
+%<class>\ProvidesClass{ucph-revy}
+%<*class>
+ [2023/05/23 v1.0.0 Initial publish]
+%</class>
+%<*driver>
+\documentclass[a4paper]{ltxdoc}
+\makeatletter
+
+\usepackage[\revy at doclang]{babel}
+\usepackage{iflang}
+\usepackage{calc}
+\usepackage{fancyvrb}
+\usepackage{hypdoc}
+\usepackage{tabulary}
+\usepackage{tikz}
+\usepackage{caption}
+\DeclareCaptionFormat{revy}{%
+ \hfill{\bfseries\sffamily\small #1\hspace{-1cm}}
+
+ \footnotesize{#3}
+}
+\captionsetup[figure]{format=revy}
+\let\oldfigure=\figure
+\let\oldendfigure=\endfigure
+\renewenvironment{figure}[1][]{
+ \oldfigure[#1]
+ \rule{\textwidth + 1cm}{.5pt}
+
+ \vspace*{-.8em}\caption{}%
+ \let\oldcaption\caption
+ \def\caption##1{
+ \let\caption\oldcaption
+ \par\rule{\textwidth + 1cm}{1pt}
+ \par\vspace*{-.4em}
+ \caption*{##1}}%
+
+ \vspace*{-1.5em}%
+}{
+ \oldendfigure
+}
+\bibliographystyle{plain}
+\EnableCrossrefs
+\CodelineIndex
+\RecordChanges
+\long\def\jump#1\land{}
+\newenvironment{implementation}{%
+ \par\pagebreak[2]\noindent
+ \interlinepenalty 100%
+ \let\imppar=\par
+ \def\par{\penalty 100\imppar}%
+ \rule{\textwidth + 1cm}{.5pt}%
+ \makebox[0pt][r]{%
+ \hfill\small\raisebox{-1em}{\bfseries{\sffamily{%
+ \IfLanguageName{danish}{Implementering}{Implementation}%
+ }}}%
+ }\par\nopagebreak%
+}{%
+ \par\noindent%
+ \raisebox{.7em}{\rule{\textwidth + 1 cm}{1pt}}%
+ \par\pagebreak[2]%
+}
+\IfLanguageName{danish}{
+ \newenvironment{danish}{\relax}{\relax}
+ \newenvironment{english}{%
+ \long\def\totheend##1\end##2{%
+ \IfStrEq{english}{##2}{\end{english}}{\totheend}}%
+ \totheend
+ }{\relax}
+}{
+ \newenvironment{english}{\relax}{\relax}
+ \newenvironment{danish}{%
+ \long\def\totheend##1\end##2{%
+ \IfStrEq{danish}{##2}{\end{danish}}{\totheend}}%
+ \totheend
+ }{\relax}
+}
+\newenvironment{showcommand}{\quote}{\endquote}
+\usepackage{hyperref}
+\urlstyle{sf}
+%</driver>
+%<*class>
+%
+% \fi
+% \begingroup
+% ^^A we'll just hijack some functionality here...
+% \let\endinput\relax
+% \MaybeStop{
+% \gdef\implementation{%
+% \def\decide##1{%
+% \IfStrEq{implementation}{##1}%
+% {\end{implementation}}%
+% { \catcode`\{=12 \catcode`\}=12
+% \totheend
+% }
+% }
+% \long\def\totheend##1\end{%
+% \catcode`\{=1 \catcode`\}=2
+% \decide
+% }
+% \catcode`\{=12 \catcode`\}=12
+% \totheend
+% }
+% \gdef\endimplementation{\relax}
+% }
+%\endgroup
+%
+% \changes{v1.0.0}{2023/05/23}{Initial conversion to a class}
+%
+% \GetFileInfo{ucph-revy.dtx}
+%
+% \DoNotIndex{\#,\$,\%,\&,\@,\\,\{,\},\^,\_,\~,\ ,\,,\/,\TeX,\LaTeX}
+% \DoNotIndex{\@ne}
+% \DoNotIndex{\fi,\else}
+% \DoNotIndex{\advance,\begingroup,\catcode,\closein,\end,\begin}
+% \DoNotIndex{\closeout,\day,\def,\edef,\else,\empty,\endgroup,\xdef}
+% \DoNotIndex{\newcommand,\renewcommand,\newenvironment,\renewenvironment}
+%
+% \newcommand{\cn}{\textsf{ucph--revy}}
+%
+% \title{\begin{english}The \cn\ class\end{english}\begin{danish}
+% Klassen \cn\end{danish}\thanks{This document corresponds to
+% \cn~\fileversion, dated \filedate.}}
+% \author{Kristoffer Levin Hansen \\
+% \href{mailto:kristoffer at levinhansen.dk}{\sf kristoffer at levinhansen.dk}}
+%
+% \maketitle
+%
+% \begin{abstract}
+% \IfLanguageName{danish}{
+% En klasse, som kommer med kommer med kommandoerne til at typesætte
+% et manuskript i den stil, som bruges blandt SaTyR--revyerne ved
+% Science på Københavns Universitet. Tidligere kendt som
+% \texttt{revy.sty}.
+% }{
+% A \LaTeX\ class for typesetting scripts in the style used for
+% student theatric productions at the University of Copenhagen's
+% (ucph) science faculties. Formerly known to some as
+% \texttt{revy.sty}. }
+% \end{abstract}
+%
+% \tableofcontents
+%
+% \begin{figure}[p]
+% \centering
+% \newtoks\tabtoks
+% \tabtoks={\undertab 0\text Akt 1\stop\overtab 1\text Introsang\stop\overtab 2\text Eksempel\stop\overtab 3\text Example\stop\overtab 4\text Studiepolitisk indlæg\stop\undertab 4\text Akt 2\stop\overtab 5\text Noget om kvant\stop\overtab 6\text Sang til en forelæser\stop\undertab 6\text Ekstranumre\stop\overtab 7\text Under bæltestedet\stop\undertab 7\text\done\stop}
+% \edef\revy at tabs{\the\tabtoks}
+% \let\LARGE\small
+% \let\Large\footnotesize
+% \let\large\scriptsize
+% \tiny
+% \renewenvironment{document}{}{}
+% \IfLanguageName{danish}{\exDaPre}{}
+% \IfLanguageName{english}{\exEnPre}{}
+% \paperheight 90em
+% \def\rectoheaderthumbtab{%
+% \vspace*{-82em}
+% \revy at thumbindex{
+% \tabheight 11.5em
+% \def\overtableft{-0.4cm}
+% \def\overtabright{0.1cm}
+% \def\undertableft{\overtableft - 0.4cm}
+% \def\underlabeloffset{\undersign.2cm}
+% \filtername{\@title}
+% }
+% \hspace{-8.1em}%
+% }%
+% \begin{minipage}[t][\textheight]{\textwidth}
+% \vfill
+% \hspace{-4cm}
+% \fbox{
+% \hspace{1cm}
+% \begin{minipage}[t][81em]{.55\textwidth}
+% \def\getpagerefnumber#1{2}
+% \let\maketitle\class at maketitle
+% \vbox to 0pt{\vss
+% \hbox to \textwidth {\hfil\rectoheaderthumbtab }}
+% \vspace{8em}
+% \begin{danish}
+% \exDaPOne
+% \end{danish}
+% \begin{english}
+% \exEnPOne
+% \end{english}
+% \vspace{1em}
+% \end{minipage}
+% \hspace{1cm}
+% }
+% \fbox{
+% \hspace{1cm}
+% \begin{minipage}[t][81em]{.55\textwidth}
+% \ps at revyheadings
+% \let\thepage=2
+% \def\pageref#1{2}
+% \vspace{3em}
+% \@oddhead
+% \begin{danish}
+% \exDaPTwo
+% \exDaPThree
+% \exDaPFour
+% \end{danish}
+% \begin{english}
+% \exEnPTwo
+% \exEnPThree
+% \exEnPFour
+% \end{english}
+% \end{minipage}
+% \hspace{1cm}
+% }
+% \hspace*{-15cm}
+%
+% \vfill
+%
+% \caption{
+% \begin{danish}
+% Et eksempel på, hvad denne klasse kan bruges til at
+% lave.
+% \end{danish}
+% \begin{english}
+% An example of what this class can be used to create.
+% \end{english}
+% }\label{eksempel}\label{example}
+% \end{minipage}
+% \end{figure}
+%
+% \begin{danish}
+% \section{Introduktion}
+%
+% I umindelige tider har studenterrevyerne på KU Science brugt den
+% samme stil til at typesætte deres manuskripter. Den har indtil nu
+% boet i filen \texttt{revy.sty}, som er blevet det rundt mellem
+% revyster og revytter i andægtig stilhed. Den her klasse bibeholder
+% funtionaliteten fra \texttt{revy.sty}, men implementerer den nu i
+% dens korrekte plads i \LaTeX--hierakiet, som en
+% klasse\cite{overleaf:classpackage}, og med et mere beskrivende
+% navn, så den kan udgives i en pakkesamling.
+%
+% Klassen kan sætte både talt dialog og sangtekster, med
+% rolleangivelse, og kommer med en bestemt stil til titler,
+% sidehoveder og ting som rolle- og rekvisitlister.
+%
+% Et eksempel på, hvordan manuskripter skrevet i vores stil ser ud,
+% er gengivet i figur \ref{eksempel}. Den er tiltænkt til brug i en
+% revy, hvor hvert nummer lever sit eget liv indtil ret sent i
+% processen. Derfor er hvert nummer sit eget dokument, med egen
+% titel og andre informationer, og samlingen til et færdigt \TeX
+% hæfte er ikke inden for klassens emnefelt.
+%
+% Vi har også lavet en programpakke, som står for at lave et samlet
+% \TeX hæfte ud af en samling af \texttt{.tex}--filer (som bruger
+% den her dokumentklasse). Den er sidst set på adressen
+% \end{danish}
+% \begin{english}
+% \section{Introduction}
+%
+% A style of typesetting scripts in \LaTeX, originally developed for
+% DIKURevy, the students' revue at DIKU, the Computer Scinece
+% Institute at ucph, the University of Copenhagen. It has spread to
+% adjacent revues at ucph Science as they have sprung into
+% existence. Once known to its users as the package
+% \texttt{revy.sty}, that package has been transplanted into this
+% class, at the proper place in the \LaTeX\
+% hierarchy\cite{overleaf:classpackage}, practically in its
+% entirety.
+%
+% This class features the ability to set lines of dialogue and song
+% lyrics with a clearly associated indication of the speaker or
+% singer, along with stage directions. The style is intended for a
+% revue, which is formed out of a number of little pieces, so there
+% commands for typesetting a cast list and prop list, along with
+% relevant information like the time to perform, or the name of a
+% larger piece, which are intended to be typeset along with the
+% title.
+%
+% Figure \ref{eksempel} shown an example of how all this looks when
+% typeset.
+%
+% If you're looking for the script package that's designed to help
+% with typesetting and compositing a full manuscript, it was last
+% seen at
+% \end{english}^^A
+% \url{https://github.com/fysikrevy/fysikrevytex}.
+%
+% \begin{danish}^^A
+% Ifølge \texttt{revy.sty} var de originale forfattere
+% \end{danish}^^A
+% \begin{english}^^A
+% According to \texttt{revy.sty}, its origianl authors were
+% \end{english}^^A
+% Uffe Friis Lichtenberg, Arne John Glenstrup
+% \begin{danish}^^A
+% og
+% \end{danish}^^A
+% \begin{english}
+% and
+% \end{english}^^A
+% Anders Komár Ravn.
+%
+% \PrintChanges
+%
+% \begin{danish}
+% \section{Brugsvejledning}
+% Et eksempel på en \texttt{.tex}-fil, som kan bruges til at
+% producere noget nær det i figur \ref{eksempel}, er gengivet i sin
+% helhed i appendiks \ref{fullex}, eller filen
+% \texttt{Eksempel.tex}, som \LaTeX\ burde have produceret sammen
+% med den fil, som du læser nu. Her gennemgår vi nogle af
+% højdepunkterne, for at forstå hvordan klassen kan bruges.
+% \end{danish}
+% \begin{english}
+% \section{Usage}
+% An example of a \texttt{.tex} file that will typeset something
+% like figure \ref{example} is presented in appendix \ref{fullex},
+% or in the file \texttt{Example.tex}, which should have been
+% produced by \LaTeX\ alongside the documentation file that you are
+% reading. In the present section, we'll hit some of the highlights
+% of that file, to understand how it works.
+% \end{english}
+% \begin{danish}
+% \subsection{Invokering og valgmuligheder}
+% Klassen (ned)kaldes, ved at starte en \texttt{.tex}--fil med
+% \end{danish}
+% \begin{english}
+% \subsection{Invoking and arguments}
+% First, to use the \cn\ class in a \verb|.tex| file, that file must
+% start with
+% \end{english}
+%
+% \begin{verbatim}
+% \documentclass{ucph-revy}
+% \end{verbatim}
+%
+% \begin{danish}
+% \cn\ nedarver fra \DescribeMacro{article}
+% \textsf{article}--klassen, så alle valgmuligheder, som godtages af
+% \texttt{article} godtages også af \cn. Som standard vælger \cn\
+% \texttt{a4paper} og \texttt{11pt}, fra \textsf{article}'s
+% valgmuligheder, hvis \cn\ ikke bliver kaldt med nogen
+% valgmuligheder, som er i modstrid med dem.
+%
+% Derudover tilføjer \cn\
+% valgmulighederne \DescribeMacro{thumbindex} \verb|thumbindex|
+% og \DescribeMacro{planfile=} \verb|planfile|, som tilføjer
+% registermærkninger og lader forfatteren ændre hvilken fil
+% registermærkningerne bliver bygget ud fra. Hvad det mere specifikt
+% betyder bliver gennemgået i sektion \ref{thumbindex}.
+% \end{danish}
+% \begin{english}
+% \cn\ inherits from the \texttt{article}\DescribeMacro{article}
+% class, and accepts all its options. It sets \texttt{a4paper} and
+% \texttt{11pt} by default, if not given any contrary options.
+%
+% In addition, \cn\ add the options
+% \DescribeMacro{thumbindex} \verb|thumbindex|
+% and \DescribeMacro{planfile=}\verb|planfile|, which activates the
+% construction of thumb indexes in the file and allows setting the
+% file that the thumb index is built from. We'll go through exactly
+% how this works in seciton \ref{thumbindex}.
+% \end{english}
+%
+% \begin{implementation}
+% \label{loadclass}
+% \begin{danish}
+% Vi håndterer valgmuligheder til klassen her, i starten af
+% filen. Vi skal bruge den her pakke.
+% \end{danish}
+% \begin{english}
+% We handle class options here, at the start of the file. To do
+% so, we need this package.
+% \end{english}
+% \begin{macrocode}
+\RequirePackage{xstring}
+% \end{macrocode}
+% \begin{macro}{\if at thumbindex}
+% \begin{danish}
+% Kommer til at holde styr på, om \verb|thumbindex| er givet. Vi
+% kommer til at gøre noget med den nede i sektion
+% \ref{thumbindex}.
+% \end{danish}
+% \begin{english}
+% Keeps track of \verb|thumbindex|. We will do stuff with it
+% when we get to section \ref{thumbindex}.
+% \end{english}
+% \begin{macrocode}
+\newif\if at thumbindex\@thumbindexfalse
+% \end{macrocode}
+% \end{macro}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+% \fi
+% \begin{danish}
+% Og nu kan vi definere valgmulighederne:
+% \end{danish}
+% \begin{english}
+% And now we're ready to define the arguments:
+% \end{english}
+% \begin{macro}{thumbindex}
+% \begin{macrocode}
+\DeclareOption{thumbindex}{\@thumbindextrue}
+% \end{macrocode}
+% \end{macro}
+% \begin{macro}{planfile=}
+% \begin{danish}
+% Tager en tekststreng, så den skal behandles helt
+% specielt. \textsf{xstring} definerer bl.a. makroen
+% \verb|\IfBeginWith|.
+% \end{danish}
+% \begin{english}
+% Takes a text string, and
+% so needs particular treatment. \textsf{xstring} defines, among
+% other things, the macro \verb|\IfBeginWith|
+% \end{english}
+% \begin{macrocode}
+\newcommand{\planfile}{aktoversigt.plan}
+\DeclareOption*{
+ \IfBeginWith{\CurrentOption}{planfile=}{
+ \def\planfile#1=#2{#2}
+ \edef\planfile{\expandafter\planfile\CurrentOption}
+ }{
+ \PassOptionsToClass{\CurrentOption}{article}
+ }
+}
+\ProcessOptions\relax
+\LoadClass[a4paper,11pt]{article}
+% \end{macrocode}
+% \end{macro}
+% \end{implementation}
+%
+% \begin{implementation}
+% \begin{danish}
+% De her kommandoer gør tekstblokken højere.
+% \end{danish}
+% \begin{english}
+% These commands make the text block taller.
+% \end{english}
+% \begin{macrocode}
+\setlength{\topmargin}{0cm}
+\setlength{\voffset}{-1cm}
+\setlength{\textheight}{\paperheight}
+\addtolength{\textheight}{-4cm}
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{danish}
+% I eksemplet inkluderer vi fire pakker. De er ikke strengt
+% nødvendige for at få \cn\ til at fungere, men de kommer næsten med
+% sikkerhed til at gøre dit liv lettere.
+%
+% \medskip\noindent\begin{tabulary}{\textwidth}{lL}
+% \verb|\usepackage[utf8]{inputenc}| & \\
+% \verb|\usepackage[T1]{fontenc}| &
+% Gør \LaTeX's håndtering af danske bogstaver mere moderne. \\
+% \verb|\usepackage[danish]{babel}| &
+% Fortæller \LaTeX\ en masse ting om dansk, bl.a. hvordan
+% man bryder ord.\\
+% \verb|\usepackage{hyperref}| &
+% Giver mulighed for at lave links, som det til Youtube i
+% figur \ref{eksempel}.\\
+% \verb|\urlstyle{sf}| &
+% Gør, at links bliver sat med \textsf{sans serif} tekst
+% i stedet for \texttt{monospace}.
+% \end{tabulary}
+% \end{danish}
+% \begin{english}
+% In the example, we've included three packages that aren't strictly
+% necessary for \cn\ to function, but will probably make your life
+% easier.
+%
+% \medskip\noindent\begin{tabulary}{\textwidth}{lL}
+% \verb|\usepackage[utf8]{inputenc}| & \\
+% \verb|\usepackage[T1]{fontenc}| &
+% Modernize \LaTeX's handling of (particularly special)
+% characters.\\
+% \verb|\usepackage{hyperref}| &
+% Enables the creation of hyperlinks, like the one in
+% figure \ref{example}.\\
+% \verb|\urlstyle{sf}| &
+% Demands that hyperlinks be set in \textsf{sans serif},
+% rather than \texttt{monospace}
+% \end{tabulary}
+% \end{english}
+%
+% \begin{danish}
+% \subsection{Registermærkninger}\label{thumbindex}
+%
+% \changes{v1.0.0}{2023/09/05}{Nyt maskineri til registermærkninger}
+% Kasserne i kanten af siderne i figur \ref{eksempel} er
+% registermærkninger. De er tænkt som en hjælp med at finde rundt i
+% manuskripter, når de bliver sat sammen af flere enkelte numre, som
+% hver især bruger \cn. De giver kun mening at bruge i dokumenter
+% som er en del af en større samling, så for at sætte dem skal
+% klassen gives
+% valgmuligheden \DescribeMacro{thumbindex}\verb|thumbindex|.
+% \end{danish}
+% \begin{english}
+% \subsection{Thumb index}\label{thumbindex}
+%
+% \changes{v1.0.0}{2023/09/05}{New machinery for thumb indexes}
+% To help organizing a compiled manuscript, which might consist of a
+% collection of many \texttt{.tex} files, we profide a facility for
+% creating a thumb index in the typeset margins. That's the gray and
+% black boxes on the edge of the pages in figure \ref{eksempel}. It
+% is off by default, since it only really makes sense in a
+% compilation of documents, but is enabled by giving the
+% option \DescribeMacro{thumbindex}\verb|thumbindex| to the class.
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% \verb|\if at thumbindex|\DescribeMacro{\if at thumbindex}\ blev
+% defineret på side \pageref{loadclass}, og fortæller bare, om
+% \verb|thumbindex| er blevet valgt. Hvis den ikke er, så
+% springer vi al koden i det her afsnit over.
+% \end{danish}
+% \begin{english}
+% \verb|\if at thumbindex|\DescribeMacro{\if at thumbindex}\ was defined
+% on page \pageref{loadclass}, and just tells us if the option
+% \verb|thumbindex| was given. If it wasn't, well just skip
+% all the code in this section.
+% \end{english}
+% \begin{macrocode}
+\if at thumbindex
+ \expandafter\@firstofone
+\else
+ \expandafter\@gobble
+\fi{
+% \end{macrocode}
+% \end{implementation}
+% \label{begintabdefgroup}
+%
+% \begin{danish}
+% \cn\ får at vide hvilke numre, som er med i et manuskript, fra en
+% ekstern tekstfil, som vi som standard går ud fra hedder
+% \texttt{aktoversigt.plan}, og ligger i samme mappe som
+% \texttt{.tex}--dokumentet. Hvis det ikke passer, kan det laves om,
+% ved at give
+% valgmuligheden \DescribeMacro{planfile=}\verb|planfile=|\meta{filnavn}
+% til pakken. Så for eksempel, hvis planfilen ligger i mappen over
+% \texttt{.tex}--dokumentet og hedder \texttt{plan.txt}, kan pakken
+% kaldes således:
+% \end{danish}
+% \begin{english}^^A
+% The structure of the consolidated manuscript is
+% defined in a seperate text file, which contains the filenames of
+% the \texttt{.tex} files that make up the manuscript, and divide
+% the show into sections with their own headings. By default, we
+% assume that the plan file is in the same folder as the current
+% \texttt{.tex} file, and named \verb|aktoversigt.plan|. This may be
+% changed by
+% passing \DescribeMacro{planfile=}\verb|planfile=|\meta{filename}
+% as a parameter to the class. Calling both these options might look
+% like so:
+% \end{english}
+% \begin{verbatim}
+%\documentclass[thumbindex,planfile=../plan.txt]{ucph-revy}
+% \end{verbatim}
+% \begin{danish}
+% Et eksempel på en sådan planfil kunne være:
+% \begin{verbatim}
+% Akt 1
+% sange/introsang.tex
+% sketches/Eksempel.tex
+% sketches/studiepolitisk_indlæg.tex
+%
+% Akt 2
+% sketches/noget_om_kvant.tex
+% sange/sang_til_en_forelæser.tex
+%
+% Ekstranumre
+% sange/under_bæltestedet.tex
+% \end{verbatim}
+% Mappenavnene (\texttt{sange}, \texttt{sketches}) er ikke
+% nødvendige for at registermærkningerne kan fungere, de er bare et
+% eksempel. \texttt{.tex}--filerne kan placeres hvor som helst,
+% \TeX\ kan læse fra.
+%
+% Ud fra sådan en planfil kan klassen generere et
+% register\textbf{indeks} som ligner det i figur \ref{registerex},
+% eller register\textbf{mærkninger} som dem i figur
+% \ref{eksempel}. De titler, som er vist i figur \ref{registerex},
+% finder \cn\, ved at læse \verb|\title|--makroen i de filer, som er
+% angivet i planfilen.
+%
+% \begin{figure}[hbtp]
+% \paperheight 18em
+% \tabtoks={\undertab 0\text Akt 1\stop\overtab 1\text Introsang\stop\overtab 2\text Eksempel\stop\overtab 3\text Studiepolitisk indlæg\stop\undertab 3\text Akt 2\stop\overtab 4\text Noget om kvant\stop\overtab 5\text Sang til en forelæser\stop\undertab 5\text Eks.\stop\overtab 6\text Under bæltestedet\stop\undertab 6\text\done\stop}
+% \edef\revy at tabs{\the\tabtoks}
+% \hfill\rectothumbindexwithtitles
+% \caption{Et eksempel på et indeks til registermærkninger. I brug
+% er det tænkt til at fylde hele siden i højden, så mærkningernes
+% placering matcher registermækrningerne (som i figur
+% \ref{eksempel}).}
+% \label{registerex}
+% \end{figure}
+%
+% For at sætte et registermærke i et enkelt dokument, altså som i
+% figur \ref{eksempel}, skal \cn\ vide hvor den aktuelle fil er i
+% rækkefølgen. For at finde ud af det, læser den hver fil, som er
+% oplistet i planfilen, og sammenligner indholdet af deres
+% \verb|\title|--makroer med den seneste \verb|\title|, som \TeX\
+% har set.
+%
+% Derfor er det nødvendigt, for at \cn\ kan sætte registermærkerne,
+% at der er angivet en \verb|\title|. Det er altid den sidste
+% \verb|\title| i en fil, som \cn\ sammenligner med den
+% \verb|\title|, som \TeX\ kender. Det kan gå galt, hvis der er
+% flere \verb|\title|'r i en fil.
+%
+% Hvis der er flere af filerne i planfilen, som har den
+% \verb|\title| som \cn\ leder efter, vil \cn\ sætte registermærker
+% for alle de tilsvarende pladser i rækkefølgen.
+% \end{danish}
+%
+% \begin{english}
+% An example of such a plan file might be:
+% \begin{verbatim}
+% Act 1
+% songs/opener.tex
+% sketches/Example.tex
+% sketches/anarchocommunist_commune.tex
+%
+% Act 2
+% songs/glitzy_dance_act.tex
+% sketches/crossdressing.tex
+%
+% Act 3
+% sketches/stop_police.tex
+% \end{verbatim}
+% Note that the folder names (\texttt{songs}, \texttt{sketches}) are
+% merely for illustration. The \texttt{.tex} files can be placed at any
+% location that \TeX\ can read.
+%
+% From this plan file, the class can generate a thumb mark for each
+% of thsee individual files, as demonstrated in figure
+% \ref{eksempel}, which shows the location of that file in the
+% larger structure of the piece. It can also generate a thumb index,
+% as demonstrated in figure \ref{thumbindexex}, which outlines the
+% location of every part of the piece, and can serve as an aide to
+% navigation.
+%
+% \begin{figure}[hbtp]
+% \paperheight 18em
+% \tabtoks={\undertab 0\text Act 1\stop\overtab 1\text Opener\stop\overtab 2\text Example\stop\overtab 3\text Anarchocommunist Commune\stop\undertab 3\text Act 2\stop\overtab 4\text Non--sequitor Dance Act\stop\overtab 5\text Find a Reason to Dress as Ladies\stop\undertab 5\text Act 3\stop\overtab 6\text Stop, Police\stop\undertab 6\text\done\stop}
+% \edef\revy at tabs{\the\tabtoks}
+% \hfill\rectothumbindexwithtitles
+% \caption{An example thumb index. This example is compressed
+% vertically. It is intended to be nearly the height of the page,
+% to match the thumb markings (such as the ones in figure
+% \ref{eksempel}).}
+% \label{thumbindexex}
+% \end{figure}
+%
+% The titles in the thumb index demonstrated in figure
+% \ref{thumbindexex} are taken from the content of the \verb|\title|
+% macro in the files listed in the plan file. Also, the routine for
+% setting the thumb mark for an individual file determine
+% \emph{which} file it is in by comparing the content of the
+% \verb|\title| macro in the files in the plan file with the title
+% that \TeX\ knows about in the current file.
+%
+% Therefore, it is necessary for the thumb index to work that a
+% \verb|\title| is declared in each of the files that are listed in
+% the plan file.
+%
+% If there are more than one \verb|\title| invocations in a file,
+% the thumb index routine will use the last one. If several of the
+% files in the plan file have the same name, those files will end up
+% with several thumb marks.
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% For at sammenligningen kan fungere, er vi afhængige af, at
+% tekstrepræsentationen ikke skifter undervejs. Det kan ske, hvis
+% \verb|.tex|--filen kalder \textsf{fontenc}, og titlerne
+% indeholder specialtegn. Den simple og effektive\footnote{Læs:
+% det er et hack, som ikke har givet mig problemer \emph{endnu}.}
+% løsning er bare at kalde \textsf{fontenc} selv, så der ikke er
+% plads til misforståelser.
+% \end{danish}
+% \begin{english}
+% For this comparing of titles to work, we depend of the text
+% representation not changing between the \verb|\title|
+% declaration and the time when the thumb index routine runs. It
+% might, though, if \textsf{fontenc} is called. To quickly knock
+% that problem on the head,\footnote{In a way that hasn't come
+% back to bite \emph{me} yet.} we'll just call \textsf{fontenc}
+% ourselves.
+% \end{english}
+% \begin{macrocode}
+ \RequirePackage[T1]{fontenc}
+% \end{macrocode}
+%
+% \begin{danish}
+% Koden, som læser og forstår planfilen og de andre
+% \verb|.tex|--filer bor i den her gruppe. I sidste ende kommer vi
+% til at definere
+% makroen \DescribeMacro{\revy at tabs}\verb|\revy at tabs|, som burde,
+% for hver overskrift i planfilen, indeholde sekvensen
+% \begin{showcommand}
+% \verb|\undertab| \meta{tæller ved start} \verb|\text|
+% \meta{overskrift} \verb|\stop|,
+% \end{showcommand}
+% for hvert filnavn i planfilen indeholde sekvensen
+% \begin{showcommand}
+% \verb|\overtab| \meta{tæller} \verb|\text|
+% \meta{titel i fil} \verb|\stop|,
+% \end{showcommand}
+% og som afslutning sekvensen
+% \begin{showcommand}
+% \verb|\undertab| \meta{antal filer} \verb|\text| \verb|\done|
+% \verb|\stop|.
+% \end{showcommand}
+% Undervejs bygger vi de her sekvenser op i en
+% \verb|toks|. Konstruktionen, hvor \verb|\act| bliver defineret, og
+% så kaldt med det samme, er for at styre, hvor dybt \TeX\ udvider
+% vores makroer\cite{eijkhout:toksstack}.
+% \end{danish}
+% \begin{english}
+% The code that reads and comprehends the plan file and the listed
+% \texttt{.tex} files lives in this group. The ultimate effect ought
+% to be defining the
+% macro \DescribeMacro{\revy at tabs}\verb|\revy at tabs|, which will
+% contain, for each heading in the plan file, the sequence
+% \begin{showcommand}
+% \verb|\undertab| \meta{counter at start} \verb|\text|
+% \meta{hading} \verb|\stop|,
+% \end{showcommand}
+% for each file name in the plan file, the sequence
+% \begin{showcommand}
+% \verb|\overtab| \meta{counter} \verb|\text|
+% \meta{title in file} \verb|\stop|,
+% \end{showcommand}
+% and finally the sequence
+% \begin{showcommand}
+% \verb|\undertab| \meta{no. of files} \verb|\text| \verb|\done|
+% \verb|\stop|.
+% \end{showcommand}
+% As we go, these sequences will be built up in a \verb|toks|. The construction where \verb|\act| is defined, and then immediately called, controls how deeply \TeX\ will expand our macros\cite{eijkhout:toksstack}.
+% \end{english}
+% \begin{macrocode}
+ \begingroup
+% \end{macrocode}
+% \begin{macrocode}
+ \count256=0
+ \endlinechar=-1
+ \newtoks\tabtoks
+ \newread\tabtex
+ \newread\planread
+ \openin\planread=\planfile
+% \end{macrocode}
+% \begin{macrocode}
+ \def\expandFiHere#1\fi{\fi #1}
+% \end{macrocode}
+% \begin{macrocode}
+ \def\patheat#1/#2{%
+ \ifx\relax#2\else
+ \expandFiHere#1/\patheat#2%
+ \fi
+ }
+ \edef\planpath{\expandafter\patheat\planfile/\relax}
+% \end{macrocode}
+% \begin{macrocode}
+ \def\titleeater#1#2\title#3{%
+ \ifx\done#3%
+ #1%
+ \else
+ \expandFiHere
+ \titleeater{#3}%
+ \fi
+ }
+% \end{macrocode}
+% \begin{danish}
+% Her i \verb|\loop|'et tjekker vi først, om vi er færdige med
+% planfilen (\verb|\repeat| kobler på den \verb|\else|, som hører
+% til den første \verb|\ifeof|. Hvis den \verb|\ifeof| er sand, så
+% læser \TeX\ kun den \verb|\fi|, som er gemt inde i
+% \verb|\repeat|, og kalder ikke den rekursion, som også ligger
+% derinde. Jeg prøver at forklare det her for mig selv, for jeg
+% bliver forvirret hver gang jeg vender tilbage til den her
+% konstruktion.) Så tjekker vi, om der {\em ikke} er en åben fil i
+% \verb|\tabtex|. Hvis ikke, prøver vi at greje den næste linje i
+% planfilen. Ellers leder vi efter \verb|\title|--kald i filen i
+% \verb|\tabtex| (og håber, at det ikke spænder over flere
+% linjer).
+% \end{danish}
+% \begin{english}
+% In this loop, we read the plan file plan file line by line. If the
+% line ends in \texttt{.tex}, we take it as a file name, and open
+% that file, looking for \verb|\title| commands, which hopefully do
+% not span across any line breaks.
+% \end{english}
+% \begin{macrocode}
+ \loop\ifeof\planread
+ \closein\planread
+ \else
+ \ifeof\tabtex
+ \let\readline\empty
+ \read\planread to \line
+ \expandafter\ifx\expandafter\par\line\else
+ \IfEndWith{\line}{.tex}{
+ \advance\count256 by 1
+% \end{macrocode}
+% \begin{danish}
+% \verb|\set at curr@file| tager sig af problemer med catcode'er.
+% \end{danish}
+% \begin{english}
+% \verb|\set at curr@file| beats down issues with catcodes in
+% filenames.
+% \end{english}
+% \begin{macrocode}
+ \set at curr@file{\line}
+ \openin\tabtex={\planpath\@curr at file}
+ }{%
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\undertab
+ \number\count256
+ \noexpand\text
+ \line
+ \noexpand\stop
+ }}\act
+ }
+ \fi
+ \else
+ \read\tabtex to \subline
+ \edef\readline{%
+ \expandafter\titleeater
+ \expandafter\readline\subline\title\done
+ }
+ \ifeof\tabtex
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\overtab
+ \number\count256
+ \noexpand\text
+ \readline
+ \noexpand\stop
+ }}\act
+ \fi
+ \fi
+ \repeat
+ \closein\tabtex
+% \end{macrocode}
+%
+% \begin{danish}
+% Afslutningssekvensen:
+% \end{danish}
+% \begin{english}
+% The final sequence:
+% \end{english}
+% \begin{macrocode}
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\undertab
+ \number\count256
+ \noexpand\text
+ \noexpand\done
+ \noexpand\stop
+ }}\act
+% \end{macrocode}
+% \begin{macro}{\revy at tabs}
+% And then, the money shot.
+% \begin{macrocode}
+ \xdef\revy at tabs{\the\tabtoks}
+% \end{macrocode}
+% \end{macro}
+% \begin{macrocode}
+ \endgroup
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{danish}
+% I eksemplet i appendiks \ref{fullex} er \verb|thumbindex| ikke
+% taget med, fordi det kun rigtig giver mening at lave
+% registermærkninger i en samling af manuskripter. Men hvis der
+% ligger en fil i samme mappe som eksempelfilen, som hedder
+% \texttt{aktoversigt.plan}, hvor indholdet er eksemplet fra før, og
+% hvis invokeringen i eksempelfilen skiftes ud med
+% \end{danish}
+% \begin{english}
+% The thumbindex hasn't been enabled in the example file in appendix
+% \ref{fullex}, since there's nothing to index. However, if you were
+% to place the example plan file above in a file along side
+% \texttt{Example.tex} named \texttt{aktoversigt.plan}, and replace
+% the class invocation at the top of \texttt{Example.tex} with
+% \end{english}
+% \begin{verbatim}
+%\documentclass[thumbindex]{ucph-revy}
+% \end{verbatim}
+% \begin{danish}
+% så burde \texttt{.tex}--filen kompilere til et resultat, som har
+% registermærkninger ligesom i eksemplet i figur
+% \ref{eksempel}. Manglende filer bliver bare ignoreret.
+%
+% Det lyder måske som en god idé at have en side med et register,
+% som ligner det i figur \ref{registerex}, men som passer i
+% størrelsen til de mærkninger, som bliver sat i den enkelte
+% manuskriptfil. Et eksempel på hvordan man kunne lave en side med
+% sådan et registerindeks findes i appendiks
+% \ref{registerindeks}. Hvis du har adgang til klassens kildefiler
+% kan du også trække den kode ud i filen \texttt{Thumbindex.tex},
+% ved at køre filen \texttt{upch-revy-ex-thumb.ins} igennem \LaTeX.
+% \end{danish}
+% \begin{english}
+% then the typeset result should have a thumb marking like the one
+% in figure \ref{example}. Nonexistent files are simply ignored when
+% constructing the thumb index.
+%
+% You might also like to have a page with an index of the thumb
+% markings, something similar to figure \ref{thumbindexex}, but
+% scaled to a full page. Appendix \ref{registerindeks} hold a
+% complete example of one way to make a page like that. If you have
+% access to the package's source files, you can also extract that
+% code as the file \texttt{Thumbindex.tex}, by running the file
+% \texttt{ucph-revy-ex-thumb.ins} through \LaTeX.
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% \textsf{Ti{\em k}Z} er ikke et tegneprogram\cite{tikz}, men vi
+% bruger den alligevel til at tegne registermærkningerne.
+% \end{danish}
+% \begin{english}
+% \textsf{Ti{\em k}Z} is not a drawing program\cite{tikz}, but we'll
+% use it to draw our thumbtabs regardless.
+% \end{english}
+% \begin{macrocode}
+ \RequirePackage{tikz}
+% \end{macrocode}
+%
+% \begin{macro}{\revy at thumbindex}
+% \begin{danish}
+% Den her makro indeholder alle procedurene, som typesætter
+% registermærkningerne. Argumentet bliver ekspanderet lige før
+% typesætningen rent faktisk finder sted, så makroens interne
+% tilstand kan justeres. Læg særligt mærke til makroerne
+% \verb|\filter|, \verb|\movetoleftside| og
+% \verb|\writetitlestrue|, som bliver defineret internt i makroen,
+% og som lave om på hvilke dele af registermærkerne, som bliver
+% typesat. Makroerne, som bliver defineret på side
+% \pageref{thumbindexuse} og frem, demonstrerer hvordan de
+% bruges.
+%
+% Vi kommer til at se den fremgangsmåde, at der bliver lavet
+% definitioner af \verb|\undertab| og \verb|\overtab|, som vi
+% bagte ind i \verb|\revy at tabs| i den forrige kodeblok, der gør
+% det arbejde, vi ønsker at få lavet, når \verb|\revy at tabs| bliver
+% ekspanderet.
+% \end{danish}^^A
+% \begin{english}^^A
+% This macro contains the procedures that typeset
+% the thumb index. Its argument is expanded immediately before the
+% thumb tabs are actually typeset, allowing you to modify the
+% macro's internal state at that point. For this purpose, you'll
+% want to pay special attention to the macros \verb|\filter|,
+% \verb|\movetoleftside| and \verb|\writetitlestrue|, which will
+% be defined internally in this macro, and alter which parts of
+% the thumbindex are typeset.
+%
+% The approach that we will see used, as we go through the macro,
+% is to define \verb|\undertab| and \verb|\overtab| in such a way
+% that they perform the tasks that we want to see performed, when
+% we expand \verb|\revy at tabs|.
+% \end{english}
+% \iffalse
+%<*driver>
+}
+\land
+%</driver>
+% \fi
+% \begin{macrocode}
+ \def\revy at thumbindex#1{%
+ \begingroup
+% \end{macrocode}
+% \begin{macro}{\expandFiHere}
+% \begin{danish}
+% Du genkender måske den her som \verb|\hop|, hvis du har læst
+% \cite{eijkhout:hop}.
+% \end{danish}
+% \begin{english}
+% You man reckognize this one as \verb|\hop| if you've read
+% \cite{eijkhout:hop}.
+% \end{english}
+% \begin{macrocode}
+\def\expandFiHere##1\fi{\fi ##1}
+% \end{macrocode}
+% \end{macro}
+% \begin{danish}
+% Find ud af hvor højt et enkelt mærke skal være.
+% \end{danish}
+% \begin{english}
+% Find the height of a single tab.
+% \end{english}
+% \begin{macrocode}
+ \newdimen\tabheight
+ \tabheight=\paperheight
+ \advance\tabheight by -1cm%
+ \def\undertab##1\text##2\stop{
+ \ifx\done##2%
+ \divide\tabheight by ##1%
+ \fi
+ }
+ \def\overtab##1\text##2\stop{}%
+ \revy at tabs
+% \end{macrocode}
+% \begin{macro}{\movetoleftside}
+% \begin{danish}^^A
+% De her definitioner indeholder forskellen på at vende
+% registermærkningerne mod højre eller mod venstre.
+% \end{danish}^^A
+% \begin{english}^^A
+% These definitions contain the differences
+% between right and left facing thumb tabs.
+% \end{english}
+% \begin{macrocode}
+ \def\overtableft{-1cm}
+ \def\overtabright{1cm}
+ \def\undertabright{\overtabright}
+ \def\undertableft{\overtableft - 1cm}
+ \def\underangle{|-}
+ \def\underpos{.25}
+ \def\undersign{}
+ \def\underlabeloffset{\undersign.5cm}
+ \def\textanchorcorner{east}
+ \def\textoffset{\undertableft - .5cm}
+ \def\textside{right}
+ \def\movetoleftside{
+% \end{macrocode}
+% \begin{macrocode}
+ \def\overtableft{-1.8cm}
+ \def\overtabright{.2cm}
+ \def\undertabright{\overtabright + 1cm}
+ \def\undertableft{\overtableft}
+ \def\underangle{-|}
+ \def\undersign{-}
+ \def\underpos{.75}
+ \def\textanchorcorner{west}
+ \def\textoffset{\undertabright + .5cm}
+ \def\textside{left}
+ }
+% \end{macrocode}
+% \end{macro}
+% \begin{macro}{\ifwritetitles}
+% \begin{macrocode}
+\newif\ifwritetitles\writetitlesfalse
+% \end{macrocode}
+% \end{macro}
+% \begin{danish}
+% Her kobler vi mening på de tokens, som vi stoppede ind i
+% \verb|\revy at tabtoks| tidligere.
+% \end{danish}
+% \begin{english}
+% Here, we attach meaning to the tokens we stuffed into
+% \verb|\revy at tabtoks| previously.
+% \end{english}
+% \begin{macrocode}
+ \def\printovertab##1##2{
+ \fill ( 0, -##1\tabheight )
+ node[ text=white, anchor=east ]{\bfseries##1}
+ +( \overtableft, -.5\tabheight + 1mm )
+ rectangle +( \overtabright, .5\tabheight - 1mm )
+ +( \textoffset, 0 )
+ \ifwritetitles
+ node[ anchor=\textanchorcorner ]{\small\bfseries##2}
+ \fi
+ ;
+ }%
+% \end{macrocode}
+% \begin{macrocode}
+ \def\printundertab##1##2##3{%
+ \path ( 0, -##1\tabheight ) +( \undertabright, -.5\tabheight - 1mm )
+ coordinate (topright);
+ \path ( 0, -##2\tabheight ) +( \undertableft, -.5\tabheight + 1mm )
+ coordinate (bottomleft);
+ \fill[ color=black!30 ] (topright) rectangle (bottomleft);
+ \path (bottomleft)
+ \underangle node[ xshift=\underlabeloffset,
+ pos=\underpos,
+ rotate=\undersign90
+ ]{\Large##3}
+ (topright);
+ }%
+% \end{macrocode}
+% \begin{macrocode}
+ \def\overtab##1\text##2\stop{%
+ \printovertab{##1}{##2}
+ }
+% \end{macrocode}
+% \begin{macrocode}
+ \def\undertab##1\text##2\stop{
+ \ifx\done##2\else
+ \let\undertab\undertabspan
+ \expandFiHere
+ \undertab##1\text##2\stop
+ \fi
+ }
+% \end{macrocode}
+% \begin{macrocode}
+ \def\undertabspan##1\text##2\stop##3\undertab##4\text##5\stop{%
+ \printundertab{##1}{##4}{##2}%
+ ##3%
+ \ifx\done##5\else
+ \expandFiHere
+ \undertab##4\text##5\stop
+ \fi
+ }%
+% \end{macrocode}
+% \begin{macro}{\filtername}
+% \begin{macrocode}
+ \def\filtername##1{
+ \def\doWhenMatch{}
+ \def\overtab####1\text####2\stop{
+ \IfStrEq{##1}{####2}{
+ \doWhenMatch
+ \printovertab{####1}{####2}
+ }{}
+ }
+% \end{macrocode}
+% \begin{macrocode}
+ \def\undertabspan####1\text####2\stop####3\undertab####4\text####5\stop{
+ \def\doWhenMatch{
+ \printundertab{####1}{####4}{####2}
+ \def\doWhenMatch{}
+ }
+% \end{macrocode}
+% \begin{macrocode}
+ ####3
+ \ifx\done####5\else
+ \expandFiHere
+ \undertab####4\text####5\stop
+ \fi
+ }
+ }
+% \end{macrocode}
+% \end{macro}
+% \begin{danish}
+% Som lovet, argumentet til makroen, lige før registermærkningerne
+% bliver typesat.
+% \end{danish}
+% \begin{english}
+% As promised, the macro argument, just before the thumbindex is
+% actually typeset.
+% \end{english}
+% \begin{macrocode}
+ #1
+% \end{macrocode}
+% \begin{macrocode}
+ \begin{tikzpicture}
+ \revy at tabs
+ \path (0, 0) -- (0, -\paperheight + .5cm);
+ \end{tikzpicture}
+ \endgroup
+ }
+% \end{macrocode}
+% \begin{danish}
+% Og således slutter \verb|\revy at thumbindex|.
+% \end{danish}
+% \begin{english}
+% And thus concludes \verb|\revy at thumbindex|.
+% \end{english}
+% \end{macro}
+% \end{implementation}
+%
+% \label{thumbindexuse}
+% \begin{danish}
+% I resten af det her afsnit følger de makroer, som kan bruges til
+% at tegne registermærkningerne.
+% \end{danish}
+% \begin{english}
+% In the remaider of this section, we list the macros that may be
+% used to typeset the thumb indices.
+% \end{english}
+%
+% \begin{macro}{\rectothumbtabfor}
+% \begin{danish}
+% \begin{showcommand}
+% \verb|\rectothumbtabfor|\marg{titel}
+% \end{showcommand}
+% Sætter et registermærke, som er orienteret mod højre,
+% altså egenet til en recto--side, for filen (eller filerne), hvis
+% titel matcher dens argument. Det giver mest mening hvis den får
+% titlen på det aktuelle dokument, som er gemt i \verb|\@title|. Det
+% er den her makro, som bliver brugt til at sætte registermærkerne i
+% eksemplet i figur \ref{eksempel}.
+% \end{danish}
+% \begin{english}
+% \begin{showcommand}
+% \verb|\rectothumbtabfor|\marg{title}
+% \end{showcommand}
+% Sets a thumb tab, oriented to the right, so suitable for a recto
+% page, that corresponds to the file (or files) whose discovered
+% title matches the argument. The most sensible argument to give it
+% is the title of the current document, which can be found in
+% \verb|\@title|. This is the macro that typeset the thumb tabs in
+% figure \ref{example}.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+ \newcommand{\rectothumbtabfor}[1]{
+ \revy at thumbindex{
+ \filtername{#1}
+ }
+ }
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \begin{macro}{\rectothumbindexwithtitles}
+% \begin{showcommand}
+% \verb|\rectothumbindexwithtitles|
+% \end{showcommand}
+% \begin{danish}
+% Sætter registerindekset, som i figur \ref{registerex}. Læg mærke
+% til, at eksemplet i figur \ref{registerex} er trykket sammen i
+% højden. Som standard skalerer den her makro indekset efter
+% \verb|\paperheight|, ligesom mærkerne i figur \ref{eksempel} er.
+% \end{danish}
+% \begin{english}
+% Sets the thumbs index, as was demonstrated in figure
+% \ref{thumbindexex}. Do note that the example in figure
+% \ref{thumbindexex} has been squeezed vertically. By default, the
+% index is scaled vertically after \verb|\paperheight|, like the
+% thumb tabs in figure \ref{example} were.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+ \newcommand{\rectothumbindexwithtitles}{
+ \revy at thumbindex{
+ \writetitlestrue
+ }
+ }
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \begin{macro}{\rectothumbindex}
+% \begin{showcommand}
+% \verb|\rectothumbindex|
+% \end{showcommand}
+% \begin{danish}
+% Sætter alle mærkerne, ligesom den forrige makro, men uden
+% titelnavnene.
+% \end{danish}
+% \begin{english}
+% Sets all the thumb marks, just like the previous macro, but
+% without writing out the titles.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+ \newcommand{\rectothumbindex}{
+ \revy at thumbindex{}
+ }
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \begin{macro}{\rectothumbtabwithtitlefor}
+% \begin{danish}
+% \begin{showcommand}
+% \verb|\rectothumbtabwithtitlefor|\marg{titel}
+% \end{showcommand}
+% Sætter kun registermærket for indgangen(e) med samme titel som
+% parameteren, og skriver dens titel. Det svæver lidt i det uhvisse,
+% hvad det gavner, at gøre sådan, men muligheden er med for
+% fuldstændighedens skyld.
+% \end{danish}
+% \begin{english}
+% \begin{showcommand}
+% \verb|\rectothumbtabwithtitlefor|\marg{title}
+% \end{showcommand}
+% Sets only the thumb tab for the entr(y/ies) with the title given
+% in the parameter. It's unclear why you'd want to, but the option
+% is included, for completeness.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+ \newcommand{\rectothumbtabwithtitlefor}[1]{
+ \revy at thumbindex{
+ \filtername{#1}
+ \writetitlestrue
+ }
+ }
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\versothumbtabfor}
+% \begin{macro}{\versothumbindexwithtitles}
+% \begin{macro}{\versothumbindex}
+% \begin{macro}{\versothumbtabwithtitlefor}
+% \begin{danish}
+% Alle disse makroer kommer også i en venstreorienteret udgave, som
+% egner sig til marginen på en verso--side:
+% \end{danish}
+% \begin{english}
+% These macros also come in left oriented versions, suitable for the
+% margin of verso pages.
+% \end{english}
+% \begin{showcommand}
+% \verb|\versothumbtabfor|\marg{titel}
+% \item\verb|\versothumbindexwithtitle|
+% \item\verb|\versothumbindex|
+% \item\verb|\versothumbtabwithtitlefor|\marg{titel}
+% \end{showcommand}
+% \begin{implementation}
+% \begin{macrocode}
+ \newcommand{\versothumbindex}{
+ \revy at thumbindex{
+ \movetoleftside
+ }
+ }
+ \newcommand{\versothumbindexwithtitles}{
+ \revy at thumbindex{
+ \movetoleftside
+ \writetitlestrue
+ }
+ }
+ \newcommand{\versothumbtabfor}[1]{
+ \revy at thumbindex{
+ \movetoleftside
+ \filtername{#1}
+ }
+ }
+ \newcommand{\versothumbtabwithtitlefor}[1]{
+ \revy at thumbindex{
+ \movetoleftside
+ \filtername{#1}
+ \writetitlestrue
+ }
+ }
+% \end{macrocode}
+% \end{implementation}
+% \iffalse
+%<*driver>
+\jump
+{
+%</driver>
+% \fi
+% \begin{implementation}
+% \begin{danish}
+% Og således afsluttes den betingede gruppe for
+% \verb|\if at thumbindex|.
+% \end{danish}
+% \begin{english}
+% And thus concludes the conditional group for
+% \verb|\if at thumbindex|.
+% \end{english}
+% \begin{macrocode}
+}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}\end{macro}\end{macro}\end{macro}
+%
+% \begin{danish}
+% \subsection{Infoblokken}
+% Lige efter titlen kan vi sætte en masse information, som er
+% brugbar i arbejdet med at organisere en revy. Figur \ref{title}
+% viser et eksempel på, hvordan titlen ser ud med alle informationer
+% fyldt ud.
+%
+% \begin{figure}[hbtp]
+% \begin{macro}{\maketitle}
+% \changes{v1.0.0}{2023/09/05}{Nyt layout af titelblokken}
+% \phantom{.}
+% \begingroup
+% \exDaPre
+% \def\getpagerefnumber#1{2}
+% \vspace{6em}
+% \class at maketitle
+% \medskip
+% \endgroup
+% \caption{Et eksempel på, hvordan titlen er ud, når alle de
+% informationer, som kan sættes sammen med den, er fyldt ud. Det
+% bliver sat med kommandoen \texttt{\textbackslash
+% maketitle}.\label{title}}
+% \end{macro}
+% \end{figure}
+%
+% I \texttt{.tex}--filen fortæller vi \cn\ om de her ting med en
+% række makroer i preamble'en. For eksemplets skyld er alle
+% makroerne vist i eksemplet, men de kan, untagen versionsnummeret,
+% sagtens udelades i et \cn--dokument, hvis det ikke giver mening
+% at have dem med. Makroerne var:
+%\end{danish}
+%\begin{english}
+% \subsection{The infoblock}
+% \cn's modified title block contains some additinal information that
+% is useful in organizing a show. Figure \ref{title} shows an example
+% of how the title block looks with every possilbe piece of
+% informaiton included.
+%
+% \begin{figure}[hbtp]
+% \begin{macro}{\maketitle}
+% \changes{v1.0.0}{2023/09/05}{New layout of the tile block}
+% \phantom{.}
+% \begingroup
+% \exEnPre
+% \def\getpagerefnumber#1{2}
+% \vspace{6em}
+% \class at maketitle
+% \medskip
+% \endgroup
+% \caption{An example of how \cn's tilte block looks with every
+% possible piece of information filled in. It is set with the
+% command \texttt{\textbackslash maketitle}.\label{title}}
+% \end{macro}
+% \end{figure}
+%
+% We give \cn\ this information with a series of preamble
+% commands. For the sake of the example, the example file includes
+% all of these commands, but they are not required for a \cn\
+% document to compile. If they don't make sense to include in a
+% document, just leave them out. The macros were:
+% \end{english}
+% \iffalse
+%<*driver>
+\land
+%</driver>
+% \fi
+% \begin{macro}{\version}
+%\begin{verbatim}
+%\version{1.0}
+%\end{verbatim}
+% \begin{implementation}
+% \begin{macrocode}
+\def\version#1{\def\@version{#1}}
+% \end{macrocode}
+% \end{implementation}
+% \begin{danish}
+% \verb|\version| er den eneste af de her kommandoer, som ikke kan
+% udelades, fordi versionskontrol er vigtigt\footnote{Måske synes
+% du, at der findes bedre måder, at lave versionskontrol på her i
+% det futuristiske år 2023, men så kan du se det her påmindelse om
+% rent faktiske at bruge dem.}.
+% \end{danish}
+% \begin{english}
+% \verb|\version| is the only one of these commands that may not
+% be omitted, because version conrol is important\footnote{You
+% might be of the opinion that there are better ways of doing
+% version control in the far future year 2023. In which case, you
+% may take this as a reminder to actually use one of them.}.
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% Versionsnummeret gøres påkrævet af de her kommandoer:
+% \end{danish}
+% \begin{english}
+% The version number is made a requirement by these commands:
+% \end{english}
+% \begin{macrocode}
+\def\@version{\@ifundefined{the at version}
+{\typein[\versionsnr]{Indtast revytekstens versionsnummer: }%
+\global\let\the at version=\versionsnr}{}\the at version}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\revyname}
+% \begin{macro}{\revyyear}
+% \begin{macro}{\title}
+% \begin{danish}
+%\begin{verbatim}
+%\revyname{FysikRevy\texttrademark}
+%\revyyear{2019}
+%\title{Eksempel}
+%\author{en eksempelsmed}
+%\end{verbatim}
+%\end{danish}
+%\begin{english}
+% \begin{verbatim}
+%\revyname{The Meaning of Liff}
+%\revyyear{3001}
+%\title{Example}
+%\author{an examplesmith}
+% \end{verbatim}
+%\end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\def\revyname#1{\def\@revyname{#1}}
+\def\revyyear#1{\def\@revyyear{#1}}
+% \end{macrocode}
+% \begin{danish}
+% \verb|\title| og \verb|\author| bliver ikke ændret.
+% \end{danish}
+% \begin{english}
+% \verb|\title| and \verb|\author| remian unaltered.
+% \end{english}
+% \end{implementation}
+% \begin{danish}
+% Hvis \cn\ ikke får at vide, hvad revyens navn og år skal være,
+% og hvad titlen er, går den som standard ud fra, at det er
+% "`DIKUrevy"', "`1973"' og "`En sketch"'.
+% \end{danish}
+% \begin{english}
+% If \cn\ isn't given a revue name, year or a title, it will use the
+% defaults of ``DIKUrevy'', ``1973'' and ``En sketch''.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\def\@revyyear{1973}
+\def\@revyname{DIKUrevy}
+\def\@title{En sketch}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+%
+% \begin{macro}{\author}
+% \begin{macro}{\status}
+% \begin{macro}{\eta}
+% \begin{macro}{\responsible}
+% \begin{macro}{\melody}
+% \begin{danish}
+% De resterende bliver ikke sat, hvis de ikke bliver defineret.
+%\begin{verbatim}
+%\status{eksempel}
+%\eta{$1$ minut, $47$ sekunder}
+%\responsible{Dig}
+%\author{en eksempelsmed}
+%\melody{Queen: "`Bohemian Rhapsody"' (\url{https://youtu.be/fJ9rUzIMcZQ})}
+%\end{verbatim}
+% \end{danish}
+% \begin{english}
+% The rest aren't typeset if they are not defined.
+%\begin{verbatim}
+%\status{example}
+%\eta{$1$ minute, $47$ seconds}
+%\responsible{Probably you}
+%\melody{Monty Python: ``Always look on the bright side of life''
+% (\url{https://youtu.be/SJUhlRoBL8M})}
+%\end{verbatim}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% For at holde styr på, om de her ting er defineret, definerer
+% vi følgende \verb|\if|--makroer, og sætter dem til falsk som
+% udgangspunkt:
+% \end{danish}
+% \begin{english}
+% These new \verb|\if| macros keep track of which of these
+% things have been defined.
+% \end{english}
+% \begin{macrocode}
+\newif\if at author\@authorfalse
+\newif\if at status\@statusfalse
+\newif\if at eta\@etafalse
+\newif\if at responsible\@responsiblefalse
+\newif\if at melody\@melodyfalse
+% \end{macrocode}
+% \begin{danish}
+% Og så makroerne, som sætter værdierne:
+% \end{danish}
+% \begin{english}
+% And these macros define them:
+% \end{english}
+% \begin{macrocode}
+\def\author#1{\def\@author{#1}\@authortrue}
+\def\status#1{\def\@status{#1}\@statustrue}
+\def\eta#1{\def\@eta{#1}\@etatrue}
+\def\responsible#1{\def\@responsible{#1}\@responsibletrue}
+\def\melody#1{\def\@melody{#1}\@melodytrue}
+% \end{macrocode}
+% \begin{danish}
+% Vi sørger for, at de interne makroer ikke er udefinerede:
+% \end{danish}
+% \begin{english}
+% Ensuring that the internal macros aren't undefined:
+% \end{english}
+% \begin{macrocode}
+\def\@author{}
+\def\@status{}
+\def\@eta{}
+\def\@responsible{}
+\def\@melody{}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+%
+% \begin{macro}{\auteurs}
+% \begin{danish}
+% Og som bonus har vi bibeholdt \verb|\auteurs|, som er et alias til
+% \verb|\author|, for folk med fine fornemmelser.
+% \end{danish}
+% \begin{english}
+% And as a bonus, we've retained \verb|\auteurs| as an alias of
+% \verb|\author|, for fancy folk.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\let\auteurs\author
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\writtenbyname}
+% \begin{macro}{\melodyname}
+% \begin{macro}{\responsibletext}
+% \begin{macro}{\statustext}
+% \begin{danish}
+% Mærkaterne, som \cn\ bruger i infoblokken, altså
+% "`\@writtenbyname"', "`\@melodyname"', etc., kan laves om med
+% makroerne
+% \begin{showcommand}
+% \verb|\writtenbyname|\marg{tekst}
+% \item\verb|\melodyname|\marg{tekst}
+% \item\verb|\responsibletext|\marg{tekst}
+% \end{showcommand}
+% og
+% \begin{showcommand}
+% \verb|\statustext|\marg{tekst}
+% \end{showcommand}
+% De fleste af dem tager bare den nye mærkat som argument, så fx
+% "`\@responsibletext"' kan laves om til "`Kæmpehare:"' ved at sige
+% \begin{verbatim}
+%\responsibletext{Kæmpehare:}
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% \begin{verbatim}
+%\writtenbyname{written by}
+%\melodyname{Melody:}
+%\responsibletext{\TeX--responsible}
+% \end{verbatim}
+% The labels on some of the bits of info are in danish by default:
+% ``\@writtenbyname'', ``\@melodyname'' and ``\@responsibletext'',
+% respectively. These commands overwrite those defaults. There is
+% also a command for changing the ``Status'' label, which happens
+% not to be necessary in english:
+% \begin{showcommand}
+% \verb|\statustext| \marg{text}
+% \end{showcommand}
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\def\writtenbyname#1{\def\@writtenbyname{#1}}
+\def\melodyname#1{\def\@melodyname{#1}}
+\def\responsibletext#1{\def\@responsibletext{#1}}
+\def\statustext#1{\def\@statustext{#1}}
+\def\@writtenbyname{skrevet af}
+\def\@melodyname{Melodi:}
+\def\@responsibletext{\TeX--ansvarlig:}
+\def\@statustext{Status:}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+%
+% \begin{macro}{\pagessum}
+% \begin{danish}
+% Men sidetallet er lidt mere kompliceret, så her har vi brug for
+% en makro, som tager 1 argument (et \meta{tal}), og sætter ordet
+% `side' i det rigtige tal efter det. Så \verb|\pagessum{0}| giver
+% "`0 sider"', mens \verb|\pagessum{1}| giver "`1 side"'. En ny
+% makro, som hedder \verb|\pagessum|, men gør ngoet andet, kan
+% defineres med \verb|\renewcommand|.
+% \end{danish}
+% \begin{english}
+% The page count is a touch more complicated, and requires a macro
+% that takes 1 argument (a \meta{number}), and evaluates to the
+% grammatically correct phrase for that page count. Thus
+% \verb|\pagessum{0}| becomes ``0 sider'' (the plural), while
+% \verb|\pagessum{1}| becomes ``1 side'' (the singular).
+% \end{english}
+% \begin{implementation}
+% \begin{english}
+% The default macro, for danish, is
+% \end{english}
+% \begin{macrocode}
+\newcommand{\pagessum}[1]{#1 side\ifnum1=#1\else r\fi}
+% \end{macrocode}
+% \end{implementation}
+% \begin{english}
+% In the example, such a macro is given for english in the line
+% \begin{verbatim}
+%\renewcommand{\pagessum}[1]{#1 page\ifnum#1=1\else s\fi}
+% \end{verbatim}
+% \end{english}
+% \end{macro}
+%
+% \begin{implementation}
+% \begin{macro}{\maketitle}
+% \begin{danish}
+% omskrives, så den laver en titelblok som den i figur \ref{title}.
+% \end{danish}
+% \begin{english}
+% is rewritten to create a title segment like what was shown in
+% figure \ref{title}.
+% \end{english}
+% \iffalse
+%<*driver>
+%^^A I do want to keep the real \maketitle in the .dtx file, though
+\let\actual at maketitle\maketitle
+%</driver>
+% \fi
+% \begin{macrocode}
+\def\maketitle{{\thispagestyle{empty}
+ \vspace*{-\headheight}\vspace*{-\headsep}
+ \centering{\Large\@revyname{} \@revyyear}\vspace{5pt}\\
+ {\LARGE \bf \@title}\vspace{5pt}\\
+ \if at author{\large\@writtenbyname{} \@author}\vspace{5pt}\\\fi
+ \if at melody{\sl\@melodyname{} \@melody}\vspace{5pt}\\\fi
+% \end{macrocode}
+% \begin{macrocode}
+ \if at leftfields
+ \begin{varwidth}[t]{\bigheaderwidth}\raggedleft
+ \if at status{\@statustext{} \@status}\vspace{2pt}\\\fi
+ \if at responsible{\@responsibletext{} \@responsible}\vspace{2pt}\\\fi
+ \if at eta{(\@eta)}\\\fi
+ \end{varwidth}%
+% \end{macrocode}
+% \begin{danish}
+% Det eksplicitte mellemrum her holder formatteringen konsistent.
+% \end{danish}
+% \begin{english}
+% The explicit space here keeps the foratting regular.
+% \end{english}
+% \begin{macrocode}
+ \ \hspace{.5em}\vrule{}\hspace{.5em}
+ \begin{varwidth}[t]{\smallheaderwidth}\raggedright
+ Version \@version\vspace{2pt}\\
+ \today\vspace{2pt}\\
+ \pagessum{\getpagerefnumber{lastpage}}
+ \end{varwidth}
+% \end{macrocode}
+% \begin{macrocode}
+ \else
+ Version \@version
+ \ \hspace{.5em}\vrule\hspace{.5em}
+ \today
+ \ \hspace{.5em}\vrule\hspace{.5em}
+ \pagessum{\getpagerefnumber{lastpage}}
+ \fi
+ \vskip 5pt }}
+% \end{macrocode}
+% \iffalse
+%<*driver>
+\let\class at maketitle\maketitle
+\let\maketitle\actual at maketitle
+%</driver>
+% \fi
+%
+% \begin{danish}
+% Miljøet \verb|varwidth|\DescribeEnv{varwidth}\ styrer placeringen
+% af dobbeltkolonnedelen af titelblokken. Det kommer fra
+% \end{danish}
+% \begin{english}
+% The environment \verb|varwidth|\DescribeEnv{varwidth}\ controls the
+% placement of the two--column part of the title block. It comes
+% from
+% \end{english}
+% \begin{macrocode}
+\RequirePackage{varwidth}
+% \end{macrocode}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+% \fi
+%
+% \begin{danish}
+% \texttt{\bslash getpagerefnumber} er en version af \texttt{\bslash
+% pageref} som kan udvides. Den kommer fra
+% \end{danish}
+% \begin{english}
+% \texttt{\bslash getpagerefnumber} is an expandable version of
+% \texttt{\bslash pageref} from
+% \end{english}
+% \begin{macrocode}
+\RequirePackage{refcount}
+% \end{macrocode}
+%
+% \begin{macro}{\if at leftfields}
+% \begin{danish}
+% Den her makro fungerer som\footnote{her er $\lor$ logisk
+% `eller'.} \verb|\if at responsible| $\lor$ \verb|\if at status|
+% $\lor$ \verb|\if at eta|. \TeX{}'s \texttt{\bslash
+% if}--mekanisme understøtter ikke som sådan en
+% $\lor$--operator, så vi bruger tallene 0 og 1 som
+% stedfortrædere for booliske værdier, og bruger
+% talsammenligninger til at definere
+% \end{danish}
+% \begin{english}
+% This macro is defined to effectively be\footnote{$\lor$ being
+% logical OR.} \verb|\if at responsible| $\lor$ \verb|\if at status|
+% $\lor$ \verb|\if at eta|. In the absence of a real
+% $\lor$--operator for \TeX{}'s \texttt{\bslash if}, it uses
+% 1's and 0's as standins for boolean values.
+% \end{english}
+% \iffalse
+%<*driver>
+\land
+%</driver>
+% \fi
+% \begin{macrocode}
+\def\if at leftfields{
+ \def\@responsiblenum{\ifx\iftrue\if at responsible 1 \else 0 \fi}
+ \def\@statusnum{\ifx\iftrue\if at status 1 \else 0 \fi}
+ \def\@etanum{\ifx\iftrue\if at status 1 \else 0 \fi}
+% \end{macrocode}
+% \begin{macrocode}
+ \ifnum1=\ifnum1=\@responsiblenum 1
+ \else \ifnum1=\@statusnum 1
+ \else \ifnum1=\@etanum 1
+ \else 0
+ \fi\fi\fi
+}
+% \end{macrocode}
+% \end{macro}
+% \begin{macro}{\smallheaderwidth}
+% \begin{macro}{\bigheaderwidth}
+% \begin{danish}
+% Og disse længder blev brugt.
+% \end{danish}
+% \begin{english}
+% And these lengths were used.
+% \end{english}
+% \begin{macrocode}
+\newlength{\smallheaderwidth}
+\setlength{\smallheaderwidth}{22ex}
+\newlength{\bigheaderwidth}
+\setlength{\bigheaderwidth}{\textwidth}
+\addtolength{\bigheaderwidth}{-\smallheaderwidth}
+\addtolength{\bigheaderwidth}{-1.5em}
+% \end{macrocode}
+% \end{macro}
+% \end{macro}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+% \fi
+% \end{macro}
+% \end{implementation}
+%
+% \begin{danish}
+% \subsubsection{Sidehoveder}
+% Klassen definerer også sine egne sidehoveder, illustreret i figur
+% \ref{sidehoved}, som indeholder nogle af de samme informationer.
+% \end{danish}
+% \begin{english}
+% \subsubsection{Page headers}
+% The class also defines its own header style, which is illustrated
+% in figure \ref{sidehoved}, and contains some of the same information.
+% \end{english}
+%
+% \begin{figure}[htbp]
+% \begingroup
+% \IfLanguageName{danish}{\exDaPre}{}
+% \IfLanguageName{english}{\exEnPre}{}
+% \ps at revyheadings
+% \let\thepage=2
+% \def\pageref#1{2}
+% \renewcommand{\rectoheaderthumbtab}{}
+% \vspace{3em}
+% \@oddhead
+% \medskip
+% \endgroup
+% \begin{danish}
+% \caption{Et eksempel på sidehovederne, som \cn\ definerer.}
+% \end{danish}
+% \begin{english}
+% \caption{An example of the headers that \cn\ define.}
+% \end{english}
+% \label{sidehoved}
+% \end{figure}
+%
+% \iffalse
+%<*driver>
+\land
+%</driver>
+% \fi
+%
+% \begin{danish}
+% De her sidehoveder hører til en ny \texttt{pagestyle}, som hedder
+% \texttt{revyheadings}.
+% \end{danish}
+% \begin{english}
+% These headers belong ot a new \texttt{pagestyle} named
+% \texttt{revyheadings}
+% \end{english}
+% \begin{implementation}
+% \begin{macro}{\ps at revyheadings}
+% \begin{macrocode}
+\gdef\ps at revyheadings{
+ \def\@oddhead{\vbox to 0pt{\vss
+ \hbox to \textwidth{\hfil\rectoheaderthumbtab}
+ \hbox{\rm\strut\@revyname{} \@revyyear}
+ \hbox to \textwidth{Version \@version\quad\today
+ \hfil {\large\sl\@title}\hfil
+ Side \rm\thepage/\pageref{lastpage}}
+ \hrule}}
+ \def\@evenhead{\vbox to 0pt{\vss
+ \hbox{\versoheaderthumbtab}
+ \hbox to \textwidth{\hfil\rm\strut\@revyname{} \@revyyear}
+ \hbox to \textwidth{Side \rm\thepage/\pageref{lastpage}
+ \hfil {\large\sl\@title}\hfil
+ Version \@version\quad\today}
+ \hrule}}
+ \def\@oddfoot{}\def\@evenfoot{}}
+% \end{macrocode}
+% \end{macro}
+%
+% \begin{macro}{\rectoheaderthumbtab}
+% \begin{macro}{\versoheaderthumbtab}
+% \begin{danish}
+% Her er \verb|\rectoheaderthumbtab| og
+% \verb|\versoheaderthumbtab| makroer, som placerer
+% registermærkningerne korrekt på siden i forhold til sidehovedet,
+% og kalder kommandoen, som tegner dem, så længe \cn\ er blevet
+% kaldt med valgmuligheden \verb|thumbindex|, se sektion
+% \ref{thumbindex}. Hvis ikke, så gør de ikke noget.
+% \end{danish}
+% \begin{english}
+% Here, the \verb|\rectoheaderthumbtab| and
+% \verb|\versoheaderthumbtab| are macros that place the thumb
+% markings correctly in relation to the page header, and call the
+% drawing macro, so long as \cn\ has been given the option
+% \verb|thumbindex|, see section \ref{thumbindex}. If not, they do
+% nothing.
+% \end{english}
+% \begin{macrocode}
+\newcommand{\rectoheaderthumbtab}{%
+ \if at thumbindex
+ \rectothumbtabfor{\@title}%
+ \vspace*{ -\paperheight }\vspace*{ -\voffset }\vspace*{ 0.32in }%
+ \hspace{-\paperwidth }\hspace{ 1in }\hspace{ \oddsidemargin }%
+ \hspace{ \hoffset }\hspace{ \textwidth }\hspace{-.6cm}%
+ \fi
+}
+\newcommand{\versoheaderthumbtab}{%
+ \if at thumbindex
+ \hspace{ -2.5in }\hspace{ -\evensidemargin }%
+ \hspace{ -\hoffset }\hspace{ -1in }%
+ \versothumbtabfor{\@title}%
+ \vspace*{ -\paperheight }\vspace*{ -\voffset }\vspace*{ 0.32in }%
+ \fi
+}
+% \end{macrocode}
+% \end{macro}
+% \end{macro}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+% \fi
+% \end{implementation}
+% \begin{danish}
+% Den nye \texttt{pagestyle} er aktiveret som standard.
+% \end{danish}
+% \begin{english}
+% The new \texttt{pagestyle} is activated by default.
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\pagestyle{revyheadings}
+% \end{macrocode}
+% \DescribeMacro{\ps at empty}
+% \begin{danish}^^A
+% Men vi omdefinerer også \texttt{pagestyle}'en "`\texttt{empty}"'
+% til at være
+% \end{danish}^^A
+% \begin{english}^^A
+% But we also redefine the \texttt{pagestyle} ``\texttt{enpty}'' to be
+% \end{english}
+% \begin{macrocode}
+\gdef\ps at empty{
+ \def\@oddhead{\vbox to 0pt{\vss
+ \hbox to \textwidth {\hfil\rectoheaderthumbtab }
+ \vbox to 2em{}}}
+ \def\@evenhead{\vbox to 0pt{\vss\hbox{\versoheaderthumbtab}}}
+ \def\@oddfoot{}\def\@evenfoot{}}
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{danish}
+% \subsection{Tildelingslister}
+%
+% Rolle- og rekvisitlisterne i starten af eksemplet, som også er
+% gengivet i figur \ref{lists}, produceres af følgende linjer:
+%
+%\begin{verbatim}
+% \begin{roles}
+% \role{PH}[Jophiel] Per Hedegaard
+% \role{I} Vred instruktør
+% \role{A9}[A--ni] Anine
+% \end{roles}
+% \begin{props}
+% \prop{Hedegaard--hår}[Person, der skaffer]
+% \prop{Didgeridoo}[Anine]
+% \end{props}
+%\end{verbatim}
+%
+% \begin{figure}[htbp]
+% \medskip
+% \begin{roles}
+% \role{PH}[Jophiel] Per Hedegaard
+% \role{I} Vred instruktør
+% \role{A9}[A--ni] Anine
+% \end{roles}
+% \begin{props}
+% \prop{Hedegaard--hår}[Person, der skaffer]
+% \prop{Didgeridoo}[Anine]
+% Et traditionelt Australsk blæseinstrument
+% \end{props}
+% \medskip
+% \caption{Eksempel på lister, som kan sættes med \cn\ til at
+% uddele, for eksempel, roller og ansvar for for rekvisitter.}
+% \label{lists}
+% \end{figure}
+%
+% \end{danish}
+% \begin{english}
+% \subsection{Assignement lists}
+%
+% We provide a number of environments for setting information about
+% the material in a file in lists. In the example file, we produce
+% something like the lists shown in figure \ref{lists}, with the
+% passage
+% \begin{verbatim}
+%\rolename{Roles:}
+%\begin{roles}
+% \role{KA}[Graham] Arthur, king of all the Britons
+% \role{P}[Michael] Peasant
+% \role{RC}[John] Roman Centurion
+% % [...]
+%\end{roles}
+%\propname{Props:}
+%\begin{props}
+% \prop{Large sign}
+% \prop{Field of crosses}
+%\end{props}
+% \end{verbatim}
+% \begin{figure}[hbtp]
+% \medskip
+% \rolename{Roles:}
+% \begin{roles}
+% \role{KA}[Graham] Arthur, king of all the Britons
+% \role{P}[Michael] Peasant
+% \role{RC}[John] Roman Centurion
+% \end{roles}
+% \propname{Props:}
+% \begin{props}
+% \prop{Large sign}
+% \prop{Field of crosses}
+% \end{props}
+% \medskip
+% \caption{Examples of the assignment lists that can be typeset
+% with \cn, for noting cast lists, among other things.}
+% \label{lists}
+% \end{figure}
+% \end{english}
+%
+% \iffalse
+%<*driver>
+\land
+%</driver>
+% \fi
+% \begin{implementation}
+% \begin{environment}{revy at list}
+% \begin{danish}
+% Begge de miljøer blev udledt fra det her miljø.
+% \end{danish}
+% \begin{english}
+% Both those environments are derived from this environment.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{revy at list}[1]%
+{{\smallskip\noindent\Large\bf#1}
+ \begin{list}{}{
+ \labelwidth 8em
+ \leftmargin 10em
+ \rightmargin 0em
+ \labelsep 1em
+ \listparindent 0em
+ \topsep 1ex
+ \partopsep 0ex
+ \parsep 1ex
+ \itemsep -1ex\relax
+ }%
+ }%
+ {\end{list}\smallskip\hfil\rule{6cm}{0.1mm}\medskip\par}
+% \end{macrocode}
+% \begin{danish}
+% Argumentet, som det her miljø tager, er listens overskrift.
+% \end{danish}
+% \begin{english}
+% The argument that this environment takes is the title for the
+% list.
+% \end{english}
+% \end{environment}
+%
+% \begin{macro}{\revy at itemname}
+% \begin{danish}
+% Fordi \texttt{revy at list} er afledt fra \texttt{list}--miljøet,
+% så forventer det, at punkter på listen bliver kaldt med
+% \verb|\item|. Vi, som brugere, forventer, at vi kan bruge vores
+% egne navne for punkter på de her lister, og at de bliver sat i
+% deres egen stil. Den her makro laver de definitioner, som er
+% nødvendige, for at bruge de kommandoer.
+% \end{danish}
+% \begin{english}
+% As the \texttt{revy at list} environment is derived from the
+% \texttt{list} environment, it expects entries in its list to
+% ultimately be called with \verb|\item|. However, for the
+% environments presented to the end user, we like to provide item
+% commands that more closely match the intended use. This macro
+% bundles the process of creating those commands.
+% \end{english}
+% \begin{macrocode}
+\def\revy at itemname#1{%
+ \def\@itemwithout##1{\item [{\bf ##1} \hfill] }
+ \def\@itemwith##1[##2]{\item [{\bf ##1} (##2) \hfill] }
+ \expandafter\def\csname #1\endcsname##1{%
+ \@ifnextchar [{\@itemwith{##1}}{\@itemwithout{##1}}%]
+ }
+}
+% \end{macrocode}
+% \begin{danish}
+% Argumentet er navnet på den kommando, som kommer til at sætte
+% punkter på listen.
+%
+% Se nogle eksempler på, hvordan den bruges, lige under her.
+% \end{danish}
+% \begin{english}
+% The argument is the name of the macro that will be created for
+% setting items on our lists.
+%
+% Some examples of how these are used will follow.
+% \end{english}
+% \end{macro}
+% \end{implementation}
+%
+% \begin{environment}{roles}
+% \begin{danish}
+% I rollelisten, for eksempel, sættes hver rolletildeling med
+% kommandoen
+%
+% \verb|\role|\marg{fk.}\oarg{skuespiller}\meta{rollebeskrivelse}.
+% \end{danish}
+% \begin{english}
+% In the role list, each role is set with the macro
+%
+% \verb|\role|\marg{abr.}\oarg{actor}\meta{description}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% Her afledes rollelistemiljøet fra \texttt{revy at list}.
+% \end{danish}
+% \begin{english}
+% The roles list environment is here derived from
+% \texttt{revy at list}.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{roles}{
+ \begin{revy at list}{\@rolename}
+ \revy at itemname{role}
+ }{
+ \end{revy at list}
+}
+% \end{macrocode}
+% \end{implementation}
+% \end{environment}
+%
+% \begin{environment}{props}
+% \begin{environment}{mics}
+% \begin{environment}{instructors}
+% \begin{danish}
+% Ud over rollelisten findes også miljøer til lister over
+% rekvisitter (som også ver med i eksemplet), mikrofoner og
+% instruktørere.\footnote{\cn\ stiller ikke nogen krav til
+% hvorvidt nogen af de her miljøer bliver brugt. Check med din
+% revyorganisation for at høre hvad der skal være med i materiale
+% til din revy.} For de sidste miljøer er kommandoerne til at lave
+% et punkt på de lister henholdsvis
+% \begin{showcommand}
+% \verb|\prop|\marg{rekvisit}\oarg{ansvarlig}\meta{beskrivelse},
+%
+% \end{showcommand}
+% \begin{showcommand}
+% \verb|\mic|\marg{fk.}\oarg{skuespiller}\meta{mikrofon}
+% \end{showcommand}
+% og
+% \begin{showcommand}
+% \verb|\instructor|\oarg{titel}\meta{navn}.
+% \end{showcommand}
+% \end{danish}
+% \begin{english}
+% Beyond the roles environment, \cn\ defines these three
+% additional environments, for typesetting lists that may be
+% useful to a production. Of these, the examples in figures
+% \ref{eksempel} and \ref{lists} used \verb|props|.
+%
+% Within these environments, \verb|props|, \verb|mics| and
+% \verb|instructors|, the macros for setting a list item are
+% \begin{showcommand}
+% \verb|\prop|\marg{prop}\oarg{responsible}\meta{description},
+% \end{showcommand}
+% \begin{showcommand}
+% \verb|\mic|\marg{abr.}\oarg{actor}\meta{microphon}
+% \end{showcommand}
+% og
+% \begin{showcommand}
+% \verb|\instructor|\oarg{title}\meta{name},
+% \end{showcommand}
+% respectively.
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% Definitionen følger de samme linjer som definitionen af
+% \texttt{roles}--miljøet.
+% \end{danish}
+% \begin{english}
+% Their definitions run along the same lines as the
+% \texttt{roles} environment.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{props}{
+ \begin{revy at list}{\@propname}
+ \revy at itemname{prop}
+ }{
+ \end{revy at list}
+}
+\newenvironment{mics}{
+ \begin{revy at list}{\@micname}
+ \revy at itemname{mic}
+ }{
+ \end{revy at list}
+}
+% \end{macrocode}
+% \begin{danish}
+% Strukturen i listekommandoen \verb|\instructor|, i
+% \texttt{instructors}, er forskellig fra den, som
+% \verb|\revy at itemname| definerer, så vi implementerer den særskilt.
+% \end{danish}
+% \begin{english}
+% However, the structure of the item macro in \texttt{instructors}
+% doesn't fit the pattern, and so needs its own particular
+% implementation.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{instructors}{
+ \begin{revy at list}{\@instructorname}
+ \def\@instructorwith[##1]{\item [{\bf ##1} \hfill] }
+ \def\@instructorwithout{\item}
+ \def\instructor{%
+ \@ifnextchar [{\@instructorwith}{\@instructorwithout}%]
+ }
+ }{
+ \end{revy at list}
+}
+% \end{macrocode}
+% \end{implementation}
+% \end{environment}
+% \end{environment}
+% \end{environment}
+%
+%
+% \begin{macro}{\rolename}
+% \begin{macro}{\propname}
+% \begin{macro}{\micname}
+% \begin{macro}{\instructorname}
+% \begin{danish}
+% Miljøernes standardoverskrifter---"`Roller:"', "`Rekvisitter:"',
+% "`Mikrofoner"' og "`Instruktører:"'---kan ændres med
+% makroerne
+% \begin{showcommand}
+% \verb|\rolename|\marg{tekst},
+% \item\verb|\propname|\marg{tekst},
+% \item\verb|\micname|\marg{tekst}
+% \end{showcommand}
+% og
+% \begin{showcommand}
+% \verb|\instructorname|\marg{tekst}
+% \end{showcommand}
+% \end{danish}
+% \begin{english}
+% The default headings for these environments---``Roller:'',
+% ``Rekvisitter:'', ``Mikrofoner'' and ``Instruktører:''---may be
+% changed with the macros
+% \begin{showcommand}
+% \verb|\rolename|\marg{text},
+% \item\verb|\propname|\marg{text},
+% \item\verb|\micname|\marg{text}
+% \end{showcommand}
+% og
+% \begin{showcommand}
+% \verb|\instructorname|\marg{text}
+% \end{showcommand}
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+\def\rolename#1{\def\@rolename{#1}}
+\def\propname#1{\def\@propname{#1}}
+\def\micname#1{\def\@micname{#1}}
+\def\instructorname#1{\def\@instructorname{#1}}
+% \end{macrocode}
+% \begin{danish}
+% Makroerne, som opbevarer de her navne, er
+% \end{danish}
+% \begin{english}
+% The macros that store these names are
+% \end{english}
+% \begin{macrocode}
+\def\@rolename{Roller:}
+\def\@propname{Rekvisitter:}
+\def\@micname{Mikrofoner:}
+\def\@instructorname{Instruktører:}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+% \end{macro}
+%
+% \begin{danish}
+% \subsection{Brødtekst}
+% \end{danish}
+% \begin{english}
+% \subsection{Body text}
+% \end{english}
+% \subsubsection{\texttt{sketch}}
+% \begin{environment}{sketch}
+% \begin{danish}
+% \changes{v1.0.0}{2023/09/05}{Brødtekst--makroer
+% (\texttt{\textbackslash scene}, etc.) findes ikke længere uden for
+% \texttt{song} og \texttt{sketch} miljøerne.}
+% For at sætte talte replikker, som eksemplet vist i figur
+% \ref{sketchex}, bruger vi miljøet |sketch|.
+%
+% \begin{figure}[hbtp]
+% \begin{center}$\vdots$\end{center}
+% \begin{sketch}
+% \says{A9} Nå, men så må jeg jo hellere begynde at lede. \act{Vender
+% sig mod Bandet} Bandet, har I...?
+% \scene Hvert bandmedlem holder sin egen didgeridoo op.
+% \says{A9}[Til PH] Den ser ud til at være i vinkel.
+% \says{PH} Sejt.
+% \end{sketch}
+% \begin{center}$\vdots$\end{center}
+% \caption{Et eksempel på, hvordan replikker typesættes med
+% \texttt{sketch}--miljøet.}
+% \label{sketchex}
+% \end{figure}
+% \end{danish}
+% \begin{english}
+% \changes{v1.0.0}{2023/09/05}{The body text macros
+% (\texttt{\textbackslash scene}, etc.) are no longer available
+% outside the \texttt{song} and \texttt{sketch} environments.}
+% To typese spoken lines, as in the example shown in figure
+% \ref{sketchex}, use the \texttt{sketch} envrionment.
+%
+% \begin{figure}[hbtp]
+% \begin{center}$\vdots$\end{center}
+% \begin{sketch}
+% \says{RC}[To KA] Did you write th... wait a minute. \act{Off
+% stage} It's him! \act{Back at KA} How did you get here?
+%
+% \does{KA} attempts to sidle away.
+%
+% \says{RC} Get him!
+%
+% \scene Several Roman soldiers appear, and drag \role{KA} off
+% stage, while \role{KA} attempts to protest.
+% \end{sketch}
+% \begin{center}$\vdots$\end{center}
+% \caption{An example of how spoken lines are typeset, using the
+% \texttt{sketch} environment.}
+% \label{sketchex}
+% \end{figure}
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% \verb|sketch| er, ligesom tildelingslisterne, implementeret
+% ved brug af \verb|list|--milljøet. Miljøet
+% \verb|revy at bodycommon| introducerer makroer, som er fælles
+% mellem miljøerne \verb|sketch| og \verb|song|. Den bliver
+% defineret på side \pageref{bodycommon}.
+% \end{danish}
+% \begin{english}
+% \verb|sketch|, like the assignment list environments, is
+% derived from the \verb|list| environment. The environment
+% \verb|revy at bodycommon| introduces macros that are shared
+% between the \verb|sketch| and \verb|song| environments. It is
+% defined on page \pageref{bodycommon}.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{sketch}{%
+ \begin{revy at bodycommon}
+ \rm\begin{list}{}{
+ \labelwidth 2em
+ \leftmargin 3em
+ \rightmargin 0em
+ \labelsep 0.5em
+ \listparindent 2em
+ \topsep 1ex
+ \partopsep 1ex
+ \parsep 0ex
+ \itemsep 1ex\relax}%
+ \item \rule{0.2em}{0em}\vspace{-1em}\par %}
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{macro}{\says}
+% \begin{danish}
+% Inde i \verb|sketch| sætter makroen \verb|\says| hver enkelt
+% replik. Den fulde syntaks er:
+% \begin{showcommand}
+% \verb|\says|\marg{fk.}\oarg{instruktion} \meta{replik}
+% \end{showcommand}
+% \end{danish}
+% \begin{english}
+% Inside the \verb|sketch| environment, the macro \verb|\says|
+% sets each line of dialouge. Its complete syntax is:
+% \begin{showcommand}
+% \verb|\says|\marg{abr.}\oarg{direction} \meta{line}
+% \end{showcommand}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% \verb|\says| og \verb|\scene| (se side \pageref{sceneuse})
+% skifter frem og tilbage mellem hver deres tilstand i
+% miljøet. Vi piller ved \verb|\leftskip|, for at ændre
+% indrykningen af \verb|\scene|.
+% \end{danish}
+% \begin{english}
+% \verb|\says| and \verb|\scene| (see page \pageref{sceneuse})
+% effectively shift the environment back and forth between two
+% modes of typesetting. We mess around with \verb|\leftskip| to
+% accomplish changes in indentation.
+% \end{english}
+% \begin{macrocode}
+ \newdimen\old at leftskip
+ \old at leftskip \leftskip
+ \newdimen\short at leftskip
+ \short at leftskip \leftskip
+ \advance\short at leftskip -1.5em
+% \end{macrocode}
+% \begin{macro}{\says}
+% \begin{macrocode}
+\def\says##1{\@ifnextchar [{\@saysas{##1}}{\@says{##1}}} %]
+\def\@saysas##1[##2]{\rm\item [{\bf ##1 }{\it (##2)\,}\hfill:]
+ \leftskip \old at leftskip}
+\def\@says##1{\rm\item [{\bf ##1\,}\hfill:]\leftskip \old at leftskip}
+% \end{macrocode}
+% \end{macro}
+% \begin{macro}{\scene}
+% \begin{macrocode}
+\def\scene{\medskip\par\noindent\it\leftskip \short at leftskip }
+% \end{macrocode}
+% \end{macro}
+% \end{implementation}
+%
+% \begin{danish}
+% Så for eksempel den næstsidste replik i figur \ref{sketchex} er
+% kreéret med følgende kode:
+% \begin{verbatim}
+% \says{A9}[Til PH] Den ser ud til at være i vinkel.
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% Thus, for example, part of the first line of figure
+% \ref{sketchex} gets created with the following code:
+% \begin{verbatim}
+% \says{RC}[To KA] Did you write th... wait a minute. \act{Off stage} (...)
+% \end{verbatim}
+% \end{english}
+% \end{macro}
+%
+% \begin{implementation}
+% \begin{danish}
+% Og her afslutter vi \verb|sketch|--miljøet.
+% \end{danish}
+% \begin{english}
+% And here, the \verb|sketch| environment is concluded.
+% \end{english}
+% \begin{macrocode}
+ }{%
+ \end{list}
+ \end{revy at bodycommon}
+}
+% \end{macrocode}
+% \end{implementation}
+% \end{environment}
+%
+% \subsubsection{\texttt{song}}
+% \begin{environment}{song}
+% \begin{danish}
+% \changes{v1.0.0}{2023/09/05}{Brødtekst--makroer
+% (\texttt{\textbackslash scene}, etc.) findes ikke længere uden for
+% \texttt{song} og \texttt{sketch} miljøerne.}
+% Miljøet \verb|song| er til sangtekster, som sættes som eksemplet
+% i figur \ref{songex}.
+%
+% \begin{figure}[hbtp]
+% \begin{center}$\vdots$\end{center}
+% \begin{song}
+% \scene{Bandet spiller "`Bohemian Rhapsody"' af Queen,
+% udelukkende på
+% didgeridoo.}
+% \sings{A9} Åh, Per Hede
+% Er den lede
+% Og han dumped' mig i kvant!
+%
+% \sings{PH} Per Hedegaard har er reeksamenssæt til dig
+% \end{song}
+% \begin{center}$\vdots$\end{center}
+% \caption{Et eksempel på, hvordan sangtekster typesættes, med
+% miljøet \texttt{song}.}
+% \label{songex}
+% \end{figure}
+% \end{danish}
+% \begin{english}
+% \changes{v1.0.0}{2023/09/05}{The body text macros
+% (\texttt{\textbackslash scene}, etc.) are no longer available
+% outside the \texttt{song} and \texttt{sketch} environments.}
+% The \verb|song| environment is for song lyrics, which are set as
+% demonstrated in figure \ref{songex}.
+%
+% \begin{figure}[hbtp]
+% \begin{center}$\vdots$\end{center}
+% \begin{song}
+% \sings{CC} ...be silly chumps,
+% Just purse you're lips and whistle,
+% That's the thing.
+%
+% And, always look on the bright side of life,
+% \end{song}
+% \begin{center}$\vdots$\end{center}
+% \caption{An example of how song lyrics are typeset, using the
+% \texttt{song} environment.}
+% \label{songex}
+% \end{figure}
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% \verb|song|--miljøet er også implementeret ud fra \verb|list|
+% og \verb|revy at bodycommon|.
+% \end{danish}
+% \begin{english}
+% The \verb|song| environment is also implemented as a
+% derivative of \verb|list| and uses \verb|revy at bodycommon|.
+% \end{english}
+% \begin{macrocode}
+\newenvironment{song}{%
+ \begin{revy at bodycommon}
+ \rm\begin{list}{}{%
+ \raggedright
+ \labelwidth 4.5em
+ \leftmargin 7em
+ \rightmargin 0em
+ \labelsep 2em
+ \listparindent -2em
+ \topsep 0ex
+ \partopsep \bigskipamount
+ \parsep .6\baselineskip
+ \itemsep -.6\baselineskip
+ \relax
+ }
+ \item[] \rule{0.2em}{0em}\vspace{-\baselineskip}\strut\par %}
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{macro}{\sings}
+% \begin{danish}
+% Inde i \verb|song|--miljøet sætter makroen \verb|\sings|
+% sangstrofer. Den fulde syntaks er
+%
+% \begin{showcommand}
+% \verb|\sings|\marg{fk.}\oarg{instruktion} \meta{sangtekst}
+% \end{showcommand}
+%
+% Linjeskift er vigtige i sangtekster, så \verb|song|--miljøet
+% ændrer, hvordan \LaTeX\ reagerer på linjeskift i kildefilen. For
+% eksempel kan \textbf{A9}'s strofer i figur \ref{songex} kreeres
+% med denne kildekode:
+% \begin{verbatim}
+% \sings{A9} Åh, Per Hede
+% Er den lede
+% Og han dumped' mig i kvant!
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% Within the \verb|song| environment, the macro \verb|\sings| sets
+% song lyrics. Its full syntax is
+% \begin{showcommand}
+% \verb|\sings|\marg{abr.}\oarg{direction} \meta{lyric}
+% \end{showcommand}
+%
+% Line breaks are significant in song lyrics, and so the
+% \verb|song| chanees how \LaTeX\ reacts to carriage returns in
+% the source file. For example, the lyric shown in figure
+% \ref{songex} is the product, in part, of this source code:
+% \begin{verbatim}
+% \sings{CC} ...be silly chumps,
+% Just purse you're lips and whistle,
+% That's the thing.
+% \end{verbatim}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% \verb|\sings| og \verb|\scene| skifter frem og tilbage mellem
+% to endnu mere forskellige tilstande, end \verb|\says| og
+% \verb|\scene| i \verb|sketch|--miljøet. Læg især mærke til
+% brugen af \verb|\obeycr| og \verb|\restorecr|.
+% \end{danish}
+% \begin{english}
+% \verb|\sings| and \verb|\scene| shift back and forth between
+% to even more different states within the \verb|song|
+% environment than was the case in \verb|sketch|. Much of the
+% magic relates to the macros \verb|\obeycr| and
+% \verb|\restorecr|.
+% \end{english}
+% \begin{macrocode}
+ \newdimen\old at leftskip
+ \old at leftskip \leftskip
+ \newdimen\short at leftskip
+ \short at leftskip \leftskip
+ \advance\short at leftskip -5.5em
+% \end{macrocode}
+% \begin{macro}{\sings}
+% \begin{macrocode}
+\def\sings##1{\obeycr
+ \@ifnextchar [{\@singsas{##1}}{\@sings{##1}}} %}
+\def\@singsas##1[##2]{\rm\item [\hskip\@leftsingpad{\bf ##1 }{\it
+ (##2)\,}:\hskip\@rightsingpad]\hskip-2em\leftskip \old at leftskip}
+\def\@sings##1{\rm\item [\hskip\@leftsingpad{\bf ##1\,}:\hskip
+ \@rightsingpad]\hskip-2em\leftskip \old at leftskip}
+% \end{macrocode}
+% \end{macro}
+% \begin{macro}{\scene}
+% \begin{macrocode}
+\let\old at sings=\sings
+\def\scene{%
+ \def\sings{\let\sings=\old at sings \medskip\sings}
+ \medskip\par\leftskip \short at leftskip \restorecr
+ \it\noindent\relax
+}
+% \end{macrocode}
+% \end{macro}
+%
+% \begin{danish}
+% \verb|\@leftsingpad| og \verb|\@rightsingpad| gør det muligt, at
+% stille sangtekster til at være venstre- eller højrejusterede.
+% \end{danish}
+% \begin{english}
+% \verb|\@leftsingpad| and \verb|\@rightsingpad| allow us to set
+% lyrics to be left or right justfied.
+% \end{english}
+% \begin{macrocode}
+ \newskip\@leftsingpad
+ \newskip\@rightsingpad
+ \def\flushsingsright{\@leftsingpad 0pt plus 1fill\@rightsingpad 0pt\relax}
+ \def\flushsingsleft{\@leftsingpad 0pt\@rightsingpad 0pt plus 1fill\relax}
+% \end{macrocode}
+% \begin{danish}
+% Som standard sætter vi venstrejustering.
+% \end{danish}
+% \begin{english}
+% We set left justification as the default.
+% \end{english}
+% \begin{macrocode}
+ \flushsingsleft
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{implementation}
+% \begin{danish}
+% Vi kalder \verb|\obeycr| her, sammen med nogle kommandoer, som
+% fortæller \LaTeX, at den ikke skal bekymre sig så meget om
+% længderne på linjer.
+% \end{danish}
+% \begin{english}
+% We call \verb|\obeycr| here, along with some macros that get
+% \LaTeX\ to be less concerned about the proper length of lines.
+% \end{english}
+% \begin{macrocode}
+ \tolerance10000\hfuzz21cm\obeycr
+}{
+ \end{list}
+ \end{revy at bodycommon}
+}
+% \end{macrocode}
+% \end{implementation}
+%
+% \begin{implementation}
+% \begin{macro}{\obeycr}
+% \begin{macro}{\restorecr}
+% \begin{danish}
+% Makroerne, som gør linjeskift--magien mulig, er
+% \end{danish}
+% \begin{english}
+% The macros that make the line breaking magic possible, are
+% \end{english}
+% \begin{macrocode}
+\newif\if at newpar
+{
+ \catcode`\^^M=13
+% \end{macrocode}
+% \begin{danish}
+% Så nu skal vi passe på med vores linjeskift her i koden...
+% \end{danish}
+% \begin{english}
+% At this point, we must be careful with carriage returns in the
+% code itself...
+% \end{english}
+% \begin{macrocode}
+ \gdef\@carriagereturn{%
+ \@ifnextchar^^M{%
+ \@newpartrue%
+ }{%
+ \@ifnextchar\end{}{%
+ \@ifnextchar\sings{%
+ \if at newpar\bigskip\par\fi\@newparfalse%
+ }{%
+ \if at newpar\par\else\\\fi\@newparfalse%
+ }%
+ }%
+ }%
+ }%
+ \gdef\obeycr{%
+ \catcode`\^^M=13 %
+ \let^^M=\@carriagereturn%
+ \@gobblecr%
+ }%
+ \gdef\restorecr{\catcode`\^^M=5 }%
+}
+% \end{macrocode}
+% \end{macro}
+% \end{macro}
+% \end{implementation}
+% \end{environment}
+%
+% \begin{danish}
+%
+% \subsubsection{Fælles for \texttt{sketch} og \texttt{song}}
+% Vi har også de følgende makroer, som kan bruges i både
+% \verb|song|- og \verb|sketch|--miljøerne:
+% \end{danish}
+% \begin{english}
+% \subsubsection{Both \texttt{sketch} and \texttt{song}}
+% The \verb|sketch| and \verb|song| macros both provide the
+% following macros:
+% \end{english}
+% \begin{implementation}\label{bodycommon}
+% \begin{environment}{revy at bodycommon}
+% \begin{danish}
+% De bliver pakket i miljøet \verb|revy at bodycommon|.
+% \end{danish}
+% \begin{english}
+% They are packaged in the environment \verb|revy at bodycommon|.
+% \end{english}
+% \DescribeEnv{revy at bodycommon}
+% \begin{macrocode}
+\newenvironment{revy at bodycommon}{
+% \end{macrocode}
+% ^^A}
+% \end{environment}
+% \end{implementation}
+%
+% \begin{macro}{\role}
+% \begin{danish}
+% En makro til at formattere rolleforkortelser i teksten.
+% \end{danish}
+% \begin{english}
+% A macro for formatting role abbreviations within the text.
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% Den her makro har det samme navn som indgangskommandoen i
+% \verb|roles|--miljøet. Men det er fint, for den bliver
+% defineret inde i \verb|roles|'s interne \verb|group|.
+% \end{danish}
+% \begin{english}
+% This macro has the same name as the item command inside the
+% \verb|roles| environment. But it's OK, because that command is
+% defined inside \verb|roles|'s internal \verb|group|.
+% \end{english}
+% \begin{macrocode}
+ \let\role = \textbf
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\does}
+% \begin{danish}
+% \changes{v1.0.0}{2023/09/05}{Ny makro}
+% En makro til at give instruktioner til en bestemt rolle, som
+% ikke er en talt replik, som for eksempel
+% \begin{verbatim}
+%\does{I} reagerer med åbenmundet vantro.
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% \changes{v1.0.0}{2023/09/05}{New macro}
+% A macro for giving instructions for a particular role that
+% aren't a spoken line, such as
+% \begin{verbatim}
+%\does{KA} attempts to sidle away.
+% \end{verbatim}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% Udrykningen på 1em er en hårdt indkodet længde, som passer
+% til, hvordan \verb|song| og \verb|sketch| er sat op lige
+% nu. Jeg er sikker på den ikke kommer til at hoppe op og bide
+% nogen bagi senere...
+% \end{danish}
+% \begin{english}
+% The 1em exdent is a hardcoded length that matches how
+% \verb|song| and \verb|sketch| are defined right now. I'm sure
+% it won't jump up and bite anyone in the future...
+% \end{english}
+% \begin{macrocode}
+ \def\does##1{\scene \hspace{-1em}\role{##1}}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\scene}\label{sceneuse}
+% \begin{danish}
+% \verb|\scene| bruges til regibemærkninger, som for eksempel
+% \begin{verbatim}
+% \scene Hvert bandmedlem holder sin egen didgeridoo op.
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% \verb|\scene| is used for stage directions, such as
+% \begin{verbatim}
+% \scene P \& KA are startled.
+% \end{verbatim}
+% \end{english}
+% \begin{implementation}
+% \begin{danish}
+% \verb|\scene| blev implementeret inde i \verb|sketch|- og
+% \verb|song|--miljøerne.
+% \end{danish}
+% \begin{english}
+% \verb|\scene| was implemented inside the \verb|sketch| and
+% \verb|song| environments.
+% \end{english}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{macro}{\act}
+% \begin{danish}
+% \verb|\act| er til instruktioner, som for eksempel
+% \begin{verbatim}
+% (...) \act{Vender sig mod Bandet} Bandet, har I...?
+% \end{verbatim}
+% \end{danish}
+% \begin{english}
+% \verb|\act| is for directions, such as in
+% \begin{verbatim}
+% (...) It's him! \act{Back at KA} How did you get here?
+% \end{verbatim}
+% \end{english}
+% \begin{implementation}
+% \begin{macrocode}
+ \def\act##1{\textit{(##1)}}
+% \end{macrocode}
+% \end{implementation}
+% \end{macro}
+%
+% \begin{danish}
+% De blev begge brugt til at lave eksemplet i figur \ref{sketchex}.
+% \end{danish}
+% \begin{english}
+% Both were used in the example in figure \ref{sketchex}.
+% \end{english}
+%
+% \begin{implementation}
+% \begin{danish}
+% Og her afslutter vi miljøet \verb|revy at bodycommon|.
+% \end{danish}
+% \begin{english}
+% And here, we end the the environment \verb|revy at bodycommon|.
+% \end{english}
+% \begin{macrocode}
+}{}
+% \end{macrocode}
+% \end{implementation}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+% \fi
+%
+% \begin{implementation}
+% \begin{danish}
+% \subsection{\texttt{.aux}--filen}
+% Til fremtidigt brug sørger vi for, at vores metadata også bliver
+% skrevet ud til \texttt{.aux}--filen, når dokumentet er færdigt.
+%
+% Det er også her, vi sætter en \texttt{label} på den sidste side.
+% \end{danish}
+% \begin{english}
+% \subsection{The \texttt{.aux} file}
+% For futue use, we will also ensure that our metadata is written
+% to the \texttt{.aux} file at the end of the document.
+%
+% This is also where we \texttt{label} the last page.
+% \end{english}
+% \begin{macrocode}
+\let\revyinfo=\relax
+\newtoks\@titletoks
+\newtoks\@authortoks
+\newtoks\@melodytoks
+\newtoks\@revyrevynametoks
+\newtoks\@revyrevyyeartoks
+\let\end at document=\enddocument
+\def\enddocument{\label{lastpage}\write\@auxout
+ {\string\@ifundefined{revyinfo}{\string\def\string
+ \revyinfo\string##1\string##2\string##3\string
+ ##4\string##5\string##6\string##7\string##8{}}{}}\@titletoks=
+ \expandafter{\@title}\@titletoks=
+ \expandafter{\@title}\@authortoks=
+ \expandafter{\@author}\@melodytoks=
+ \expandafter{\@melody}\@revyrevynametoks=
+ \expandafter{\@revyname}\@revyrevyyeartoks=
+ \expandafter{\@revyyear}\write\@auxout
+ {\string\revyinfo{\the\@titletoks}{\@version}
+ {\today}%
+ {\the\@authortoks}%
+ {\the\@melodytoks}%
+ {}%
+ {\the\@revyrevynametoks}%
+ {\the\@revyrevyyeartoks}%
+ }%
+ \end at document
+}
+% \end{macrocode}
+% \end{implementation}
+%
+% \appendix
+% \bibliography{ucph-revy}
+% \begin{implementation}
+% \PrintIndex
+% \end{implementation}
+% \begin{danish}
+% \section{Komplet eksempel}
+% \label{fullex}
+% \VerbatimInput{Eksempel.tex}
+% \end{danish}
+% \begin{english}
+% \section{Complete example}
+% \label{fullex}
+% \VerbatimInput{Example.tex}
+% \end{english}
+%
+% \iffalse
+%</class>
+%<*ex-da>
+\documentclass{ucph-revy}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage[danish]{babel}
+\usepackage{hyperref}
+%<*driver>
+\land
+\def\exDaPre{
+%</driver>
+\urlstyle{sf}
+
+\version{1.0}
+\revyname{FysikRevy\texttrademark}
+\revyyear{2019}
+\status{eksempel}
+\eta{$1$ minut, $47$ sekunder}
+\responsible{Dig}
+
+\title{Eksempel}
+\author{en eksempelsmed}
+\melody{Queen: „Bohemian Rhapsody`` (\url{https://youtu.be/fJ9rUzIMcZQ})}
+%<*driver>
+}
+\def\exDaPOne{
+%</driver>
+
+\begin{document}
+\maketitle
+
+\begin{roles}
+ \role{PH}[Jophiel] Per Hedegaard
+ \role{I} Vred instruktør
+ \role{A9}[A--ni] Anine
+\end{roles}
+\begin{props}
+ \prop{Hedegaard--hår}[Person, der skaffer]
+ \prop{Didgeridoo}[Anine]
+\end{props}
+
+\begin{sketch}
+ \scene{Lys op}
+ \says{PH} Hej venner. I den her sketch, der spiller jeg Per
+ Hedegaard. Det kan man se ud fra farven på mit hår. Men bare rolig,
+ jeg er ikke Per Hedegaard i virkeligheden, der er ikke nogen
+ regneøvelser, I har glemt at lave.
+
+ Se, hvis jeg tager håret af \act{fjerner parykken}, så er det helt
+ tydeligt, at jeg ikke er den rigtige Hedegaard.
+
+ \says{I}[Stormer ind på scenen] \emph{NEEEEEJ}, for helvede. Du må
+ ikke pille ved den fjerde væg. Det er simpelthen så uprofessionelt,
+ det der!
+
+ \says{PH} Se, venner, det var meningen, at der skulle have været en
+ anden replik der, men fordi der ikke er sat nogen på den rolle i
+ rollelisten, så kunne vi ikke høre nogen som helst kritik af min
+ performance.
+
+ \does{I} reagerer med åbenmundet vantro.
+
+ \says{PH} Det må også være svært at følge skuepil--instruktioner,
+ når man ikke eksisterer, kan jeg forestille mig.
+
+ \says{A9} Hej Jophiel.
+ \does{PH} tager sin paryk på igen.
+ \says{A9} Hej, Per Hedegaard.
+ \says{A9} Var det ikke meningen, at det her skulle være en sang?
+ \says{PH} Jo, for dælen. Har du en didgeridoo med?
+ \says{A9} Didgeridoo?
+ \says{PH} Ja. Der står i rekvisitlisten, at du skaffer en.
+ \says{A9} Jamen så må det jo passe.
+ \says{PH} Ja, ellers skriver vi "`Person, der skaffer,"' for at
+ minde os om at skrive et navn ind.
+ \says{A9} Nå, men så må jeg jo hellere begynde at lede. \act{Vender
+ sig mod Bandet} Bandet, har I...?
+%<*driver>
+\end{sketch}
+\end{document}
+}
+\def\exDaPTwo{
+ \begin{document}
+ \begin{sketch}
+%</driver>
+ \scene{Hvert bandmedlem holder sin egen didgeridoo op.}
+ \says{A9}[Til PH] Den ser ud til at være i vinkel.
+ \says{PH} Sejt.
+ \says{PH}[Råber til Bandet] Og \emph{tre!} \emph{Fire!}
+\end{sketch}
+%<*driver>
+}
+\catcode`\^^M=13%
+\def\exDaPThree{%
+%</driver>
+\begin{song}%
+%<*driver>
+ % \restorecr doesn't work, if the cr's have already been tokenized,
+ % so we need to do something else
+ \let\old at scene=\scene%
+ \let\old at cr=^^M%
+ \def\scene{\old at scene\def^^M{ \relax}}%
+ \let\old at sings\sings%
+ \def\sings{\let^^M=\old at cr \old at sings}%
+%</driver>
+ \scene{Bandet spiller ``Bohemian Rhapsody" af Queen, udelukkende på
+ didgeridoo.}
+
+ \sings{A9} Åh, Per Hede
+ Er den lede
+ Og han dumped' mig i kvant!
+
+ \sings{PH} Per Hedegaard har er reeksamenssæt til dig
+ \sings{A9} Til mig?
+ \sings{PH} Til dig!
+ \scene{Episk didgeridoo--solo, mens A9 løser reeksamenssæt.}
+
+ \scene ...
+
+ \does{A9} rækker hånden i vejret, og bandet stopper.
+\end{song}%
+%<*driver>
+}\catcode`\^^M=5
+\def\exDaPFour{
+%</driver>
+\begin{sketch}
+ \says{PH}[Er et stykke tid om at lægge mærke til A9, men kommer til
+ sidst over] Ja, spørgsmål?
+ \says{A9} Det her eksamenssæt er jo trivielt...?
+ \scene{Lys ned}
+\end{sketch}
+
+\end{document}
+%</ex-da>
+%<*driver>
+}
+\jump
+%</driver>
+%<*ex-en>
+\documentclass{ucph-revy}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage{hyperref}
+%<*driver>
+\land
+\def\exEnPre{
+%</driver>
+\urlstyle{sf}
+
+\version{1.0}
+\revyname{The Meaning of Liff}
+\revyyear{3001}
+\title{Example}
+\author{an examplesmith}
+\status{example}
+\eta{$1$ minute, $47$ seconds}
+\responsible{Probably you}
+\melody{Monty Python: ``Always look on the bright side of life''
+ (\url{https://youtu.be/SJUhlRoBL8M})}
+
+\writtenbyname{written by}
+\melodyname{Melody:}
+\responsibletext{\TeX--responsible}
+
+%<*driver>
+\renewcommand{\pagessum}[1]{##1 page\ifnum##1=1\else s\fi}
+}
+\iffalse
+%</driver>
+\renewcommand{\pagessum}[1]{#1 page\ifnum#1=1\else s\fi}
+%<*driver>
+\fi
+\def\exEnPOne{
+%</driver>
+
+\begin{document}
+\maketitle
+
+\rolename{Roles:}
+\begin{roles}
+ \role{KA}[Graham] Arthur, king of all the Britons
+ \role{P}[Michael] Peasant
+ \role{RC}[John] Roman Centurion
+ \role{R1...?} Several Roman Soldiers
+ \role{CC}[Eric] Crucified Criminal
+ \role{B}[Graham] Brian
+\end{roles}
+\propname{Props:}
+\begin{props}
+ \prop{Large sign}
+ \prop{Field of crosses}
+\end{props}
+
+\begin{sketch}
+ \scene Lights up on a muddy field with a castle in the background.
+
+ \says{KA}[As he enters] Hello!
+
+ \says{KA} Now, by rights, you should all be kneeling, given that I
+ am Arthur, king of all the Britons. However, it has been brought to
+ my attention that the audence seating is not laid out to allow for
+ that. We had some considerable trouble during dress rehearsals. So I
+ will excuse you from that requirement.
+
+ Now, has anyone seen a particularly fancy cup? Perhaps out
+ in the bar? You see, I am on a quest given to me by God, to find the
+ holy... \act{Interrupted, as he steps in a hole.} Oh dear...
+
+ \says{P}[Shrieking, as he rears up from the ground] Oi! What do you
+ think you're doing!
+
+ \says{P} You broke my sign!
+
+ \says{KA} Sign? What sign?
+
+ \says{P} Well, look.
+
+ \does{P} raises up a sign that reads
+
+ \begin{center}\sc Romanes Eunt Dom[ ]\end{center}
+
+ The last bit of the sign has a foot--shaped hole in it.
+
+ \says{P} You can't read it anymore!
+
+ \says{KA} You certainly can! It says ``Romans go home.''
+
+ \says{RC}[Appears from offstage] No it doesn't.
+
+ \does{P \& KA} are startled.
+
+%<*driver>
+\end{sketch}
+\end{document}
+}
+\def\exEnPTwo{
+ \begin{sketch}
+%</driver>
+ \says{RC}[To KA] Did you write th... wait a minute. \act{Off stage}
+ It's him! \act{Back at KA} How did you get here?
+
+ \does{KA} attempts to sidle away.
+
+ \says{RC} Get him!
+
+ \scene Several Roman soldiers appear, and drag \role{KA} off stage,
+ while \role{KA} attempts to protest.
+
+ \says{KA}[As he is dragged off] I am not him! I am Arthur, King of
+ the Britons!
+
+ \scene The scene changes to a field of crosses, with several
+ crucified criminals and B.
+
+ \does{CC} is in the middle of singing to \role{B}.
+\end{sketch}
+%<*driver>
+}
+\catcode`\^^M=13%
+\def\exEnPThree{%
+%</driver>
+\begin{song}%
+%<*driver>
+ % \restorecr doesn't work, if the cr's have already been tokenized,
+ % so we need to do something else
+ \let\old at scene=\scene%
+ \let\old at cr=^^M%
+ \def\scene{\old at scene\def^^M{ \relax}}%
+ \let\old at sings\sings%
+ \def\sings{\let^^M=\old at cr \old at sings}%
+%</driver>
+ \sings{CC} ...be silly chumps,
+ Just purse you're lips and whistle,
+ That's the thing.
+
+ And, always look on the bright side of life,
+ Always look on the right side of life,
+ For life is quite absurd,
+ An. death's the final word...
+\end{song}
+%<*driver>
+}\catcode`\^^M=5
+\def\exEnPFour{
+\begin{document}
+%</driver>
+\begin{sketch}
+ \says{RC}[Shouting as he walks on stage] Right, you lanky reprobate!
+ Don't think that the mighty Roman bureaucracy doesn't keep track of
+ its inmates
+
+ \scene KA is dragged on stage by two Roman soldiers behind RA.
+
+ \says{RA} Look, we have your designated cross ready for you
+ right... \act{points to B'a cross, then falters when he notices
+ B.}
+
+ \scene Everyone looks back and forth between B and KA.
+
+ \scene End scene
+\end{sketch}
+\end{document}
+}
+%</ex-en>
+%\fi
+%\begin{danish}
+%
+%\section{Eksempel på registerindeks}\label{registerindeks}
+% \end{danish}
+% \begin{english}
+% \section{Example of a thumb index page}\label{registerindeks}
+% \end{english}
+% \iffalse
+%<*driver>
+\jump
+%</driver>
+%<*registerindex>
+% \fi
+%\begin{verbatim}
+
+\documentclass[a4paper,11pt,thumbindex]{article}
+
+\usepackage[utf8]{inputenc}
+\usepackage[T1]{fontenc}
+\usepackage[danish]{babel}
+\usepackage{calc}
+\usepackage{tikz}
+
+\version{1.0}
+\title{Registerindeks}
+
+\begin{document}
+\thispagestyle{empty}
+\newlength{\torightside}
+\setlength{\torightside}{ \paperwidth - 1in - \hoffset %
+ - \oddsidemargin + .6cm}
+\newlength{\totop}
+\setlength{\totop}{ -\headsep - \headheight - \topmargin %
+ - \voffset - 1in - .5cm}
+
+\vbox to 0pt{\vskip \totop \hbox to \torightside{\hss%
+ \rectothumbindexwithtitles%
+ }}
+\vbox to 0pt{\tikz \path (0,0) -- (0, -.5\textheight)
+ node[rotate=90]{\parbox{\textheight}{\maketitle}}; }
+\end{document}
+%\end{verbatim}
+% \iffalse
+%</registerindex>
+%<*driver>
+\land
+%</driver>
+% \fi
+\endinput
+% Local Variables:
+% mode: doctex
+% TeX-master: t
+% End:
Property changes on: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.dtx
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.ins
===================================================================
--- trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.ins (rev 0)
+++ trunk/Master/texmf-dist/source/latex/ucph-revy/ucph-revy.ins 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,40 @@
+\input docstrip.tex
+\keepsilent
+\usedir{tex/latex/ucph-revy}
+\askforoverwritefalse
+\preamble
+This is a generated file.
+
+Copyright (C) 1995 Arne John Glenstrup
+ 2000 Uffe Friis Lichtenberg
+ 2023 Kristoffer Levin Hansen
+
+This file may be distributed and/or modified under the
+conditions of the LaTeX Project Public License, either
+version 1.3 of this license or (at your option) any later
+version. The latest version of this license is in:
+
+http://www.latex-project.org/lppl.txt
+
+and version 1.3 or later is part of all distributions of
+LaTeX version 2005/12/01 or later.
+\endpreamble
+\generate{\file{ucph-revy.cls}{\from{ucph-revy.dtx}{class}}}
+\obeyspaces
+\Msg{****************************************************}
+\Msg{* *}
+\Msg{* To finish the installation you have to move the *}
+\Msg{* following file into a directory searched by TeX: *}
+\Msg{* *}
+\Msg{* ucph-revy.cls *}
+\Msg{* *}
+\Msg{* To produce the documentation run the file *}
+\Msg{* ucph-revy-en-doc.ins through LaTeX. *}
+\Msg{* To produce the user manual, or documentation in}
+\Msg{* danish, run the corresponding .ins file thorugh}
+\Msg{* LaTeX. See the README file for the full list.}
+\Msg{* *}
+\Msg{* Happy TeXing! *}
+\Msg{* *}
+\Msg{****************************************************}
+\endbatchfile
Added: trunk/Master/texmf-dist/tex/latex/ucph-revy/ucph-revy.cls
===================================================================
--- trunk/Master/texmf-dist/tex/latex/ucph-revy/ucph-revy.cls (rev 0)
+++ trunk/Master/texmf-dist/tex/latex/ucph-revy/ucph-revy.cls 2023-09-09 20:10:33 UTC (rev 68224)
@@ -0,0 +1,576 @@
+%%
+%% This is file `ucph-revy.cls',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% ucph-revy.dtx (with options: `class')
+%% This is a generated file.
+%%
+%% Copyright (C) 1995 Arne John Glenstrup
+%% 2000 Uffe Friis Lichtenberg
+%% 2023 Kristoffer Levin Hansen
+%%
+%% This file may be distributed and/or modified under the
+%% conditions of the LaTeX Project Public License, either
+%% version 1.3 of this license or (at your option) any later
+%% version. The latest version of this license is in:
+%%
+%% http://www.latex-project.org/lppl.txt
+%%
+%% and version 1.3 or later is part of all distributions of
+%% LaTeX version 2005/12/01 or later.
+\NeedsTeXFormat{LaTeX2e}[2005/12/01]
+\ProvidesClass{ucph-revy}
+ [2023/05/23 v1.0.0 Initial publish]
+\RequirePackage{xstring}
+\newif\if at thumbindex\@thumbindexfalse
+\DeclareOption{thumbindex}{\@thumbindextrue}
+\newcommand{\planfile}{aktoversigt.plan}
+\DeclareOption*{
+ \IfBeginWith{\CurrentOption}{planfile=}{
+ \def\planfile#1=#2{#2}
+ \edef\planfile{\expandafter\planfile\CurrentOption}
+ }{
+ \PassOptionsToClass{\CurrentOption}{article}
+ }
+}
+\ProcessOptions\relax
+\LoadClass[a4paper,11pt]{article}
+\setlength{\topmargin}{0cm}
+\setlength{\voffset}{-1cm}
+\setlength{\textheight}{\paperheight}
+\addtolength{\textheight}{-4cm}
+\if at thumbindex
+ \expandafter\@firstofone
+\else
+ \expandafter\@gobble
+\fi{
+ \RequirePackage[T1]{fontenc}
+ \begingroup
+ \count256=0
+ \endlinechar=-1
+ \newtoks\tabtoks
+ \newread\tabtex
+ \newread\planread
+ \openin\planread=\planfile
+ \def\expandFiHere#1\fi{\fi #1}
+ \def\patheat#1/#2{%
+ \ifx\relax#2\else
+ \expandFiHere#1/\patheat#2%
+ \fi
+ }
+ \edef\planpath{\expandafter\patheat\planfile/\relax}
+ \def\titleeater#1#2\title#3{%
+ \ifx\done#3%
+ #1%
+ \else
+ \expandFiHere
+ \titleeater{#3}%
+ \fi
+ }
+ \loop\ifeof\planread
+ \closein\planread
+ \else
+ \ifeof\tabtex
+ \let\readline\empty
+ \read\planread to \line
+ \expandafter\ifx\expandafter\par\line\else
+ \IfEndWith{\line}{.tex}{
+ \advance\count256 by 1
+ \set at curr@file{\line}
+ \openin\tabtex={\planpath\@curr at file}
+ }{%
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\undertab
+ \number\count256
+ \noexpand\text
+ \line
+ \noexpand\stop
+ }}\act
+ }
+ \fi
+ \else
+ \read\tabtex to \subline
+ \edef\readline{%
+ \expandafter\titleeater
+ \expandafter\readline\subline\title\done
+ }
+ \ifeof\tabtex
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\overtab
+ \number\count256
+ \noexpand\text
+ \readline
+ \noexpand\stop
+ }}\act
+ \fi
+ \fi
+ \repeat
+ \closein\tabtex
+ \edef\act{\noexpand\tabtoks={%
+ \the\tabtoks
+ \noexpand\undertab
+ \number\count256
+ \noexpand\text
+ \noexpand\done
+ \noexpand\stop
+ }}\act
+ \xdef\revy at tabs{\the\tabtoks}
+ \endgroup
+ \RequirePackage{tikz}
+ \def\revy at thumbindex#1{%
+ \begingroup
+\def\expandFiHere##1\fi{\fi ##1}
+ \newdimen\tabheight
+ \tabheight=\paperheight
+ \advance\tabheight by -1cm%
+ \def\undertab##1\text##2\stop{
+ \ifx\done##2%
+ \divide\tabheight by ##1%
+ \fi
+ }
+ \def\overtab##1\text##2\stop{}%
+ \revy at tabs
+ \def\overtableft{-1cm}
+ \def\overtabright{1cm}
+ \def\undertabright{\overtabright}
+ \def\undertableft{\overtableft - 1cm}
+ \def\underangle{|-}
+ \def\underpos{.25}
+ \def\undersign{}
+ \def\underlabeloffset{\undersign.5cm}
+ \def\textanchorcorner{east}
+ \def\textoffset{\undertableft - .5cm}
+ \def\textside{right}
+ \def\movetoleftside{
+ \def\overtableft{-1.8cm}
+ \def\overtabright{.2cm}
+ \def\undertabright{\overtabright + 1cm}
+ \def\undertableft{\overtableft}
+ \def\underangle{-|}
+ \def\undersign{-}
+ \def\underpos{.75}
+ \def\textanchorcorner{west}
+ \def\textoffset{\undertabright + .5cm}
+ \def\textside{left}
+ }
+\newif\ifwritetitles\writetitlesfalse
+ \def\printovertab##1##2{
+ \fill ( 0, -##1\tabheight )
+ node[ text=white, anchor=east ]{\bfseries##1}
+ +( \overtableft, -.5\tabheight + 1mm )
+ rectangle +( \overtabright, .5\tabheight - 1mm )
+ +( \textoffset, 0 )
+ \ifwritetitles
+ node[ anchor=\textanchorcorner ]{\small\bfseries##2}
+ \fi
+ ;
+ }%
+ \def\printundertab##1##2##3{%
+ \path ( 0, -##1\tabheight ) +( \undertabright, -.5\tabheight - 1mm )
+ coordinate (topright);
+ \path ( 0, -##2\tabheight ) +( \undertableft, -.5\tabheight + 1mm )
+ coordinate (bottomleft);
+ \fill[ color=black!30 ] (topright) rectangle (bottomleft);
+ \path (bottomleft)
+ \underangle node[ xshift=\underlabeloffset,
+ pos=\underpos,
+ rotate=\undersign90
+ ]{\Large##3}
+ (topright);
+ }%
+ \def\overtab##1\text##2\stop{%
+ \printovertab{##1}{##2}
+ }
+ \def\undertab##1\text##2\stop{
+ \ifx\done##2\else
+ \let\undertab\undertabspan
+ \expandFiHere
+ \undertab##1\text##2\stop
+ \fi
+ }
+ \def\undertabspan##1\text##2\stop##3\undertab##4\text##5\stop{%
+ \printundertab{##1}{##4}{##2}%
+ ##3%
+ \ifx\done##5\else
+ \expandFiHere
+ \undertab##4\text##5\stop
+ \fi
+ }%
+ \def\filtername##1{
+ \def\doWhenMatch{}
+ \def\overtab####1\text####2\stop{
+ \IfStrEq{##1}{####2}{
+ \doWhenMatch
+ \printovertab{####1}{####2}
+ }{}
+ }
+ \def\undertabspan####1\text####2\stop####3\undertab####4\text####5\stop{
+ \def\doWhenMatch{
+ \printundertab{####1}{####4}{####2}
+ \def\doWhenMatch{}
+ }
+ ####3
+ \ifx\done####5\else
+ \expandFiHere
+ \undertab####4\text####5\stop
+ \fi
+ }
+ }
+ #1
+ \begin{tikzpicture}
+ \revy at tabs
+ \path (0, 0) -- (0, -\paperheight + .5cm);
+ \end{tikzpicture}
+ \endgroup
+ }
+ \newcommand{\rectothumbtabfor}[1]{
+ \revy at thumbindex{
+ \filtername{#1}
+ }
+ }
+ \newcommand{\rectothumbindexwithtitles}{
+ \revy at thumbindex{
+ \writetitlestrue
+ }
+ }
+ \newcommand{\rectothumbindex}{
+ \revy at thumbindex{}
+ }
+ \newcommand{\rectothumbtabwithtitlefor}[1]{
+ \revy at thumbindex{
+ \filtername{#1}
+ \writetitlestrue
+ }
+ }
+ \newcommand{\versothumbindex}{
+ \revy at thumbindex{
+ \movetoleftside
+ }
+ }
+ \newcommand{\versothumbindexwithtitles}{
+ \revy at thumbindex{
+ \movetoleftside
+ \writetitlestrue
+ }
+ }
+ \newcommand{\versothumbtabfor}[1]{
+ \revy at thumbindex{
+ \movetoleftside
+ \filtername{#1}
+ }
+ }
+ \newcommand{\versothumbtabwithtitlefor}[1]{
+ \revy at thumbindex{
+ \movetoleftside
+ \filtername{#1}
+ \writetitlestrue
+ }
+ }
+}
+\def\version#1{\def\@version{#1}}
+\def\@version{\@ifundefined{the at version}
+{\typein[\versionsnr]{Indtast revytekstens versionsnummer: }%
+\global\let\the at version=\versionsnr}{}\the at version}
+\def\revyname#1{\def\@revyname{#1}}
+\def\revyyear#1{\def\@revyyear{#1}}
+\def\@revyyear{1973}
+\def\@revyname{DIKUrevy}
+\def\@title{En sketch}
+\newif\if at author\@authorfalse
+\newif\if at status\@statusfalse
+\newif\if at eta\@etafalse
+\newif\if at responsible\@responsiblefalse
+\newif\if at melody\@melodyfalse
+\def\author#1{\def\@author{#1}\@authortrue}
+\def\status#1{\def\@status{#1}\@statustrue}
+\def\eta#1{\def\@eta{#1}\@etatrue}
+\def\responsible#1{\def\@responsible{#1}\@responsibletrue}
+\def\melody#1{\def\@melody{#1}\@melodytrue}
+\def\@author{}
+\def\@status{}
+\def\@eta{}
+\def\@responsible{}
+\def\@melody{}
+\let\auteurs\author
+\def\writtenbyname#1{\def\@writtenbyname{#1}}
+\def\melodyname#1{\def\@melodyname{#1}}
+\def\responsibletext#1{\def\@responsibletext{#1}}
+\def\statustext#1{\def\@statustext{#1}}
+\def\@writtenbyname{skrevet af}
+\def\@melodyname{Melodi:}
+\def\@responsibletext{\TeX--ansvarlig:}
+\def\@statustext{Status:}
+\newcommand{\pagessum}[1]{#1 side\ifnum1=#1\else r\fi}
+\def\maketitle{{\thispagestyle{empty}
+ \vspace*{-\headheight}\vspace*{-\headsep}
+ \centering{\Large\@revyname{} \@revyyear}\vspace{5pt}\\
+ {\LARGE \bf \@title}\vspace{5pt}\\
+ \if at author{\large\@writtenbyname{} \@author}\vspace{5pt}\\\fi
+ \if at melody{\sl\@melodyname{} \@melody}\vspace{5pt}\\\fi
+ \if at leftfields
+ \begin{varwidth}[t]{\bigheaderwidth}\raggedleft
+ \if at status{\@statustext{} \@status}\vspace{2pt}\\\fi
+ \if at responsible{\@responsibletext{} \@responsible}\vspace{2pt}\\\fi
+ \if at eta{(\@eta)}\\\fi
+ \end{varwidth}%
+ \ \hspace{.5em}\vrule{}\hspace{.5em}
+ \begin{varwidth}[t]{\smallheaderwidth}\raggedright
+ Version \@version\vspace{2pt}\\
+ \today\vspace{2pt}\\
+ \pagessum{\getpagerefnumber{lastpage}}
+ \end{varwidth}
+ \else
+ Version \@version
+ \ \hspace{.5em}\vrule\hspace{.5em}
+ \today
+ \ \hspace{.5em}\vrule\hspace{.5em}
+ \pagessum{\getpagerefnumber{lastpage}}
+ \fi
+ \vskip 5pt }}
+\RequirePackage{varwidth}
+\RequirePackage{refcount}
+\def\if at leftfields{
+ \def\@responsiblenum{\ifx\iftrue\if at responsible 1 \else 0 \fi}
+ \def\@statusnum{\ifx\iftrue\if at status 1 \else 0 \fi}
+ \def\@etanum{\ifx\iftrue\if at status 1 \else 0 \fi}
+ \ifnum1=\ifnum1=\@responsiblenum 1
+ \else \ifnum1=\@statusnum 1
+ \else \ifnum1=\@etanum 1
+ \else 0
+ \fi\fi\fi
+}
+\newlength{\smallheaderwidth}
+\setlength{\smallheaderwidth}{22ex}
+\newlength{\bigheaderwidth}
+\setlength{\bigheaderwidth}{\textwidth}
+\addtolength{\bigheaderwidth}{-\smallheaderwidth}
+\addtolength{\bigheaderwidth}{-1.5em}
+\gdef\ps at revyheadings{
+ \def\@oddhead{\vbox to 0pt{\vss
+ \hbox to \textwidth{\hfil\rectoheaderthumbtab}
+ \hbox{\rm\strut\@revyname{} \@revyyear}
+ \hbox to \textwidth{Version \@version\quad\today
+ \hfil {\large\sl\@title}\hfil
+ Side \rm\thepage/\pageref{lastpage}}
+ \hrule}}
+ \def\@evenhead{\vbox to 0pt{\vss
+ \hbox{\versoheaderthumbtab}
+ \hbox to \textwidth{\hfil\rm\strut\@revyname{} \@revyyear}
+ \hbox to \textwidth{Side \rm\thepage/\pageref{lastpage}
+ \hfil {\large\sl\@title}\hfil
+ Version \@version\quad\today}
+ \hrule}}
+ \def\@oddfoot{}\def\@evenfoot{}}
+\newcommand{\rectoheaderthumbtab}{%
+ \if at thumbindex
+ \rectothumbtabfor{\@title}%
+ \vspace*{ -\paperheight }\vspace*{ -\voffset }\vspace*{ 0.32in }%
+ \hspace{-\paperwidth }\hspace{ 1in }\hspace{ \oddsidemargin }%
+ \hspace{ \hoffset }\hspace{ \textwidth }\hspace{-.6cm}%
+ \fi
+}
+\newcommand{\versoheaderthumbtab}{%
+ \if at thumbindex
+ \hspace{ -2.5in }\hspace{ -\evensidemargin }%
+ \hspace{ -\hoffset }\hspace{ -1in }%
+ \versothumbtabfor{\@title}%
+ \vspace*{ -\paperheight }\vspace*{ -\voffset }\vspace*{ 0.32in }%
+ \fi
+}
+\pagestyle{revyheadings}
+\gdef\ps at empty{
+ \def\@oddhead{\vbox to 0pt{\vss
+ \hbox to \textwidth {\hfil\rectoheaderthumbtab }
+ \vbox to 2em{}}}
+ \def\@evenhead{\vbox to 0pt{\vss\hbox{\versoheaderthumbtab}}}
+ \def\@oddfoot{}\def\@evenfoot{}}
+\newenvironment{revy at list}[1]%
+{{\smallskip\noindent\Large\bf#1}
+ \begin{list}{}{
+ \labelwidth 8em
+ \leftmargin 10em
+ \rightmargin 0em
+ \labelsep 1em
+ \listparindent 0em
+ \topsep 1ex
+ \partopsep 0ex
+ \parsep 1ex
+ \itemsep -1ex\relax
+ }%
+ }%
+ {\end{list}\smallskip\hfil\rule{6cm}{0.1mm}\medskip\par}
+\def\revy at itemname#1{%
+ \def\@itemwithout##1{\item [{\bf ##1} \hfill] }
+ \def\@itemwith##1[##2]{\item [{\bf ##1} (##2) \hfill] }
+ \expandafter\def\csname #1\endcsname##1{%
+ \@ifnextchar [{\@itemwith{##1}}{\@itemwithout{##1}}%]
+ }
+}
+\newenvironment{roles}{
+ \begin{revy at list}{\@rolename}
+ \revy at itemname{role}
+ }{
+ \end{revy at list}
+}
+\newenvironment{props}{
+ \begin{revy at list}{\@propname}
+ \revy at itemname{prop}
+ }{
+ \end{revy at list}
+}
+\newenvironment{mics}{
+ \begin{revy at list}{\@micname}
+ \revy at itemname{mic}
+ }{
+ \end{revy at list}
+}
+\newenvironment{instructors}{
+ \begin{revy at list}{\@instructorname}
+ \def\@instructorwith[##1]{\item [{\bf ##1} \hfill] }
+ \def\@instructorwithout{\item}
+ \def\instructor{%
+ \@ifnextchar [{\@instructorwith}{\@instructorwithout}%]
+ }
+ }{
+ \end{revy at list}
+}
+\def\rolename#1{\def\@rolename{#1}}
+\def\propname#1{\def\@propname{#1}}
+\def\micname#1{\def\@micname{#1}}
+\def\instructorname#1{\def\@instructorname{#1}}
+\def\@rolename{Roller:}
+\def\@propname{Rekvisitter:}
+\def\@micname{Mikrofoner:}
+\def\@instructorname{Instruktører:}
+\newenvironment{sketch}{%
+ \begin{revy at bodycommon}
+ \rm\begin{list}{}{
+ \labelwidth 2em
+ \leftmargin 3em
+ \rightmargin 0em
+ \labelsep 0.5em
+ \listparindent 2em
+ \topsep 1ex
+ \partopsep 1ex
+ \parsep 0ex
+ \itemsep 1ex\relax}%
+ \item \rule{0.2em}{0em}\vspace{-1em}\par %}
+ \newdimen\old at leftskip
+ \old at leftskip \leftskip
+ \newdimen\short at leftskip
+ \short at leftskip \leftskip
+ \advance\short at leftskip -1.5em
+\def\says##1{\@ifnextchar [{\@saysas{##1}}{\@says{##1}}} %]
+\def\@saysas##1[##2]{\rm\item [{\bf ##1 }{\it (##2)\,}\hfill:]
+ \leftskip \old at leftskip}
+\def\@says##1{\rm\item [{\bf ##1\,}\hfill:]\leftskip \old at leftskip}
+\def\scene{\medskip\par\noindent\it\leftskip \short at leftskip }
+ }{%
+ \end{list}
+ \end{revy at bodycommon}
+}
+\newenvironment{song}{%
+ \begin{revy at bodycommon}
+ \rm\begin{list}{}{%
+ \raggedright
+ \labelwidth 4.5em
+ \leftmargin 7em
+ \rightmargin 0em
+ \labelsep 2em
+ \listparindent -2em
+ \topsep 0ex
+ \partopsep \bigskipamount
+ \parsep .6\baselineskip
+ \itemsep -.6\baselineskip
+ \relax
+ }
+ \item[] \rule{0.2em}{0em}\vspace{-\baselineskip}\strut\par %}
+ \newdimen\old at leftskip
+ \old at leftskip \leftskip
+ \newdimen\short at leftskip
+ \short at leftskip \leftskip
+ \advance\short at leftskip -5.5em
+\def\sings##1{\obeycr
+ \@ifnextchar [{\@singsas{##1}}{\@sings{##1}}} %}
+\def\@singsas##1[##2]{\rm\item [\hskip\@leftsingpad{\bf ##1 }{\it
+ (##2)\,}:\hskip\@rightsingpad]\hskip-2em\leftskip \old at leftskip}
+\def\@sings##1{\rm\item [\hskip\@leftsingpad{\bf ##1\,}:\hskip
+ \@rightsingpad]\hskip-2em\leftskip \old at leftskip}
+\let\old at sings=\sings
+\def\scene{%
+ \def\sings{\let\sings=\old at sings \medskip\sings}
+ \medskip\par\leftskip \short at leftskip \restorecr
+ \it\noindent\relax
+}
+ \newskip\@leftsingpad
+ \newskip\@rightsingpad
+ \def\flushsingsright{\@leftsingpad 0pt plus 1fill\@rightsingpad 0pt\relax}
+ \def\flushsingsleft{\@leftsingpad 0pt\@rightsingpad 0pt plus 1fill\relax}
+ \flushsingsleft
+ \tolerance10000\hfuzz21cm\obeycr
+}{
+ \end{list}
+ \end{revy at bodycommon}
+}
+\newif\if at newpar
+{
+ \catcode`\^^M=13
+ \gdef\@carriagereturn{%
+ \@ifnextchar^^M{%
+ \@newpartrue%
+ }{%
+ \@ifnextchar\end{}{%
+ \@ifnextchar\sings{%
+ \if at newpar\bigskip\par\fi\@newparfalse%
+ }{%
+ \if at newpar\par\else\\\fi\@newparfalse%
+ }%
+ }%
+ }%
+ }%
+ \gdef\obeycr{%
+ \catcode`\^^M=13 %
+ \let^^M=\@carriagereturn%
+ \@gobblecr%
+ }%
+ \gdef\restorecr{\catcode`\^^M=5 }%
+}
+\newenvironment{revy at bodycommon}{
+ \let\role = \textbf
+ \def\does##1{\scene \hspace{-1em}\role{##1}}
+ \def\act##1{\textit{(##1)}}
+}{}
+\let\revyinfo=\relax
+\newtoks\@titletoks
+\newtoks\@authortoks
+\newtoks\@melodytoks
+\newtoks\@revyrevynametoks
+\newtoks\@revyrevyyeartoks
+\let\end at document=\enddocument
+\def\enddocument{\label{lastpage}\write\@auxout
+ {\string\@ifundefined{revyinfo}{\string\def\string
+ \revyinfo\string##1\string##2\string##3\string
+ ##4\string##5\string##6\string##7\string##8{}}{}}\@titletoks=
+ \expandafter{\@title}\@titletoks=
+ \expandafter{\@title}\@authortoks=
+ \expandafter{\@author}\@melodytoks=
+ \expandafter{\@melody}\@revyrevynametoks=
+ \expandafter{\@revyname}\@revyrevyyeartoks=
+ \expandafter{\@revyyear}\write\@auxout
+ {\string\revyinfo{\the\@titletoks}{\@version}
+ {\today}%
+ {\the\@authortoks}%
+ {\the\@melodytoks}%
+ {}%
+ {\the\@revyrevynametoks}%
+ {\the\@revyrevyyeartoks}%
+ }%
+ \end at document
+}
+\endinput
+%%
+%% End of file `ucph-revy.cls'.
Property changes on: trunk/Master/texmf-dist/tex/latex/ucph-revy/ucph-revy.cls
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/tlpkg/bin/tlpkg-ctan-check
===================================================================
--- trunk/Master/tlpkg/bin/tlpkg-ctan-check 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/tlpkg/bin/tlpkg-ctan-check 2023-09-09 20:10:33 UTC (rev 68224)
@@ -865,7 +865,8 @@
type1cm typed-checklist typeface typehtml typeoutfileinfo typewriter
typicons typoaid typogrid tzplot
uaclasses uafthesis uantwerpendocs uassign ucalgmthesis
- ucharcat ucharclasses ucbthesis ucdavisthesis ucs ucsmonograph
+ ucharcat ucharclasses ucbthesis ucdavisthesis ucph-revy
+ ucs ucsmonograph
ucthesis udes-genie-these udesoftec uebungsblatt uestcthesis ufrgscca
uhhassignment uhrzeit uiucredborder uiucthesis
ukbill ukrhyph ulem ulqda ulthese
Modified: trunk/Master/tlpkg/tlpsrc/collection-publishers.tlpsrc
===================================================================
--- trunk/Master/tlpkg/tlpsrc/collection-publishers.tlpsrc 2023-09-09 20:09:19 UTC (rev 68223)
+++ trunk/Master/tlpkg/tlpsrc/collection-publishers.tlpsrc 2023-09-09 20:10:33 UTC (rev 68224)
@@ -238,6 +238,7 @@
depend ucalgmthesis
depend ucbthesis
depend ucdavisthesis
+depend ucph-revy
depend ucsmonograph
depend ucthesis
depend udes-genie-these
Added: trunk/Master/tlpkg/tlpsrc/ucph-revy.tlpsrc
===================================================================
More information about the tex-live-commits
mailing list.