1993-08-26 01:19:55 +00:00
|
|
|
.\"
|
|
|
|
.\" FreeBSD install - a package for the installation and maintainance
|
|
|
|
.\" of non-core utilities.
|
|
|
|
.\"
|
|
|
|
.\" 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.
|
|
|
|
.\"
|
|
|
|
.\" Jordan K. Hubbard
|
|
|
|
.\"
|
|
|
|
.\"
|
1996-02-12 04:57:03 +00:00
|
|
|
.\" @(#)pkg_delete.1
|
1999-08-28 01:35:59 +00:00
|
|
|
.\" $FreeBSD$
|
1993-08-26 01:19:55 +00:00
|
|
|
.\"
|
2008-05-30 14:26:09 +00:00
|
|
|
.Dd May 30, 2008
|
1999-08-15 08:47:11 +00:00
|
|
|
.Dt PKG_DELETE 1
|
2000-12-14 11:52:05 +00:00
|
|
|
.Os
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh NAME
|
|
|
|
.Nm pkg_delete
|
1997-10-08 07:48:21 +00:00
|
|
|
.Nd a utility for deleting previously installed software package distributions
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm
|
2004-06-29 18:54:47 +00:00
|
|
|
.Op Fl dDfGinrvxX
|
1994-12-06 01:04:17 +00:00
|
|
|
.Op Fl p Ar prefix
|
|
|
|
.Ar pkg-name ...
|
2001-02-27 09:00:18 +00:00
|
|
|
.Nm
|
|
|
|
.Fl a
|
|
|
|
.Op Ar flags
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh DESCRIPTION
|
1993-08-26 01:19:55 +00:00
|
|
|
The
|
1994-12-06 01:04:17 +00:00
|
|
|
.Nm
|
1993-08-26 01:19:55 +00:00
|
|
|
command is used to delete packages that have been previously installed
|
|
|
|
with the
|
1996-02-12 04:57:03 +00:00
|
|
|
.Xr pkg_add 1
|
1993-08-26 01:19:55 +00:00
|
|
|
command.
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh WARNING
|
|
|
|
.Bf -emphasis
|
|
|
|
Since the
|
|
|
|
.Nm
|
|
|
|
command may execute scripts or programs provided by a package file,
|
1999-09-01 10:04:47 +00:00
|
|
|
your system may be susceptible to
|
|
|
|
.Dq Em trojan horses
|
|
|
|
or other subtle
|
1994-12-06 01:04:17 +00:00
|
|
|
attacks from miscreants who create dangerous package files.
|
|
|
|
.Pp
|
|
|
|
You are advised to verify the competence and identity of those who
|
2004-07-02 23:13:00 +00:00
|
|
|
provide installable package files.
|
|
|
|
For extra protection, examine all
|
2001-01-16 09:39:23 +00:00
|
|
|
the package control files in the package record directory
|
|
|
|
.Pa ( /var/db/pkg/<pkg-name>/ ) .
|
1998-12-16 13:59:31 +00:00
|
|
|
Pay particular attention to any +INSTALL, +POST-INSTALL, +DEINSTALL,
|
|
|
|
+POST-DEINSTALL, +REQUIRE or +MTREE_DIRS files, and inspect the +CONTENTS
|
|
|
|
file for
|
1994-12-06 01:04:17 +00:00
|
|
|
.Cm @cwd ,
|
2001-07-15 08:06:20 +00:00
|
|
|
.Cm @mode
|
1994-12-06 01:04:17 +00:00
|
|
|
(check for setuid),
|
|
|
|
.Cm @dirrm ,
|
|
|
|
.Cm @exec ,
|
|
|
|
and
|
|
|
|
.Cm @unexec
|
|
|
|
directives, and/or use the
|
|
|
|
.Xr pkg_info 1
|
|
|
|
command to examine the installed package control files.
|
|
|
|
.Ef
|
|
|
|
.Sh OPTIONS
|
1997-10-08 07:48:21 +00:00
|
|
|
The following command line options are supported:
|
1994-12-06 01:04:17 +00:00
|
|
|
.Bl -tag -width indent
|
|
|
|
.It Ar pkg-name ...
|
|
|
|
The named packages are deinstalled.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl a , -all
|
2001-02-27 09:00:18 +00:00
|
|
|
Unconditionally delete all currently installed packages.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl i , -interactive
|
2001-02-27 09:00:18 +00:00
|
|
|
Request confirmation before attempting to delete each package,
|
|
|
|
regardless whether or not the standard input device is a
|
|
|
|
terminal.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl v , -verbose
|
1997-10-08 07:48:21 +00:00
|
|
|
Turn on verbose output.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl D , -no-script , -no-scripts
|
1994-12-06 01:04:17 +00:00
|
|
|
If a deinstallation script exists for a given package, do not execute it.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl n , -dry-run
|
2005-02-13 22:25:33 +00:00
|
|
|
Do not actually deinstall a package, just report the steps that
|
1994-12-06 01:04:17 +00:00
|
|
|
would be taken if it were.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl p , -prefix Ar prefix
|
1997-10-08 07:48:21 +00:00
|
|
|
Set
|
1994-12-06 01:04:17 +00:00
|
|
|
.Ar prefix
|
1993-08-26 01:19:55 +00:00
|
|
|
as the directory in which to delete files from any installed packages
|
2004-07-02 23:13:00 +00:00
|
|
|
which do not explicitly set theirs.
|
|
|
|
For most packages, the prefix will
|
1994-12-06 01:04:17 +00:00
|
|
|
be set automatically to the installed location by
|
1996-02-12 04:57:03 +00:00
|
|
|
.Xr pkg_add 1 .
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl d , -clean-dirs
|
2004-07-02 23:13:00 +00:00
|
|
|
Remove empty directories created by file cleanup.
|
|
|
|
By default, only
|
1994-12-06 01:04:17 +00:00
|
|
|
files/directories explicitly listed in a package's contents (either as
|
|
|
|
normal files/directories or with the
|
|
|
|
.Cm @dirrm
|
2004-07-02 23:13:00 +00:00
|
|
|
directive) will be removed at deinstallation time.
|
|
|
|
This option tells
|
1994-12-06 01:04:17 +00:00
|
|
|
.Nm
|
|
|
|
to also remove any directories that were emptied as a result of removing
|
2001-07-15 08:06:20 +00:00
|
|
|
the package.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl f , -force
|
1994-12-06 01:04:17 +00:00
|
|
|
Force removal of the package, even if a dependency is recorded or the
|
|
|
|
deinstall or require script fails.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl G , -no-glob
|
2001-02-27 09:00:18 +00:00
|
|
|
Do not try to expand shell glob patterns in the
|
|
|
|
.Ar pkg-name
|
|
|
|
when selecting packages to be deleted (by default
|
|
|
|
.Nm
|
|
|
|
automatically expands shell glob patterns in the
|
|
|
|
.Ar pkg-name ) .
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl x , -regex
|
2001-02-27 09:00:18 +00:00
|
|
|
Treat the
|
|
|
|
.Ar pkg-name
|
|
|
|
as a regular expression and delete all packages whose names match
|
2004-07-02 23:13:00 +00:00
|
|
|
that regular expression.
|
|
|
|
Multiple regular expressions could be
|
2001-02-27 09:00:18 +00:00
|
|
|
provided, in that case
|
|
|
|
.Nm
|
|
|
|
deletes all packages that match at least one
|
|
|
|
regular expression from the list.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl X , -extended
|
2004-06-29 18:54:47 +00:00
|
|
|
Like
|
|
|
|
.Fl x ,
|
|
|
|
but treats the
|
|
|
|
.Ar pkg-name
|
|
|
|
as an extended regular expression.
|
2008-05-30 14:26:09 +00:00
|
|
|
.It Fl r , -recursive
|
2004-07-02 23:13:00 +00:00
|
|
|
Recursive removal.
|
|
|
|
In addition to specified packages, delete all
|
2001-09-19 08:06:48 +00:00
|
|
|
packages that depend on those packages as well.
|
1994-12-06 01:04:17 +00:00
|
|
|
.El
|
|
|
|
.Sh TECHNICAL DETAILS
|
2002-04-20 12:27:18 +00:00
|
|
|
The
|
2000-11-20 20:10:44 +00:00
|
|
|
.Nm
|
2002-04-20 12:27:18 +00:00
|
|
|
utility
|
2004-07-02 23:13:00 +00:00
|
|
|
does pretty much what it says.
|
|
|
|
It examines installed package records in
|
1994-12-06 01:04:17 +00:00
|
|
|
.Pa /var/db/pkg/<pkg-name> ,
|
|
|
|
deletes the package contents, and finally removes the package records.
|
1998-12-31 20:29:29 +00:00
|
|
|
If the environment variable
|
|
|
|
.Ev PKG_DBDIR
|
|
|
|
is set, this overrides the
|
|
|
|
.Pa /var/db/pkg/
|
|
|
|
path shown above.
|
1994-12-06 01:04:17 +00:00
|
|
|
.Pp
|
|
|
|
If a package is required by other installed packages,
|
|
|
|
.Nm
|
|
|
|
will list those dependent packages and refuse to delete the package
|
|
|
|
(unless the
|
|
|
|
.Fl f
|
|
|
|
option is given).
|
|
|
|
.Pp
|
1993-08-26 01:19:55 +00:00
|
|
|
If the package contains a
|
1994-12-06 01:04:17 +00:00
|
|
|
.Ar require
|
2001-07-15 08:06:20 +00:00
|
|
|
file (see
|
2001-01-16 09:39:23 +00:00
|
|
|
.Xr pkg_create 1 ) ,
|
1994-12-06 01:04:17 +00:00
|
|
|
then this is executed first as
|
2001-02-07 13:45:30 +00:00
|
|
|
.Bd -ragged -offset indent -compact
|
1994-12-06 01:04:17 +00:00
|
|
|
.Cm require
|
|
|
|
.Ar <pkg-name>
|
|
|
|
.Ar DEINSTALL
|
|
|
|
.Ed
|
|
|
|
(where
|
|
|
|
.Ar pkg-name
|
|
|
|
is the name of the package in question and
|
1997-06-19 15:18:34 +00:00
|
|
|
.Ar DEINSTALL
|
1994-12-06 01:04:17 +00:00
|
|
|
is a keyword denoting that this is a deinstallation)
|
2004-07-02 23:13:00 +00:00
|
|
|
to see whether or not deinstallation should continue.
|
|
|
|
A non-zero exit
|
1994-12-06 01:04:17 +00:00
|
|
|
status means no, unless the
|
|
|
|
.Fl f
|
|
|
|
option is specified.
|
|
|
|
.Pp
|
1993-08-26 01:19:55 +00:00
|
|
|
If a
|
1994-12-06 01:04:17 +00:00
|
|
|
.Cm deinstall
|
1993-08-26 01:19:55 +00:00
|
|
|
script exists for the package, it is executed before any files are removed.
|
|
|
|
It is this script's responsibility to clean up any additional messy details
|
|
|
|
around the package's installation, since all
|
1994-12-06 01:04:17 +00:00
|
|
|
.Nm
|
1993-08-26 01:19:55 +00:00
|
|
|
knows how to do is delete the files created in the original distribution.
|
|
|
|
The
|
1994-12-06 01:04:17 +00:00
|
|
|
.Nm deinstall
|
|
|
|
script is called as:
|
2001-02-07 13:45:30 +00:00
|
|
|
.Bd -ragged -offset indent -compact
|
1998-12-16 13:59:31 +00:00
|
|
|
.Cm script
|
1994-12-06 01:04:17 +00:00
|
|
|
.Ar <pkg-name>
|
|
|
|
.Ar DEINSTALL
|
|
|
|
.Ed
|
1998-12-16 13:59:31 +00:00
|
|
|
where
|
|
|
|
.Ar pkg-name
|
|
|
|
is the name of the package in question and
|
|
|
|
.Ar DEINSTALL
|
|
|
|
is a keyword denoting this as the pre-deinstallation phase.
|
2000-12-27 15:30:30 +00:00
|
|
|
.Pp
|
2001-02-01 16:44:04 +00:00
|
|
|
.Sy Note :
|
1998-12-16 13:59:31 +00:00
|
|
|
The
|
1994-12-06 01:04:17 +00:00
|
|
|
.Ar DEINSTALL
|
1998-12-16 13:59:31 +00:00
|
|
|
keyword will not appear if separate scripts for deinstall and post-deinstall
|
|
|
|
are given during package creation time (using the
|
2001-02-28 17:38:53 +00:00
|
|
|
.Fl k
|
2001-07-15 08:06:20 +00:00
|
|
|
and
|
2001-02-28 17:38:53 +00:00
|
|
|
.Fl K
|
2001-07-15 08:06:20 +00:00
|
|
|
flags to
|
2001-01-16 09:39:23 +00:00
|
|
|
.Xr pkg_create 1 ) .
|
1998-12-16 13:59:31 +00:00
|
|
|
.Pp
|
|
|
|
If a
|
|
|
|
.Cm post-deinstall
|
|
|
|
script exists for the package, it is executed
|
|
|
|
.Cm after
|
2004-07-02 23:13:00 +00:00
|
|
|
all files are removed.
|
|
|
|
It is this script's responsibility to clean up any
|
1998-12-16 13:59:31 +00:00
|
|
|
additional messy details around the package's installation, and leave the
|
|
|
|
system (hopefully) in the same state that it was prior to the installation
|
|
|
|
of the package.
|
2000-12-27 15:30:30 +00:00
|
|
|
.Pp
|
1998-12-16 13:59:31 +00:00
|
|
|
The
|
|
|
|
.Nm post-deinstall
|
|
|
|
script is called as:
|
2001-02-07 13:45:30 +00:00
|
|
|
.Bd -ragged -offset indent -compact
|
1998-12-16 13:59:31 +00:00
|
|
|
.Cm script
|
|
|
|
.Ar <pkg-name>
|
|
|
|
.Ar POST-DEINSTALL
|
|
|
|
.Ed
|
|
|
|
where
|
|
|
|
.Ar pkg-name
|
|
|
|
is the name of the package in question and
|
|
|
|
.Ar POST-DEINSTALL
|
|
|
|
is a keyword denoting this as the post-deinstallation phase.
|
2000-12-27 15:30:30 +00:00
|
|
|
.Pp
|
2001-02-01 16:44:04 +00:00
|
|
|
.Sy Note :
|
1998-12-16 13:59:31 +00:00
|
|
|
The
|
|
|
|
.Ar POST-DEINSTALL
|
|
|
|
keyword will not appear if separate scripts for deinstall and post-deinstall
|
|
|
|
are given during package creation time (using the
|
2001-02-28 17:38:53 +00:00
|
|
|
.Fl k
|
2001-07-15 08:06:20 +00:00
|
|
|
and
|
2001-02-28 17:38:53 +00:00
|
|
|
.Fl K
|
2001-07-15 08:06:20 +00:00
|
|
|
flags to
|
2001-01-16 09:39:23 +00:00
|
|
|
.Xr pkg_create 1 ) .
|
2000-12-27 15:30:30 +00:00
|
|
|
.Pp
|
1998-12-16 13:59:31 +00:00
|
|
|
Reasoning behind passing keywords such as
|
|
|
|
.Ar DEINSTALL
|
|
|
|
and
|
|
|
|
.Ar POST-DEINSTALL
|
|
|
|
is that it lets you potentially write only one program/script that handles
|
|
|
|
all aspects of installation and deletion.
|
2000-12-27 15:30:30 +00:00
|
|
|
.Pp
|
1998-12-16 13:59:31 +00:00
|
|
|
But experience has proved that this is a lot more difficult to maintain and
|
|
|
|
is not as advantageous as having separate scripts that handle each aspect of
|
|
|
|
installation and deinstallation.
|
1994-12-06 01:04:17 +00:00
|
|
|
.Pp
|
1994-05-25 18:00:04 +00:00
|
|
|
All scripts are called with the environment variable
|
1994-12-06 01:04:17 +00:00
|
|
|
.Ev PKG_PREFIX
|
1994-05-25 18:00:04 +00:00
|
|
|
set to the installation prefix (see the
|
1994-12-06 01:04:17 +00:00
|
|
|
.Fl p
|
2004-07-02 23:13:00 +00:00
|
|
|
option above).
|
|
|
|
This allows a package author to write a script
|
1994-05-25 18:00:04 +00:00
|
|
|
that reliably performs some action on the directory where the package
|
1994-12-06 01:04:17 +00:00
|
|
|
is installed, even if the user might have changed it by specifying the
|
|
|
|
.Fl p
|
|
|
|
option when running
|
|
|
|
.Nm
|
1994-05-25 18:00:04 +00:00
|
|
|
or
|
1994-12-06 01:04:17 +00:00
|
|
|
.Cm pkg_add .
|
1998-12-31 20:29:29 +00:00
|
|
|
.Sh ENVIRONMENT
|
|
|
|
The environment variable
|
|
|
|
.Ev PKG_DBDIR
|
|
|
|
specifies an alternative location for the installed package database.
|
|
|
|
.Sh FILES
|
|
|
|
.Bl -tag -width /var/db/pkg -compact
|
|
|
|
.It Pa /var/db/pkg
|
|
|
|
Default location of the installed package database.
|
2000-12-27 15:30:30 +00:00
|
|
|
.El
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh SEE ALSO
|
1996-02-12 04:57:03 +00:00
|
|
|
.Xr pkg_add 1 ,
|
|
|
|
.Xr pkg_create 1 ,
|
1994-12-06 01:04:17 +00:00
|
|
|
.Xr pkg_info 1 ,
|
2000-02-29 15:13:55 +00:00
|
|
|
.Xr pkg_version 1 ,
|
1994-12-06 01:04:17 +00:00
|
|
|
.Xr mktemp 3 ,
|
1998-03-23 08:31:20 +00:00
|
|
|
.Xr mtree 8
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh AUTHORS
|
1998-03-23 08:31:20 +00:00
|
|
|
.An Jordan Hubbard
|
2001-02-20 21:57:19 +00:00
|
|
|
.Sh CONTRIBUTORS
|
2004-06-29 18:54:47 +00:00
|
|
|
.An John Kohl Aq jtk@rational.com ,
|
|
|
|
.An Oliver Eikemeier Aq eik@FreeBSD.org
|
1994-12-06 01:04:17 +00:00
|
|
|
.Sh BUGS
|
1993-08-26 01:19:55 +00:00
|
|
|
Sure to be some.
|