Tex2page support:

Macros stolen from Dorai Sitaram
Makefile target "html"
Hyperlinks freebsd.org for POSIX syscalls
This commit is contained in:
nofreude 2001-06-20 14:28:22 +00:00
parent baa65dee1d
commit 7584f719cc
13 changed files with 304 additions and 45 deletions

View File

@ -0,0 +1 @@
html

View File

@ -18,13 +18,16 @@ man.ind: man.idx
makeindex $< makeindex $<
clean: clean:
-rm *.log -rm *.log
rm -r html
INSTALL_DATA= install -c -m 644 INSTALL_DATA= install -c -m 644
tar: tar:
tar cf - *.tex sty | gzip > man.tar.gz tar cf - *.tex sty | gzip > man.tar.gz
html:
tex2page man
install: man.ps install: man.ps
@echo WARNING: @echo WARNING:

105
doc/scsh-manual/css.t2p Normal file
View File

@ -0,0 +1,105 @@
% css.t2p
% Dorai Sitaram
% 19 Jan 2001
% A basic style for HTML documents generated
% with tex2page.
\cssblock
body {
color: black;
background-color: #e5e5e5;
/*background-color: beige;*/
margin-top: 2em;
margin-left: 8%;
margin-right: 8%;
}
h1,h2,h3,h4,h5,h6 {
margin-top: .5em;
}
.partheading {
font-size: 70%;
}
.chapterheading {
font-size: 70%;
}
pre {
margin-left: 2em;
}
ol {
list-style-type: decimal;
}
ol ol {
list-style-type: lower-alpha;
}
ol ol ol {
list-style-type: lower-roman;
}
ol ol ol ol {
list-style-type: upper-alpha;
}
.scheme {
color: brown;
}
.scheme .keyword {
color: #990000;
font-weight: bold;
}
.scheme .builtin {
color: #990000;
}
.scheme .variable {
color: navy;
}
.scheme .global {
color: purple;
}
.scheme .selfeval {
color: green;
}
.scheme .comment {
color: teal;
}
.navigation {
color: red;
text-align: right;
font-style: italic;
}
.disable {
/* color: #e5e5e5; */
color: gray;
}
.smallcaps {
font-size: 75%;
}
.smallprint {
color: gray;
font-size: 75%;
text-align: right;
}
.smallprint hr {
text-align: left;
width: 40%;
}
\endcssblock

View File

@ -7,7 +7,13 @@
\maketitle \maketitle
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Some code-changes for tex2page and latex output. NF
\texonly
\chapter*{Acknowledgements} \chapter*{Acknowledgements}
\endtexonly
\htmlonly
\\ \ex{Acknowledgements} \\ \\
\endhtmlonly
Who should I thank? Who should I thank?
My so-called ``colleagues,'' who laugh at me behind my back, My so-called ``colleagues,'' who laugh at me behind my back,

View File

