NetBSD/usr.bin/xinstall/install.1

377 lines
7.8 KiB
Groff
Raw Normal View History

.\" $NetBSD: install.1,v 1.38 2003/08/07 11:17:50 agc Exp $
.\"
.\" Copyright (c) 1987, 1990, 1993
.\" The Regents of the University of California. All rights reserved.
1993-03-21 12:45:37 +03:00
.\"
.\" 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. Neither the name of the University nor the names of its contributors
1993-03-21 12:45:37 +03:00
.\" may be used to endorse or promote products derived from this software
.\" without specific prior written permission.
.\"
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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.
.\"
.\" @(#)install.1 8.1 (Berkeley) 6/6/93
1993-03-21 12:45:37 +03:00
.\"
.Dd December 21, 2002
1993-03-21 12:45:37 +03:00
.Dt INSTALL 1
.Os
1993-03-21 12:45:37 +03:00
.Sh NAME
.Nm install
.Nd install binaries
.Sh SYNOPSIS
.Nm
.Op Fl Ubcprs
1999-03-07 14:29:58 +03:00
.Bk -words
.Op Fl B Ar suffix
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl D Ar destdir
.Ek
.Bk -words
.Op Fl f Ar flags
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl M Ar metalog
.Ek
.Bk -words
.Op Fl T Ar tags
.Ek
.Bk -words
.Op Fl a Ar command
.Ek
.Bk -words
1993-03-21 12:45:37 +03:00
.Op Fl m Ar mode
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl N Ar dbdir
.Ek
.Bk -words
1993-03-21 12:45:37 +03:00
.Op Fl o Ar owner
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl g Ar group
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl l Ar linkflags
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl S Ar stripflag
1999-03-07 14:29:58 +03:00
.Ek
1993-03-21 12:45:37 +03:00
.Ar file1 file2
.Nm
.Op Fl Ubcprs
1999-03-07 14:29:58 +03:00
.Bk -words
.Op Fl B Ar suffix
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl D Ar destdir
.Ek
.Bk -words
.Op Fl f Ar flags
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl M Ar metalog
.Ek
.Bk -words
.Op Fl T Ar tags
.Ek
.Bk -words
.Op Fl a Ar command
.Ek
.Bk -words
1993-03-21 12:45:37 +03:00
.Op Fl m Ar mode
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl N Ar dbdir
.Ek
.Bk -words
1993-03-21 12:45:37 +03:00
.Op Fl o Ar owner
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl g Ar group
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl l Ar linkflags
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl S Ar stripflag
1999-03-07 14:29:58 +03:00
.Ek
.Ar file1 ...\&
1993-03-21 12:45:37 +03:00
.Ar fileN directory
.Nm
.Fl d
.Op Fl Up
1999-03-07 14:29:58 +03:00
.Bk -words
.Op Fl D Ar destdir
.Ek
.Bk -words
.Op Fl M Ar metalog
.Ek
.Bk -words
.Op Fl T Ar tags
.Ek
.Bk -words
.Op Fl a Ar command
.Ek
.Bk -words
1993-06-11 22:30:46 +04:00
.Op Fl m Ar mode
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
.Op Fl N Ar dbdir
.Ek
.Bk -words
1993-06-11 22:30:46 +04:00
.Op Fl o Ar owner
1999-03-07 14:29:58 +03:00
.Ek
.Bk -words
1993-06-11 22:30:46 +04:00
.Op Fl g Ar group
1999-03-07 14:29:58 +03:00
.Ek
.Ar directory ...\&
1993-03-21 12:45:37 +03:00
.Sh DESCRIPTION
The file(s) are moved (copied if the
1993-03-21 12:45:37 +03:00
.Fl c
option is specified, or linked if the
1997-04-03 19:28:06 +04:00
.Fl l
option is specified) to the target file or directory.
1993-03-21 12:45:37 +03:00
If the destination is a directory, then the
.Ar file
is moved into
.Ar directory
with its original filename.
2001-12-01 19:43:07 +03:00
If the target file already exists, it is
either renamed to
.Ar file.old
2001-12-01 19:43:07 +03:00
if the
.Fl b
option is given
or overwritten
if permissions allow; an alternate backup suffix may be specified via the
.Fl B
option's argument.
1993-03-21 12:45:37 +03:00
.Pp
.Bl -tag -width Ds
.It Fl a Ar command
Run
.Ar command
on the target after installation and stripping
.Pq Fl s ,
2002-12-19 12:17:01 +03:00
but before
ownership, permissions or timestamps are set and before renaming
.Pq Fl r
occurs.
.Ar command
is invoked via the
.Xr sh 1
shell, allowing a single
.Fl a
argument be to specified to
.Nm
which the shell can then tokenize.
.It Fl b
Backup any existing files before overwriting them by renaming
2001-12-01 19:43:07 +03:00
them to
.Ar file.old . See
.Fl B
for specifying a different backup suffix.
.It Fl B Ar suffix
2001-12-01 19:43:07 +03:00
Use
.Ar suffix
2001-12-01 19:43:07 +03:00
as the backup suffix if
.Fl b
2002-09-30 15:08:56 +04:00
is given.
If
1999-01-26 04:34:25 +03:00
.Ar suffix
contains a '%' sign, a numbered backup will be performed, and the
%-pattern will be expanded using
.Xr sprintf 3 ,
2001-12-01 19:43:07 +03:00
given an integer counter as the backup number.
1999-01-26 04:34:25 +03:00
The counter used starts from 0, and the first available name resulting
2001-12-01 19:43:07 +03:00
from the expansion is used.
.It Fl c
Copy the file.
This flag turns off the default behavior of
.Nm
where it deletes the original file after creating the target.
.It Fl d
Create directories.
Missing parent directories are created as required.
.It Fl D Ar destdir
Specify the
.Ev DESTDIR
(top of the file hierarchy) that the items are installed in to.
If
.Fl M Ar metalog
is in use, a leading string of
.Dq Ar destdir
2002-12-23 15:49:38 +03:00
will be removed from the file names logged to the
.Ar metalog .
This option does not affect where the actual files are installed.
.It Fl f Ar flags
Specify the target's file flags.
(See
.Xr chflags 1
for a list of possible flags and their meanings.)
.It Fl g Ar group
Specify a group.
.It Fl l Ar linkflags
2002-09-30 15:08:56 +04:00
Instead of copying the file make a link to the source.
The type of the link is determined by the
.Ar linkflags
2002-09-30 15:08:56 +04:00
argument.
Valid
.Ar linkflags
are:
.Ar a
(absolute),
.Ar r
(relative),
.Ar h
(hard),
.Ar s
(symbolic),
.Ar m
2002-09-30 15:08:56 +04:00
(mixed).
Absolute and relative have effect only for symbolic links.
Mixed links
are hard links for files on the same filesystem, symbolic otherwise.
.It Fl M Ar metalog
Write the metadata associated with each item installed to
.Ar metalog
in an
.Xr mtree 8
.Dq full path
specification line.
The metadata includes: the file name and file type, and depending upon
other options, the owner, group, file flags, modification time, and tags.
.It Fl m Ar mode
Specify an alternative mode.
The default mode is set to rwxr-xr-x (0755).
The specified mode may be either an octal or symbolic value; see
.Xr chmod 1
for a description of possible mode values.
.It Fl N Ar dbdir
Use the user database text file
.Pa master.passwd
and group database text file
.Pa group
from
.Ar dbdir ,
rather than using the results from the system's
.Xr getpwnam 3
and
.Xr getgrnam 3
(and related) library calls.
.It Fl o Ar owner
1993-03-21 12:45:37 +03:00
Specify an owner.
1998-09-28 12:16:15 +04:00
.It Fl p
Preserve the source files access and modification times.
.It Fl r
Install to a temporary file and then rename the file to its final destination
2002-09-30 15:08:56 +04:00
name.
This can be used for precious files, to avoid truncation of the original
when error conditions (filesystem full etc.) occur.
1993-03-21 12:45:37 +03:00
.It Fl s
.Nm
1993-03-21 12:45:37 +03:00
exec's the command
.Xr strip 1
to strip binaries so that install can be portable over a large
2002-09-30 15:08:56 +04:00
number of systems and binary types.
If the environment variable
1997-10-20 07:32:25 +04:00
.Ev STRIP
is set, it is used as the
.Xr strip 1
program.
.It Fl S Ar stripflags
.Nm
passes
.Ar stripflags
as option arguments to
.Xr strip 1 .
When
.Fl S
is used,
.Xr strip 1
is invoked via the
.Xr sh 1
shell, allowing a single
.Fl S
argument be to specified to
.Nm
2002-09-30 15:08:56 +04:00
which the shell can then tokenize.
Normally,
.Nm
invokes
.Xr strip 1
2002-09-30 15:08:56 +04:00
directly.
This flag implies
.Fl s .
.It Fl T Ar tags
Specify the
.Xr mtree 8
tags to write out for the file when using
.Fl M Ar metalog .
.It Fl U
Indicate that install is running unprivileged, and that it should not
try to change the owner, the group, or the file flags of the destination.
The information that would have been updated can be stored in a log
file with
2001-12-08 22:27:33 +03:00
.Fl M Ar metalog .
1993-03-21 12:45:37 +03:00
.El
.Pp
By default,
.Nm
preserves all file flags, with the exception of the ``nodump'' flag.
.Pp
The
.Nm
utility attempts to prevent moving a file onto itself.
1993-03-21 12:45:37 +03:00
.Pp
Installing
.Pa /dev/null
creates an empty file.
.Sh EXIT STATUS
The
.Nm
utility exits 0 on success,
and \*[Gt]0 if an error occurs.
.Sh ENVIRONMENT
.Bl -tag -width Fl
.It Ev STRIP
The program used to strip installed binaries when the
.Fl s
2002-09-30 15:08:56 +04:00
option is used.
If unspecified,
.Pa /usr/bin/strip
is used.
.El
1993-03-21 12:45:37 +03:00
.Sh SEE ALSO
.Xr chflags 1 ,
1993-03-21 12:45:37 +03:00
.Xr chgrp 1 ,
.Xr chmod 1 ,
.Xr cp 1 ,
.Xr mv 1 ,
.Xr strip 1 ,
2001-12-01 19:43:07 +03:00
.Xr chown 8 ,
.Xr mtree 8
1993-03-21 12:45:37 +03:00
.Sh HISTORY
The
.Nm
1993-03-21 12:45:37 +03:00
utility appeared in
.Bx 4.2 .