Implementing the "lp" command.

This command is required to exist in terms of compatibility with the
Posix 1003.2 specification.  It actually invokes the lpr service with
the proper options.
This commit is contained in:
Joerg Wunsch 1995-01-23 19:22:43 +00:00
parent fb1322e408
commit e3fa32b485
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=5810
3 changed files with 215 additions and 0 deletions

10
usr.sbin/lpr/lp/Makefile Normal file
View File

@ -0,0 +1,10 @@
# @(#)Makefile 5.6 (Berkeley) 6/23/90
BINDIR = /usr/bin
MAN1 = lp.1
beforeinstall:
install -c -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
lp.sh ${DESTDIR}${BINDIR}/lp
.include <bsd.prog.mk>

122
usr.sbin/lpr/lp/lp.1 Normal file
View File

@ -0,0 +1,122 @@
.\"
.\" Copyright (c) 1995 Joerg Wunsch
.\"
.\" All rights reserved.
.\"
.\" This program is free software.
.\"
.\" Redistribution and use in source and binary forms, with or without
.\" modification, are permitted provided that the following conditions
.\" are met:
.\" 1. Redistributions of source code must retain the above copyright
.\" notice, this list of conditions and the following disclaimer.
.\" 2. Redistributions in binary form must reproduce the above copyright
.\" notice, this list of conditions and the following disclaimer in the
.\" documentation and/or other materials provided with the distribution.
.\" 3. All advertising materials mentioning features or use of this software
.\" must display the following acknowledgement:
.\" This product includes software developed by Joerg Wunsch
.\" 4. The name of the developer may not be used to endorse or promote
.\" products derived from this software without specific prior written
.\" permission.
.\"
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
.\"
.\" $Id: lp.1,v 1.1 1995/01/22 17:47:24 j Exp $
.\"
.Dd January 22, 1995
.Dt LP 1
.Os
.Sh NAME
.Nm lp
.Nd front-end to the print spooler
.Sh SYNOPSIS
.Nm lp
.Op Fl c
.Op Fl d printer
.Op Fl n Ar num
.Op Ar name ...
.Sh DESCRIPTION
.Nm Lp
is a front-end to the print spooler as required by the
.St -p1003.2
specification. It effectively invokes
.Xr lpr 1
with the proper set of arguments.
It generally prints the named files on the destination printer.
.Pp
Option
.Fl c
makes the
.Nm
command exit only after further access to any of the input files is no
longer required. The application can then safely delete or modify the
files without affecting the output operation.
To specify a particular printer, option
.Fl d Ar dest
can be used. If no
.Fl d
is provided on the command line, the contents of the environmental
variables
.Ev LPDEST
or
.Ev PRINTER
.Pq with this precedence
are taken as the destination printer.
Option
.Fl n Ar num
can be used to specify that
.Ar num
copies of each of the named files shall be printed.
.Sh ENVIRONMENT
As described above, the variables
.Ev LPDEST
and
.Ev PRINTER
are examined to select the destination printer.
.Sh SEE ALSO
.Xr lpr 1
.Sh STANDARDS
The
.Nm lp
command is expected to comply with the
.St -p1003.2
specification.
.Sh AUTHOR
This implementation of the
.Nm
command has been written by
.if t J\(:org Wunsch.
.if n Joerg Wunsch.
.Sh BUGS
The
.Nm
command inherits several bugs from the utilities invoked, namely it
requires any option separated from its argument by a whitespace
since the getopts implementation of
.Xr sh 1
is broken, and it does not honour dashes as input file names
.Pq meant to use standard input
since
.Xr lpr 1
ignores them.
The
.St -p1003.2
specification does not provide any means to print non-text files. It
rather requires the files to be printed to be text files limited to
reasonable line lengths and printable characters.

83
usr.sbin/lpr/lp/lp.sh Normal file
View File

@ -0,0 +1,83 @@
#!/bin/sh
#
#
# Copyright (c) 1995 Joerg Wunsch
#
# All rights reserved.
#
# This program is free software.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# 3. All advertising materials mentioning features or use of this software
# must display the following acknowledgement:
# This product includes software developed by Joerg Wunsch
# 4. The name of the developer may not be used to endorse or promote
# products derived from this software without specific prior written
# permission.
#
# THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
# IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
#
# Posix 1003.2 compliant print spooler interface.
#
# $Id: lp.sh,v 1.1 1995/01/22 17:47:33 j Exp $
#
#
# XXX Bugs:
# . Our lpr command is not smart enough about dashes as input file names,
# they should indicate the use of standard input.
# . Our /bin/sh is not Posix-1003.2 compliant in its getopts command;
# if the user specifies an option argument immediately after the
# option, the variable OPTIND will be set wrong. (This way of
# specifying option arguments is deprecated by Posix, but explicitly
# allowed.)
# . Our lpr command should allow the Posix-compliant way of specifying
# options that take an argument; it currently requires the argument
# to follow the option immediately.
ncopies=""
symlink="-s"
# Posix says LPDEST gets precedence over PRINTER
dest=${LPDEST:-${PRINTER:-lp}}
#
# XXX We include the -o flag as a dummy. Posix 1003.2 does not require
# it, but the rationale mentions it as a possible future extension.
#
while getopts "cd:n:o:" option
do
case $option in
c) # copy files before printing
symlink="";;
d) # destination
dest="${OPTARG}";;
n) # number of copies
ncopies="-#${OPTARG}";;
o) # (printer option)
: ;;
*) # (error msg printed by getopts)
exit 2;;
esac
done
shift $(($OPTIND - 1))
exec /usr/bin/lpr "-P${dest}" ${symlink} ${ncopies} "$@"