@ -49,9 +49,9 @@ We place new releases at well-known network sites,
and allow them to propagate from there. and allow them to propagate from there.
We currently release scsh to the following Internet sites: We currently release scsh to the following Internet sites:
\begin{inset}\begin{flushleft} \begin{inset}\begin{flushleft}
\ex{ftp://ftp-swiss.ai.mit.edu/pub/su/} \\ \ex{\urlh{ftp://ftp-swiss.ai.mit.edu/pub/su/}{ftp://ftp-swiss.ai.mit.edu/pub/su/}} \\
\ex{http://www-swiss.ai.mit.edu/scsh/scsh.html} \ex{\urlh{http://www-swiss.ai.mit.edu/scsh/scsh.html}{http://www-swiss.ai.mit.edu/scsh/scsh.html}} \\
\ex{http://www.cs.indiana.edu/scheme-repository/} \\ \ex{\urlh{http://www.cs.indiana.edu/scheme-repository/}{http://www.cs.indiana.edu/scheme-repository/}} \\
\end{flushleft} \end{flushleft}
\end{inset} \end{inset}
These sites are These sites are

126
doc/scsh-manual/man.t2p Normal file
View File

@ -0,0 +1,126 @@
% man.t2p
% Dorai Sitaram
% Feb 6, 2000
% This file contains the tex2page macros needed to process
% the scsh LaTeX document scsh-n.n.n/doc/scsh-manual/man.tex.
% Copy (or link) this file alongside man.tex and run
%
% tex2page man
\input css.t2p
\dontuseimgforhtmlmath
\let\pagebreak\relax
\let\small\relax
%\let\PRIMtableofcontents\tableofcontents
%\def\tableofcontents{\chapter*{Contents}\PRIMtableofcontents}
\def\subtitle#1{\def\savesubtitle{#1}}
\def\maketitle{
\subject{\TIIPtitle}
{\bf \hr}
\rightline{\savesubtitle}
\bigskip\bigskip
\bigskip\bigskip
{\bf\TIIPauthor}
{\bf\hr}
}
\let\PRIMdocument\document
\def\document{\PRIMdocument
\let\ttchars\relax
\let\ttt\tt
%\def\~{\rawhtml~\endrawhtml}
\def\~{\char`\~}
\def\cd#1{{\tt\def\\{\char`\\}\defcsactive\${\char`\$}\defcsactive\&{\char`\&}#1}}
\def\cddollar{\undefcsactive\$}
\def\cdmath{\undefcsactive\$}
\def\codeallowbreaks{\relax}
\def\defvarx#1#2{\index{#1}\leftline{{\tt #1} \qquad #2}}
\let\PRIMflushright\flushright
\def\flushright{\PRIMflushright\TIIPtabularborder=0 }
\let\PRIMfigure\figure
\let\PRIMendfigure\endfigure
\def\figure{\par\hrule\PRIMfigure}
\def\endfigure{\PRIMendfigure\hrule\par}
\let\PRIMtable\table
\let\PRIMendtable\endtable
\def\table{\par\hrule\PRIMtable}
\def\endtable{\PRIMendtable\hrule\par}
\imgdef\vdots{\bf.\par.\par.}
\evalh{
(define all-blanks?
(lambda (s)
(andmap
char-whitespace?
(string->list s))))
}
\def\spaceifnotempty{\evalh{
(let ((x (ungroup (get-token))))
(unless (all-blanks? x)
(emit #\space)))
}}
\def\dfnix#1#2#3#4{\leftline{{\tt(#1\spaceifnotempty{#2}{\it#2})} \quad $\longrightarrow$ \quad {\it #3} \qquad (#4)} \index}
\def\ex#1{{\tt #1}}
\def\l#1{lambda (#1)}
\def\lx#1{lambda {#1}}
%\def\notenum#1{}
%\def\project#1{}
\def\var#1{{\it #1\/}}
\def\vari#1#2{\mbox{{\it #1\/}\undefcsactive\$$_{#2}$}}
\renewenvironment{boxedfigure}{\def\srecomment#1{\\#1\\}%
\begin{figure}\pagestyle}{\end{figure}}
\newenvironment{centercode}{\begin{code}}{\end{code}}
\def\setupcode{\tt%
\def\\{\char`\\}%
\defcsactive\${\$}%
\def\evalto{==> }%
\defcsactive\%{\%}\obeywhitespace}
\newenvironment{code}{\begin{quote}\bgroup\setupcode\GOBBLEOPTARG}
{\egroup\end{quote}}
\newenvironment{codebox}{\begin{tableplain}\bgroup\setupcode\GOBBLEOPTARG}
{\egroup\end{tableplain}}
\renewenvironment{desc}{\begin{quote}}{\end{quote}}
\renewenvironment{exampletable}{%
\def\header#1{\\\leftline{#1}\\}%
\def\splitline#1#2{\\\leftline{#1}\\\leftline{#2}}%
\begin{tabular}{}}{\end{tabular}}
\newenvironment{tightcode}{\begin{code}}{\end{code}}
\renewenvironment{widecode}{\begin{code}}{\end{code}}
\renewenvironment{inset}{\begin{quote}}{\end{quote}}
\renewenvironment{leftinset}{\begin{quote}}{\end{quote}}
\renewenvironment{tightinset}{\begin{quote}}{\end{quote}}
\renewenvironment{tightleftinset}{\begin{quote}}{\end{quote}}
}

View File

@ -4,13 +4,15 @@
\documentclass[twoside]{report} \documentclass[twoside]{report}
\usepackage{code,boxedminipage,makeidx,palatino,ct, \usepackage{code,boxedminipage,makeidx,palatino,ct,
headings,mantitle,array,matter,mysize10} headings,mantitle,array,matter,mysize10,tex2page}
\texonly
\usepackage[dvipdfm,hyperindex,hypertex, \usepackage[dvipdfm,hyperindex,hypertex,
pdftitle={scsh manual, release 0.5.3}, pdftitle={scsh manual, release 0.5.3},
pdfauthor={Olin Shivers and Brian D.~Carlstrom} pdfauthor={Olin Shivers and Brian D.~Carlstrom}
colorlinks=true,linkcolor=blue,pagecolor=blue,urlcolor=blue, colorlinks=true,linkcolor=blue,pagecolor=blue,urlcolor=blue,
pdfstartview=FitH,pdfview=FitH]{hyperref} pdfstartview=FitH,pdfview=FitH]{hyperref}
\endtexonly
% These fonts are good choices for screen-readable pdf, but the man needs % These fonts are good choices for screen-readable pdf, but the man needs
% a pass over the layout, since the this tt font will blow out the width % a pass over the layout, since the this tt font will blow out the width
@ -22,19 +24,19 @@
%\renewcommand{\ttdefault}{pcr} %\renewcommand{\ttdefault}{pcr}
% Style issues % Style issues
\parskip = 3pt plus 3pt \parskip = 3pt plus 3pt
\sloppy \sloppy
%\includeonly{syscalls} %\includeonly{syscalls}
\input{decls} \input{decls}
\makeindex \makeindex
%%% End preamble %%% End preamble
\begin{document} \begin{document}
\frontmatter \frontmatter
\include{front} \include{front}
\mainmatter \mainmatter
\include{intro} \include{intro}

View File

@ -11,7 +11,7 @@ The basic elements of this notation are \emph{process forms},
\section{Extended process forms and i/o redirections} \section{Extended process forms and i/o redirections}
An \emph{extended process form} is a specification of a {\Unix} process to An \emph{extended process form} is a specification of a {\Unix} process to
run, in a particular I/O environment: run, in a particular I/O environment:
\codex{\var{epf} {\synteq} (\var{pf} $\var{redir}_1$ {\ldots} $\var{redir}_n$)} \codex{\var{epf} {\synteq} (\var{pf} $ \var{redir}_1$ {\ldots} $ \var{redir}_n $)}
where \var{pf} is a process form and the $\var{redir}_i$ are redirection specs. where \var{pf} is a process form and the $\var{redir}_i$ are redirection specs.
A \emph{redirection spec} is one of: A \emph{redirection spec} is one of:
\begin{inset} \begin{inset}
@ -140,7 +140,7 @@ That is, it is equivalent to:
% %
\codex{(begin (apply exec-path `(\var{prog} \vari{arg}1 {\ldots} \vari{arg}n)))} \codex{(begin (apply exec-path `(\var{prog} \vari{arg}1 {\ldots} \vari{arg}n)))}
% %
\ex{Exec-path} is the version of the \ex{exec()} system call that \ex{Exec-path} is the version of the \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec()}} system call that
uses scsh's path list to search for an executable. uses scsh's path list to search for an executable.
The program and the arguments must be either strings, symbols, or integers. The program and the arguments must be either strings, symbols, or integers.
Symbols and integers are coerced to strings. Symbols and integers are coerced to strings.
@ -438,7 +438,7 @@ Our scsh programmer decides to run \ex{myprog} with stdout and stderr redirected
\emph{via {\Unix} pipes} to the ports \ex{port1} and \ex{port2}, respectively. \emph{via {\Unix} pipes} to the ports \ex{port1} and \ex{port2}, respectively.
He gets into trouble when he subsequently says \ex{(read port2)}. He gets into trouble when he subsequently says \ex{(read port2)}.
The {\Scheme} \ex{read} routine reads the open paren, and then hangs in a The {\Scheme} \ex{read} routine reads the open paren, and then hangs in a
\ex{read()} system call trying to read a matching close paren. \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=read&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{read()}} system call trying to read a matching close paren.
But before \ex{myprog} sends the close paren down the stderr But before \ex{myprog} sends the close paren down the stderr
pipe, it first tries to write a megabyte of data to the stdout pipe. pipe, it first tries to write a megabyte of data to the stdout pipe.
However, {\Scheme} is not reading that pipe---it's stuck waiting for input on However, {\Scheme} is not reading that pipe---it's stuck waiting for input on

View File

@ -398,7 +398,7 @@ would implement a simple-minded version of the Unix \ex{echo} program:
% %
The idea would be that the command The idea would be that the command
\codex{ekko Hi there.} \codex{ekko Hi there.}
would by expanded by the \ex{exec(2)} kernel call into would by expanded by the \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec(2)}} kernel call into
% %
\begin{code} \begin{code}
/usr/local/bin/scsh -e main -s ekko Hi there.\end{code} /usr/local/bin/scsh -e main -s ekko Hi there.\end{code}
@ -408,7 +408,7 @@ call the entry point on the command-line list
\codex{(main '("ekko" "Hi" "there."))} \codex{(main '("ekko" "Hi" "there."))}
and exit. and exit.
Unfortunately, the {\Unix} \ex{exec(2)} syscall's support for scripts is Unfortunately, the {\Unix} \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec(2)}} syscall's support for scripts is
not very general or well-designed. not very general or well-designed.
It will not handle multiple arguments; It will not handle multiple arguments;
the \ex{\#!} line is usually required to contain no more than 32 characters; the \ex{\#!} line is usually required to contain no more than 32 characters;
@ -555,7 +555,7 @@ Writing it this way makes it possible to compile the program
(for-each (\l{arg} (display arg) (display " ")) (for-each (\l{arg} (display arg) (display " "))
(cdr args)))\end{code} (cdr args)))\end{code}
% %
The \ex{exec(2)} expansion of the \ex{\#!} line together with The \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec(2)}} expansion of the \ex{\#!} line together with
the scsh expansion of the ``\verb|\ ekko|'' meta-argument the scsh expansion of the ``\verb|\ ekko|'' meta-argument
(see section~\ref{sec:meta-arg}) gives the following command-line expansion: (see section~\ref{sec:meta-arg}) gives the following command-line expansion:
\begin{code} \begin{code}

View File

@ -31,8 +31,15 @@ Besides the the facilities described in this chapter, scsh also provides
More documentation on these procedures can be found at URLs More documentation on these procedures can be found at URLs
\begin{tightinset} \begin{tightinset}
% The gratuitous mbox makes xdvi render the hyperlinks better. % The gratuitous mbox makes xdvi render the hyperlinks better.
\texonly
\mbox{\url{http://srfi.schemers.org/srfi-13/srfi-13.html}}\\ \mbox{\url{http://srfi.schemers.org/srfi-13/srfi-13.html}}\\
\url{http://srfi.schemers.org/srfi-13/srfi-13.txt} \url{http://srfi.schemers.org/srfi-13/srfi-13.txt}
\endtexonly
% Changed the \mbox into \urlh for tex2page to avoid problems runing tex2page
\htmlonly
\urlh{http://srfi.schemers.org/srfi-13/srfi-13.html}{http://srfi.schemers.org/srfi-13/srfi-13.html}\\
\urlh{http://srfi.schemers.org/srfi-13/srfi-13.txt}{http://srfi.schemers.org/srfi-13/srfi-13.txt}
\endhtmlonly
\end{tightinset} \end{tightinset}
\itum{The SRFI-14 character-set library} \itum{The SRFI-14 character-set library}
@ -44,8 +51,15 @@ Besides the the facilities described in this chapter, scsh also provides
More documentation on this library can be found at URLs More documentation on this library can be found at URLs
\begin{tightinset} \begin{tightinset}
% The gratuitous mbox makes xdvi render the hyperlinks better. % The gratuitous mbox makes xdvi render the hyperlinks better.
\texonly
\mbox{\url{http://srfi.schemers.org/srfi-14/srfi-14.html}}\\ \mbox{\url{http://srfi.schemers.org/srfi-14/srfi-14.html}}\\
\url{http://srfi.schemers.org/srfi-14/srfi-14.txt} \url{http://srfi.schemers.org/srfi-14/srfi-14.txt}
\endtexonly
% Changed the \mbox into \urlh for tex2page to avoid problems runing tex2page
\htmlonly
\urlh{http://srfi.schemers.org/srfi-14/srfi-14.html}{http://srfi.schemers.org/srfi-14/srfi-14.html}\\
\urlh{http://srfi.schemers.org/srfi-14/srfi-14.txt}{http://srfi.schemers.org/srfi-14/srfi-14.txt}
\endhtmlonly
\end{tightinset} \end{tightinset}
\end{itemize} \end{itemize}

View File

@ -375,7 +375,7 @@ descriptor to a port with \ex{fdes->outport} or \ex{fdes->inport}, the port
has its revealed field incremented. has its revealed field incremented.
Not all file descriptors are created by requests to make ports. Some are Not all file descriptors are created by requests to make ports. Some are
inherited on process invocation via \ex{exec(2)}, and are simply part of the inherited on process invocation via \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec(2)}}, and are simply part of the
global environment. Subprocesses may depend upon them, so if a port is later global environment. Subprocesses may depend upon them, so if a port is later
allocated for these file descriptors, is should be considered as a revealed allocated for these file descriptors, is should be considered as a revealed
port. For example, when the {\Scheme} shell's process starts up, it opens ports port. For example, when the {\Scheme} shell's process starts up, it opens ports
@ -388,7 +388,7 @@ port.
Unrevealed file ports have the nice property that they can be closed when all Unrevealed file ports have the nice property that they can be closed when all
pointers to the port are dropped. This can happen during gc, or at an pointers to the port are dropped. This can happen during gc, or at an
\ex{exec()}---since all memory is dropped at an \ex{exec()}. No one knows the \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec()}}---since all memory is dropped at an \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec()}}. No one knows the
file descriptor associated with the port, so the exec'd process certainly file descriptor associated with the port, so the exec'd process certainly
can't refer to it. can't refer to it.
@ -399,11 +399,11 @@ the garbage collector. This is critical, since shell programming
absolutely requires access to the {\Unix} file descriptors, as their absolutely requires access to the {\Unix} file descriptors, as their
numerical values are a critical part of the process interface. numerical values are a critical part of the process interface.
A port's underlying file descriptor can be shifted around with \ex{dup(2)} A port's underlying file descriptor can be shifted around with \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup(2)}}
when convenient. That is, the actual file descriptor on top of which a port is when convenient. That is, the actual file descriptor on top of which a port is
constructed can be shifted around underneath the port by the scsh kernel when constructed can be shifted around underneath the port by the scsh kernel when
necessary. This is important, because when the user is setting up file necessary. This is important, because when the user is setting up file
descriptors prior to a \ex{exec(2)}, he may explicitly use a file descriptor descriptors prior to a \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec(2)}}, he may explicitly use a file descriptor
that has already been allocated to some port. In this case, the scsh kernel that has already been allocated to some port. In this case, the scsh kernel
just shifts the port's file descriptor to some new location with \ex{dup}, just shifts the port's file descriptor to some new location with \ex{dup},
freeing up its old descriptor. This prevents errors from happening in the freeing up its old descriptor. This prevents errors from happening in the
@ -431,8 +431,8 @@ alive and well so that it can subsequently be dup'd into descriptor 0 for
\ex{prog}'s stdin. \ex{prog}'s stdin.
The port-shifting machinery makes the following guarantee: a port is only The port-shifting machinery makes the following guarantee: a port is only
moved when the underlying file descriptor is closed, either by a \ex{close()} moved when the underlying file descriptor is closed, either by a \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=close&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{close()}}
or a \ex{dup2()} operation. Otherwise a port/file-descriptor association is or a \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup2&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup2()}} operation. Otherwise a port/file-descriptor association is
stable. stable.
Under normal circumstances, all this machinery just works behind the scenes to Under normal circumstances, all this machinery just works behind the scenes to
@ -524,17 +524,17 @@ Decrement the port's revealed count.
\defunx{dup->outport} {fd/port [newfd]} {port} \defunx{dup->outport} {fd/port [newfd]} {port}
\defunx{dup->fdes} {fd/port [newfd]} {fd} \defunx{dup->fdes} {fd/port [newfd]} {fd}
\begin{desc} \begin{desc}
These procedures provide the functionality of C's \ex{dup()} and \ex{dup2()}. These procedures provide the functionality of C's \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup()}} and \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup2&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup2()}}.
The different routines return different types of values: The different routines return different types of values:
\ex{dup->inport}, \ex{dup->outport}, and \ex{dup->fdes} return \ex{dup->inport}, \ex{dup->outport}, and \ex{dup->fdes} return
input ports, output ports, and integer file descriptors, respectively. input ports, output ports, and integer file descriptors, respectively.
\ex{dup}'s return value depends on on the type of \ex{dup}'s return value depends on on the type of
\var{fd/port}---it maps fd$\rightarrow$fd and port$\rightarrow$port. \var{fd/port}---it maps fd$\rightarrow$fd and port$\rightarrow$port.
These procedures use the {\Unix} \ex{dup()} syscall to replicate These procedures use the {\Unix} \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup()}} syscall to replicate
the file descriptor or file port \var{fd/port}. the file descriptor or file port \var{fd/port}.
If a \var{newfd} file descriptor is given, it is used as the target of If a \var{newfd} file descriptor is given, it is used as the target of
the dup operation, \ie, the operation is a \ex{dup2()}. the dup operation, \ie, the operation is a \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup2&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup2()}}.
In this case, procedures that return a port (such as \ex{dup->inport}) In this case, procedures that return a port (such as \ex{dup->inport})
will return one with the revealed count set to one. will return one with the revealed count set to one.
For example, \ex{(dup (current-input-port) 5)} produces For example, \ex{(dup (current-input-port) 5)} produces
@ -953,14 +953,14 @@ It is not without reason that the FreeBSD man pages refer to {\Posix}
file locking as ``completely stupid.'' file locking as ``completely stupid.''
Scsh moves Scheme ports from file descriptor to file descriptor with Scsh moves Scheme ports from file descriptor to file descriptor with
\ex{dup()} and \ex{close()} as required by the runtime, \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup()}} and \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=close&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{close()}} as required by the runtime,
so it is impossible to keep file locks open across one of these shifts. so it is impossible to keep file locks open across one of these shifts.
Hence we can only offer {\Posix} advisory file locking directly on raw Hence we can only offer {\Posix} advisory file locking directly on raw
integer file descriptors; integer file descriptors;
regrettably, there are no facilities for locking Scheme ports. regrettably, there are no facilities for locking Scheme ports.
Note that once a Scheme port is revealed in scsh, the runtime will not Note that once a Scheme port is revealed in scsh, the runtime will not
shift the port around with \ex{dup()} and \ex{close()}. shift the port around with \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=dup&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{dup()}} and \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=close&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{close()}}.
This means the file-locking procedures can then be applied to the port's This means the file-locking procedures can then be applied to the port's
associated file descriptor. associated file descriptor.
} }
@ -1117,7 +1117,7 @@ while \ex{delete-filesys-object} simply returns.
If you override an existing object, then \var{old-fname} If you override an existing object, then \var{old-fname}
and \var{new-fname} must type-match---either both directories, and \var{new-fname} must type-match---either both directories,
or both non-directories. or both non-directories.
This is required by the semantics of {\Unix} \ex{rename()}. This is required by the semantics of {\Unix} \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=rename&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{rename()}}.
\remark{ \remark{
There is an unfortunate atomicity problem with the \ex{rename-file} There is an unfortunate atomicity problem with the \ex{rename-file}
@ -1125,7 +1125,7 @@ while \ex{delete-filesys-object} simply returns.
specify no-override, but create file \ex{new-fname} sometime between specify no-override, but create file \ex{new-fname} sometime between
\ex{rename-file}'s existence check and the actual rename operation, \ex{rename-file}'s existence check and the actual rename operation,
your file will be clobbered with \ex{old-fname}. There is no way to fix your file will be clobbered with \ex{old-fname}. There is no way to fix
this problem, given the semantics of {\Unix} \ex{rename()}; this problem, given the semantics of {\Unix} \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=rename&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{rename()}};
at least it is highly unlikely to occur in practice. at least it is highly unlikely to occur in practice.
} }
\end{defundescx} \end{defundescx}
@ -1165,7 +1165,7 @@ while \ex{delete-filesys-object} simply returns.
These procedures are not {\Posix}. These procedures are not {\Posix}.
Interestingly enough, \ex{sync\=file\=system} doesn't actually Interestingly enough, \ex{sync\=file\=system} doesn't actually
do what it is claimed to do. We just threw it in for humor value. do what it is claimed to do. We just threw it in for humor value.
See the \ex{sync(2)} man page for {\Unix} enlightenment. See the \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=sync&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{sync(2)}} man page for {\Unix} enlightenment.
\end{desc} \end{desc}
\begin{defundesc} {truncate-file} {fname/fd/port len} \undefined \begin{defundesc} {truncate-file} {fname/fd/port len} \undefined
@ -1290,7 +1290,7 @@ For example,
calls do not take a \var{chase?} flag. calls do not take a \var{chase?} flag.
Note that these procedures use the process' \emph{effective} user Note that these procedures use the process' \emph{effective} user
and group ids for permission checking. {\Posix} defines an \ex{access()} and group ids for permission checking. {\Posix} defines an \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=access&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{access()}}
function that uses the process' real uid and gids. This is handy function that uses the process' real uid and gids. This is handy
for setuid programs that would like to find out if the actual user for setuid programs that would like to find out if the actual user
has specific rights; scsh ought to provide this functionality (but doesn't has specific rights; scsh ought to provide this functionality (but doesn't
@ -1310,7 +1310,7 @@ For example,
These should be disentangled. These should be disentangled.
Some of these problems could be avoided if {\Posix} had a real-uid Some of these problems could be avoided if {\Posix} had a real-uid
variant of the \ex{access()} call we could use, but the atomicity variant of the \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=access&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{access()}} call we could use, but the atomicity
issue is still a problem. In the final analysis, the only way to issue is still a problem. In the final analysis, the only way to
find out if you have the right to perform an operation on a file find out if you have the right to perform an operation on a file
is to try and open it for the desired operation. These permission-checking is to try and open it for the desired operation. These permission-checking
@ -1467,7 +1467,7 @@ All wild-card characters in \var{str} are quoted with a backslash.
\ex{file-match} provides a more powerful file-matching service, at the \ex{file-match} provides a more powerful file-matching service, at the
expense of a less convenient notation. It is intermediate in expense of a less convenient notation. It is intermediate in
power between most shell matching machinery and recursive \ex{find(1)}. power between most shell matching machinery and recursive \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=find&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{find(1)}}.
Each pattern is a regexp. The procedure searches from \var{root}, Each pattern is a regexp. The procedure searches from \var{root},
matching the first-level files against pattern \vari{pat}1, the matching the first-level files against pattern \vari{pat}1, the
@ -1716,7 +1716,7 @@ a slash character---it is used directly. So a program with a name like
\ex{"bin/prog"} always executes the program \ex{bin/prog} in the current working \ex{"bin/prog"} always executes the program \ex{bin/prog} in the current working
directory. See \verb|$path| and \verb|exec-path-list|, below. directory. See \verb|$path| and \verb|exec-path-list|, below.
Note that there is no analog to the C function \ex{execv()}. Note that there is no analog to the C function \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=execv&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{execv()}}.
To get the effect just do To get the effect just do
\codex{(apply exec prog arglist)} \codex{(apply exec prog arglist)}
@ -1724,7 +1724,7 @@ All of these procedures flush buffered output and close unrevealed ports
before executing the new binary. before executing the new binary.
To avoid flushing buffered output, see \verb|%exec| below. To avoid flushing buffered output, see \verb|%exec| below.
Note that the C \ex{exec()} procedure allows the zeroth element of the Note that the C \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=exec&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{exec()}} procedure allows the zeroth element of the
argument vector to be different from the file being executed, \eg argument vector to be different from the file being executed, \eg
% %
\begin{inset} \begin{inset}
@ -1802,7 +1802,7 @@ Suspend the current process with a SIGSTOP signal.
\defun {fork} {[thunk]} {proc or \sharpf} \defun {fork} {[thunk]} {proc or \sharpf}
\defunx {\%fork} {[thunk]} {proc or \sharpf} \defunx {\%fork} {[thunk]} {proc or \sharpf}
\begin{desc} \begin{desc}
\ex{fork} with no arguments is like C \ex{fork()}. \ex{fork} with no arguments is like C \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=fork&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{fork()}}.
In the parent process, it returns the child's \emph{process object} In the parent process, it returns the child's \emph{process object}
(see below for more information on process objects). (see below for more information on process objects).
In the child process, it returns {\sharpf}. In the child process, it returns {\sharpf}.
@ -2242,7 +2242,7 @@ I can't remember how \ex{set-priority} and \ex{priority} work, so no
\begin{desc} \begin{desc}
These routines get and set the effective and real user and group ids. These routines get and set the effective and real user and group ids.
The \ex{set-uid} and \ex{set-gid} routines correspond to the {\Posix} The \ex{set-uid} and \ex{set-gid} routines correspond to the {\Posix}
\ex{setuid()} and \ex{setgid()} procedures. \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=setuid&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{setuid()}} and \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=setgid&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{setgid()}} procedures.
\end{desc} \end{desc}
@ -2787,7 +2787,7 @@ String & A {\Posix} time zone string understood by the OS
``\ex{UTC+\emph{hh}:\emph{mm}:\emph{ss}}''; ``\ex{UTC+\emph{hh}:\emph{mm}:\emph{ss}}'';
the trailing \ex{:\emph{mm}:\emph{ss}} portion is deleted if it is zeroes. the trailing \ex{:\emph{mm}:\emph{ss}} portion is deleted if it is zeroes.
\oops{The Posix facility for converting dates to times, \ex{mktime()}, \oops{The Posix facility for converting dates to times, \ex{\urlh{http://www.FreeBSD.org/cgi/man.cgi?query=mktime&apropos=0&sektion=0&manpath=FreeBSD+4.3-RELEASE&format=html}{mktime()}},
has a broken design: it indicates an error by returning -1, which has a broken design: it indicates an error by returning -1, which
is also a legal return value (for date 23:59:59 UCT, 12/31/1969). is also a legal return value (for date 23:59:59 UCT, 12/31/1969).
Scsh resolves the ambiguity in a paranoid fashion: it always Scsh resolves the ambiguity in a paranoid fashion: it always

View File

@ -7,8 +7,10 @@ made to scsh.
We invite interested hackers to do any of them, and send us the code; We invite interested hackers to do any of them, and send us the code;
we'll put you on the team. we'll put you on the team.
Visit the Scheme Underground Web page for more information on good hacks at Visit the Scheme Underground Web page for more information on good hacks at
\begin{tightinset}\verb|http://www.ai.mit.edu/projects/su/| \begin{inset} \begin{flushleft}
\end{tightinset} \ex{\urlh{http://www.ai.mit.edu/projects/su/}{http://www.ai.mit.edu/projects/su/}}
\end{flushleft}
\end{inset}
Scsh is a tool that lets you write fun programs that do real things in Scsh is a tool that lets you write fun programs that do real things in
an elegant language; go wild. an elegant language; go wild.

View File

@ -4,7 +4,7 @@
\documentclass[twoside]{report} \documentclass[twoside]{report}
\usepackage{code,boxedminipage,draftfooters,makeidx,palatino,ct, \usepackage{code,boxedminipage,draftfooters,makeidx,palatino,ct,
headings,mantitle,array,matter,a4} headings,mantitle,array,matter,a4,tex2page}
% Style issues % Style issues
\parskip = 3pt plus 3pt \parskip = 3pt plus 3pt