[comp.text.tex] latest manpage.sty for C++ library

rchen@m.cs.uiuc.edu (09/16/90)

% MANPAGE DOCUMENT STYLE -- Created 25 May 1990, Updated 15 September 1990
% manpage.sty

% Rong Chen (rchen@cs.uiuc.edu)
% Department of Computer Science
% University of Illinois at Urbana-Champaign
% Urbana, IL 61801

% Copyright (c) 1990 by Rong Chen 
% Permission to copy all or part of this work is granted, provided
% that the copies are not made or distributed for resale, and that
% the copyright notice and this notice are retained.
% 
% THIS WORK IS PROVIDED ON AN "AS IS" BASIS.  THE AUTHOR PROVIDES NO
% WARRANTY WHATSOEVER, EITHER EXPRESS OR IMPLIED, REGARDING THE WORK,
% INCLUDING WARRANTIES WITH RESPECT TO ITS MERCHANTABILITY OR FITNESS
% FOR ANY PARTICULAR PURPOSE.

% This style option is designed to work with the report document style
% of LaTeX version 2.09.  Use \documentstyle[11pt,manpage]{report}
% 
% The commands that are created in the style file are:
%
% \begin{manpage}{Title}{Module}{Version}  % see an example, all will be clear
% \end{manpage}                            % end of manpage environment
% \function{#1}  (e.g., \function{void demo(int dummy)}) % with \medskip added
% \function*{#1} (e.g., \function*{void demo(int dummy)})% no extra spacing
% \subtitle{#1}  (e.g., \subtitle{ANTHOR}) % fit in the same line if possible
% \subtitle*{#1} (e.g., \subtitle*{AUTHOR})% always break a newline
% "#1"           (e.g., "dummy_variable")  % argument is in italic&unbreakable
% \separator		% draw a thin line to seperate suntitle from the text
% \header{#1}{#2}{#3}	% in case you want to have a header and 
% \footer{#1}{#2}{#3}	% a footer outside of the manpage environment
% \dq			% print double quote character (")
%
% In the \function macro, data types and their dummy arguments are separated
% by a space. So if you have a function like "int f(const int n)", you should
% document it as \function{int f(const~int n)}.  The argument n is optional.
% In the \subtitle macro, two lines of text may be devided by "\\".
%
% The following characters (control-sequents) are defined (or redefined) as:
%
% \* --- the same as $\ast$
% \< --- the same as $\langle$
% \> --- the same as $\rangle$
% <  --- the same as $<$
% >  --- the same as $>$
% _  --- the same as \_
% +  --- the same as $+$
% |  --- the same as $\mid$
% ^  --- hat character that is defined as $\wedge$ being raised 0.6ex
% "  --- the same as {\tt "} when outside of the manpage environment,
%        otherwise use \dq instead

% If you make any improvements, I'd like to hear about them.

\headheight 24pt          % See LaTeX book for definitions
\headsep 12pt
\textwidth 6.25in
\textheight 8.0in
\topmargin 0in
\marginparwidth 0pt
\oddsidemargin 0pt
\evensidemargin 0pt
\marginparsep 0pt
\parindent 0pt
\newdimen\argindent \argindent 3em  % indentation for function arguments
\parskip 10pt plus 1pt

\newcommand{\header}[3]{\gdef\@header{{#1}{#2}{#3}}}
\newcommand{\footer}[3]{\gdef\@footer{{#1}{#2}{#3}}}

\catcode`\"=\active
\def\arg@quote#1"{\hbox{\it #1\/}}
\def\tt@quote{\hbox{\tt \char`\" \relax}}
\let"=\tt@quote
\let\dq=\tt@quote

\def\separator{\rule{\linewidth}{0.5pt}}

\def\function{\@ifstar{\@func@star}{\@func@norm}}
\def\@func@star#1{\expandafter\@function#1 \\ }
\def\@func@norm#1{\expandafter\@function#1 \medskip\\ }

\newdimen\arg@dim         % temp variables that you don't want to know
\newdimen\line@siz
\newbox\arg@box

\def\@function#1(#2)#3 {
  \begingroup
  \setbox\arg@box=\hbox{\bf #1 \rm \((\)} \global\arg@dim\wd\arg@box
  \setbox\arg@box=\hbox{\rm \()\);}
  \global\line@siz\linewidth\global\advance\line@siz-\wd\arg@box
  \pagebreak[3]
  \expandafter\print@name#1 \@@{\rm \((\)}\def\@comma{}\ignorespaces
  \@for\@tempa:=#2\do{\ignorespaces
    \setbox\arg@box=\hbox{\@comma} \global\advance\arg@dim\wd\arg@box
    \unskip\@comma\def\@comma{\nobreak,\penalty-\@m\ }\ignorespaces
    \expandafter\print@arg\@tempa\@@\relax\ignorespaces
  }~{\rm \()\)\nobreak#3}
  \endgroup
}

\def\print@name#1#2 #3\@@{
  \unskip\edef\tmp@name{#3}\ignorespaces
  \ifx\tmp@name\@empty{\bf #1#2 }\else{\rm #1#2 \bf #3}\fi
}

\def\print@arg#1\@@{\expandafter\print@type#1 \@@}

\def\print@type#1#2 #3\@@{
  \setbox\arg@box=\hbox{{\rm #1#2}\ifx #3\@nil\else\ignorespaces
    \expandafter\print@dummy#3=\@@\fi\unskip\/}
  \global\advance\arg@dim\wd\arg@box
  \ifdim\arg@dim>\line@siz
    \global\arg@dim\argindent \global\advance\arg@dim\wd\arg@box
    \hfill\penalty-\@m\hbox{}\kern\argindent\fi
  \box\arg@box%
}

\def\print@dummy#1=#2\@@{
  \edef\tmp@name{#1}\def\a@space{ }\ifx\tmp@name\a@space\else
    {\it\ #1\/}\ifx #2\@nil\else{\rm \(=\)}\expandafter\strip@eq#2\fi
  \fi
}

\def\strip@eq#1={{\rm #1}}

\def\subtitle{\@ifstar{\@subtit@star}{\@subtit@norm}}

\def\@subtit@star#1{
  \item[\hbox{\large\bf\begin{tabular}[t]{l}#1\end{tabular}}\hfill]
  \hfil\par
  \expandafter{\let\par=\space\ignorespaces\let\par=\endgraf}
}

\def\@subtit@norm#1{
  \setbox\arg@box=\hbox{\large\bf\begin{tabular}[t]{l}#1\end{tabular}}
  \ifdim \wd\arg@box > \labelwidth \item[\copy\arg@box\hfill]\hfil\par
  \else \dp\arg@box=0pt \item[\copy\arg@box\hfill] \fi
  \expandafter{\let\par=\space\ignorespaces\let\par=\endgraf}
}

\newenvironment{manpage}[3]{\@beginManpage#1\@@#2\@@#3\@@}{\@endManpage}

\def\@beginManpage#1\@@#2\@@#3\@@{
  \pagestyle{headings}
  \addcontentsline{toc}{section}{#2}
  \clearpage
  \gdef\@header{{#2}{#1}{#2}}
  \gdef\@footer{{#3}{\thepage}{\today}}
  \begin{list}{}{
    \setlength\labelwidth{1.2in}
    \setlength\leftmargin{\labelwidth}
    \addtolength\leftmargin{\labelsep}
    \topsep  5pt plus 2pt minus 2pt
    \itemsep 5pt plus 2pt minus 2pt
    \parsep 10pt plus 2pt minus 2pt
  }
  \raggedbottom
  \let"=\arg@quote
}

\def\@endManpage{
  \end{list} \clearpage \flushbottom
  \let"=\tt@quote
}

\def\@first#1#2#3{#1}
\def\@second#1#2#3{#2}
\def\@third#1#2#3{#3}

\def\ps@headings{
  \def\@oddhead{\parbox{\textwidth}{
    {\rm\ \ \expandafter\@first\@header\hfill
      \expandafter\@second\@header\hfill
      \expandafter\@third\@header\ \ } \\[.1cm]
    \hbox{}\rule[12pt]{\textwidth}{1pt}
  }}
  \def\@evenhead{\parbox{\textwidth}{
    {\rm\ \ \expandafter\@third\@header\hfill
      \expandafter\@second\@header\hfill
      \expandafter\@first\@header\ \ } \\[.1cm]
    \hbox{}\rule[12pt]{\textwidth}{1pt}
  }}
  \def\@oddfoot{\parbox{\textwidth}{
    \hbox{}\rule{\textwidth}{1pt} \\[.1cm]
    {\sl\ \ \expandafter\@first\@footer\hfill
      \rm\expandafter\@second\@footer\hfill
      \sl\expandafter\@third\@footer\ }
  }}
  \def\@evenfoot{\parbox{\textwidth}{
    \hbox{}\rule{\textwidth}{1pt} \\[.1cm]
    {\sl\ \ \expandafter\@third\@footer\hfill
      \rm\expandafter\@second\@footer\hfill
      \sl\expandafter\@first\@footer\ }
  }}
}

\gdef\@header{{}{}{}}
\gdef\@footer{{}{}{}}

\def\tableofcontents{\@restonecolfalse
  \newskip\@savskip \@savskip=\parskip
  \parskip 0pt plus 1pt
  \clearpage \thispagestyle{plain} \global\@topnum\z@ \@afterindentfalse
  \@makeschapterhead{{Contents\@mkboth{CONTENTS}{CONTENTS}}}
  \@afterheading \@starttoc{toc}
  \parskip=\@savskip
}

\def\@makechapterhead#1{
  \vspace*{50pt}
  { \raggedleft
    \Large\bf Chapter \thechapter \par \vskip 15pt
    \huge\bf #1\par
    \nobreak \vskip 30pt
  }
}

\def\@makeschapterhead#1{ 
  \vspace*{50pt}
  { \raggedleft 
    \huge\bf #1\par
    \nobreak \vskip 30pt 
  }
}

\def\@schapter#1{
  \addcontentsline{toc}{chapter}{#1}
  \@makeschapterhead{#1} 
  \@afterheading
}

\catcode`\<=\active \def\mit@less{\hbox{\(\char`\<\)}} \let<=\mit@less
\catcode`\>=\active \def\mit@more{\hbox{\(\char`\>\)}} \let>=\mit@more
\def\<{\hbox{\(\langle\)}} \def\>{\hbox{\(\rangle\)}} \def\*{\hbox{\(\ast\)}}
%\catcode`\_=\active \def_={\hbox{\kern.06em \vbox{\hrule width.3em}}}
\catcode`\_=\active \global\let_=\_
\catcode`\^=\active \def\mit@wedge{\hbox{\raise.06ex \hbox{\small \(\wedge\)}}}
\let^=\mit@wedge
\catcode`\+=\active \def\mit@add{\hbox{\(\char43\)}} \let+=\mit@add
\catcode`\|=\active \def\mit@mid{\hbox{\(\mid\)}} \let|=\mit@mid

----------------------------- example.tex ----------------------------------
\documentstyle[11pt,twoside,manpage]{report}
\begin{document}
\pagestyle{headings}

\begin{manpage}{OIM C++ Library}{Choice}{Version 1.0}

\subtitle{Name}
    Choice --- a set of boxes representing the choices available. 

\subtitle{Declaration}
    \#include \<choice.h\>

\function{Choice(Point origin, Point corner,
		int foreground_color, int background_color,
		int frame_style, int space_in_between,
                int number_of_choices,
                const~char\* first_label, $...$)}
    Constructs a choice object.  Each choice object is a set of boxes
    representing the choices available.  "Origin" and "corner" define the
    rectangular area inside which the boxes are displayed. 
    The "space_in_between" (in pixels)
    defines the distance between two adjacent boxes.  Depending on 
    whether there is enough room to put all the choices horizontally
    or vertically in the designated area,
    the choices will be laid out accordingly.  The
    attributes "foreground_color", "background_color" and "frame_style"
    define the colors for each box that represents each choice.
    The number of labels starting with "first_label" must match the
    number given by "number_of_choices".  Each label is displayed within
    its corresponding box.  The choices are displayed 
    as soon as they are created.

\function{Choice(int number_of_choices, Boolean is_horizontal = VIRTICAL)}
    Constructs an array of choices or 
    a choice object with boxes of different sizes.  The attributes
    of the actual choices will be defined later using the
    addItem() operation. Note: It is forbidden to have arguments
    in the constructors of array objects in C++. 

\subtitle{Description}
    A Choice object is a set of related boxes. It is used to display
    multiple choices on the screen. 
    A choice may either be selected by pressing a hot key
    (when mouse is not enabled) or by pressing a mouse button when the mouse
    cursor is within the intended choice box.  
    The first highlighted character in the text label will be the 
    hot key if the mouse is not enabled, otherwise, the highlighted
    character will have no effect. For example, label "@N@ext" designates
    "N" as the hot key for the button if the mouse is not enabled.
    By default, if the mouse driver is loaded before program execution,
    the mouse is enabled.
    When using the mouse to select
    a choice, the selection is immediate; a hot key must be confirmed
    by pressing ENTER (carriage return key).  Arrow keys can also be used
    to move the current selection in the direction indicated by the arrows,
    this also requires an ENTER to confirm.

\subtitle{Public \\ Operations}

\function{void addItem(Point origin, Point corner,
		 int foreground_color, int background_color,
		 int frame_style, const~char\* label,
		 int text_color = WHITE,
		 int text_highlight_color = LIGHT_WHITE)}
    Defines the attributes of a choice box in the array declared by the
    Choice(int "number_of_choices", Boolean "is_horizontal" = VIRTICAL) 
    constructor. 
    It must be called exactly "number_of_choices"
    times.  The first call specifies the first choice, second call specifies
    the second choice, and so on.  The attributes "origin" and "corner"
    define a box area where the choice item is located on the screen.  Other
    attributes are self-explanatory.  This call is particularly useful
    on program setup pages.

\function{void disable(int index)}
    Disables a choice box designated by "index". This means that the choice
    can still be seen on the screen but can not be selected any more.
    The hot key for the choice is rendered as in the normal text color rather
    than in the highlight color.  This call is often useful on a setup page,
    where it is often necessary to have a few choices contingent upon 
    others, i.e., they are disabled first until the choices that they 
    depend upon have been initialized and then they are enabled again.

\function{void enable(int index)}
    Enables a choice box designated by "index".
    All choices are enabled when created.
    
\function{Boolean hasValue()}
    Returns TRUE if the designated choice object has been selected at
    least once.  Graphically,
    it means one of the choices is rendered in reverse colors.  It is
    sometimes necessary to check if all choice objects on a screen have
    been selected, so that a program can go on to the next page of screen.
    If a previous select() call is returned abnormally by pressing an ESC key,
    this function will return FALSE. Should this occur, the previous 
    value, if any, will also be lost.

\function{int selectNext()}
    Steps through each choice of the choice object in sequential order.
    This function is often used in implementing parameter 
    initialization screens in a controlled order. The order that the 
    choices are steped through is the same as the order of the choice
    array.  This is operator is valid only for keyboard mode. If the
    mouse is enabled, it behaves exactly as select().

\function{void setCurrent(int index)}
    Resets the current (default) choice to the choice box indicated by
    "index".  The default choice is
    set to the first choice box ("index" $=$ 0) when a choice object is created,
    or the choice selected last time.  This call can
    change the default choice without having to select anything first.  It will
    affect the behavior of a selectNext() call.

\function{void reset()}
    Erases the default choice and resets the internal pointers as if this
    choice object had never been selected before.

\subtitle{Virtual \\ Operations}

\function{void action(int status)}
    Defines the behaviors of the choice object when a choice handler
    has been bonded to the object.  This function is called by the
    event handler when it detects that the choice object has been
    selected.  The default action is to do nothing if no choice handler
    presents, otherwise, it invokes the choice handler 
    and passes it along with the current status 
    (whatever has been returned from a status() call).  
    Do not modify this function unless it is absolutely necessary because
    it redefines the sematics of all choice objects.

\function{void bind(void \hbox{\rm (\*{\it handler})(int)})}
    Associates a choice handler function with the choice object.  Every
    time this choice object is invoked, the choice handler is called
    immediately.  
    The handler is passed along with the current "status"
    (return value of status() call) as its argument. The default 
    action taken by the event handler can be modified by changing
    the next function action().

\function{Boolean isSelected(Point cursor)}
    Returns TRUE if a legal hot key is pressed for the
    the indicated choice object. It also returns TRUE if 
    a mouse button is pressed within the range of the choice object area.
    This call is used by the event handler to check if this choice object
    has been selected.  It is hardly needed in regular applications.
    The "cursor" is for mouse cursor in mouse mode or faked with the
    current keyboard input as the cursor's x coordinate.

\function{int select()}
    Picks a choice from the choice object.  If the mouse is not enabled,
    the default choice (the one picked last time or the first one if
    this is the first time this function is called) is displayed in
    highlight colors. The arrow key can be used to move the 
    default choice. The ENTER key must be used to confirm the selection.  
    If the mouse is enabled,
    this call checks if a mouse button has been pressed while the mouse
    cursor is inside one of the choice boxes. The return value is the index 
    of the choice box selected. 
    A ESC key may be pressed
    to leave the current select() call without actually selecting anything.
    In this case, $-1$ will be returned.  
    Note: With no mouse enabled,
    select() waits for either an Enter key or ESC key to return,  whereas
    with the mouse enabled, the return is immediate.

\function{int status()}
    Returns the current choice index (the one in reverse color on the screen).
    If there is no current choice (either it has not been selected or has
    been reset) the return value is $-1$.

\subtitle{See Also}
     Event, Button, Box

\subtitle{Author}
    Ron Chen at the Office for Information Management, UIUC. 9-1-89.

\end{manpage}
\newpage
\begin{verbatim}
    /* EXAMPLE 1 */
    #include <stdlib.h>
    #include "choice.h"

    void handler1(int choice) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        box << choice + 1;
    }

    void handler2(int choice) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        box << (choice==0 ? "Ape" : (choice==1 ? "Bob" : "Car"));
    }

    void handler3(int choice) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        switch (choice) {
            case 0: box << "D"; break; case 1: box << "E"; break;
            case 2: box << "F"; break; case 3: box << "G"; break;
            case 4: exit(0);
        }
    }

    main() {
        Point a(100, 100), b(220, 130);
        Choice c1(a,b,BROWN,RED,ON_BORDER,0,4,"@1@","@2@","@3@","@4@");

        a = Point(200, 200); b = Point(400, 230);
        Choice c2(a,b,WHITE,BLUE,IN_BORDER,10,3,"@A@pe","@B@ob","@C@ar");

        a = Point(500, 230); b = Point(550, 330);
        Choice c3(a,b,GREEN,GRAY,NO_BORDER,10,5,"@D@","@E@","@F@","@G@","@H@");

        for (int pick;;) {
            if ((pick = c1.select()) != -1) handler1(pick);
            if ((pick = c2.select()) != -1) handler2(pick);
            if ((pick = c3.select()) != -1) handler3(pick);
        }
    }
\end{verbatim}
\newpage
\begin{verbatim}
    /* EXAMPLE 2 */
    #include <stdlib.h>
    #include "choice.h"

    void handler1(int pick) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        box << pick + 1;
    }

    void handler2(int pick) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        box << (pick==0 ? "Ape" : (pick==1 ? "Bob" : "Car"));
    }

    void handler3(int pick) {
        Box box(500, 30, 600, 60, LIGHT_CYAN, LIGHT_MAGENTA);
        switch (pick) {
            case 0: box << "D"; break; case 1: box << "E"; break;
            case 2: box << "F"; break; case 3: box << "G"; break;
            case 4: exit(0);
        }
    }

    main() {
        Point a(100, 100), b(220, 130);
        Choice c1(a,b,BROWN,RED,ON_BORDER,0,4,"@1@","@2@","@3@","@4@");
        Choice c2(3, HORIZONTAL);
        c2.addItem(Point(200, 200), Point(260,230),
                   WHITE, BLUE, IN_BORDER, "@A@pe");
        c2.addItem(Point(270, 200), Point(330,230),
                   WHITE, BLUE, IN_BORDER, "@B@ob");
        c2.addItem(Point(340, 200), Point(400,230),
                   WHITE, BLUE, IN_BORDER, "@C@ar");
        a = Point(500, 230); b = Point(550, 330);
        Choice c3(a,b,GREEN,GRAY,NO_BORDER,10,5,"@D@","@E@","@F@","@G@","@H@");

        c1.bind(handler1);
        c2.bind(handler2);
        c3.bind(handler3);
        Event::waitForEvents();
    }
\end{verbatim}
\end{document}