summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjlam <jlam@pkgsrc.org>2005-02-04 09:10:13 +0000
committerjlam <jlam@pkgsrc.org>2005-02-04 09:10:13 +0000
commit21f238d2ab10dea987cd356cf988f57692483425 (patch)
treedf2d36a484c7d28e736c190735e7552bd6610240
parent9f3d69e32e5a104ffab295d8448b2abdf6a1eb22 (diff)
downloadpkgsrc-21f238d2ab10dea987cd356cf988f57692483425.tar.gz
Update pkgtools/pkg_install to 20050204 (latest release from the HEAD
branch of src). Changes from version 20050106: Teach pkg_add(1) and pkg_delete(1) to pass PKG_METADATA_DIR and PKG_REFCOUNT_DBDIR in the environment when running the +* scripts. PKG_METADATA_DIR is the location of the +* files after the package is registered. PKG_REFCOUNT_DBDIR is the location of the reference counts database directory. If PKG_REFCOUNT_DBDIR is left unset, then it defaults the the location of the package database directory with ".refcount" appended to the path, e.g. /var/db/pkg.refcount. pkgviews users should explicitly set PKG_REFCOUNT_DBDIR in the shell environment to ensure that all packages will use the same refcount database. These changes allow the +INSTALL and +DEINSTALL script to keep state in +* files within ${PKG_METADATA_DIR}, and to store reference counts in ${PKG_REFCOUNT_DBDIR} to handle usage of resources outside of ${LOCALBASE}.
-rw-r--r--pkgtools/pkg_install/files/add/perform.c39
-rw-r--r--pkgtools/pkg_install/files/add/pkg_add.118
-rw-r--r--pkgtools/pkg_install/files/add/pkg_add.cat114
-rw-r--r--pkgtools/pkg_install/files/delete/perform.c6
-rw-r--r--pkgtools/pkg_install/files/delete/pkg_delete.129
-rw-r--r--pkgtools/pkg_install/files/delete/pkg_delete.cat117
-rw-r--r--pkgtools/pkg_install/files/lib/file.c40
-rw-r--r--pkgtools/pkg_install/files/lib/lib.h16
-rw-r--r--pkgtools/pkg_install/files/lib/pkgdb.c23
-rw-r--r--pkgtools/pkg_install/files/lib/version.h4
10 files changed, 163 insertions, 43 deletions
diff --git a/pkgtools/pkg_install/files/add/perform.c b/pkgtools/pkg_install/files/add/perform.c
index a85d9f42a79..f7f3e4eaa3f 100644
--- a/pkgtools/pkg_install/files/add/perform.c
+++ b/pkgtools/pkg_install/files/add/perform.c
@@ -1,4 +1,4 @@
-/* $NetBSD: perform.c,v 1.27 2004/12/29 12:16:56 agc Exp $ */
+/* $NetBSD: perform.c,v 1.28 2005/02/04 09:10:13 jlam Exp $ */
#if HAVE_CONFIG_H
#include "config.h"
@@ -11,7 +11,7 @@
#if 0
static const char *rcsid = "from FreeBSD Id: perform.c,v 1.44 1997/10/13 15:03:46 jkh Exp";
#else
-__RCSID("$NetBSD: perform.c,v 1.27 2004/12/29 12:16:56 agc Exp $");
+__RCSID("$NetBSD: perform.c,v 1.28 2005/02/04 09:10:13 jlam Exp $");
#endif
#endif
@@ -444,7 +444,6 @@ pkg_do(const char *pkg, lpkg_head_t *pkgs)
add_plist_top(&Plist, PLIST_CWD, Prefix);
}
- setenv(PKG_PREFIX_VNAME, (p = find_plist(&Plist, PLIST_CWD)) ? p->name : ".", 1);
/* Protect against old packages with bogus @name fields */
PkgName = (p = find_plist(&Plist, PLIST_NAME)) ? p->name : "anonymous";
@@ -464,6 +463,11 @@ pkg_do(const char *pkg, lpkg_head_t *pkgs)
(void) snprintf(LogDir, sizeof(LogDir), "%s/%s", dbdir, PkgName);
}
+ /* Set environment variables expected by the +INSTALL script. */
+ setenv(PKG_PREFIX_VNAME, (p = find_plist(&Plist, PLIST_CWD)) ? p->name : ".", 1);
+ setenv(PKG_METADATA_DIR_VNAME, LogDir, 1);
+ setenv(PKG_REFCOUNT_DBDIR_VNAME, pkgdb_refcount_dir(), 1);
+
/* make sure dbdir actually exists! */
if (!(isdir(dbdir) || islinktodir(dbdir))) {
if (fexec("mkdir", "-p", dbdir, NULL)) {
@@ -866,16 +870,11 @@ ignore_replace_depends_check:
}
/* Make sure pkg_info can read the entry */
(void) fexec(CHMOD_CMD, "a+rx", LogDir, NULL);
- if (fexists(INSTALL_FNAME))
- move_file(".", INSTALL_FNAME, LogDir);
- if (fexists(DEINSTALL_FNAME))
- move_file(".", DEINSTALL_FNAME, LogDir);
- if (fexists(REQUIRE_FNAME))
- move_file(".", REQUIRE_FNAME, LogDir);
- if (fexists(SIZE_PKG_FNAME))
- move_file(".", SIZE_PKG_FNAME, LogDir);
- if (fexists(SIZE_ALL_FNAME))
- move_file(".", SIZE_ALL_FNAME, LogDir);
+
+ /* Move all of the +-files into place */
+ move_files(".", "+*", LogDir);
+
+ /* Generate the +CONTENTS file in-place from the Plist */
(void) snprintf(contents, sizeof(contents), "%s/%s", LogDir, CONTENTS_FNAME);
cfile = fopen(contents, "w");
if (!cfile) {
@@ -885,20 +884,6 @@ ignore_replace_depends_check:
}
write_plist(&Plist, cfile, NULL);
fclose(cfile);
- move_file(".", DESC_FNAME, LogDir);
- move_file(".", COMMENT_FNAME, LogDir);
- if (fexists(BUILD_VERSION_FNAME))
- move_file(".", BUILD_VERSION_FNAME, LogDir);
- if (fexists(BUILD_INFO_FNAME))
- move_file(".", BUILD_INFO_FNAME, LogDir);
- if (fexists(DISPLAY_FNAME))
- move_file(".", DISPLAY_FNAME, LogDir);
- if (fexists(PRESERVE_FNAME))
- move_file(".", PRESERVE_FNAME, LogDir);
- if (fexists(VIEWS_FNAME)) {
- is_depoted_pkg = TRUE;
- move_file(".", VIEWS_FNAME, LogDir);
- }
/* register dependencies */
/* we could save some cycles here if we remembered what we
diff --git a/pkgtools/pkg_install/files/add/pkg_add.1 b/pkgtools/pkg_install/files/add/pkg_add.1
index 82d412ce6e4..1a204acee75 100644
--- a/pkgtools/pkg_install/files/add/pkg_add.1
+++ b/pkgtools/pkg_install/files/add/pkg_add.1
@@ -1,4 +1,4 @@
-.\" $NetBSD: pkg_add.1,v 1.11 2005/02/04 01:19:03 jlam Exp $
+.\" $NetBSD: pkg_add.1,v 1.12 2005/02/04 09:10:13 jlam Exp $
.\"
.\" FreeBSD install - a package for the installation and maintenance
.\" of non-core utilities.
@@ -17,7 +17,7 @@
.\"
.\" @(#)pkg_add.1
.\"
-.Dd December 10, 2004
+.Dd February 4, 2005
.Dt PKG_ADD 1
.Os
.Sh NAME
@@ -514,6 +514,14 @@ is installed, even if the user might change it with the
.Fl p
flag to
.Cm pkg_add .
+The scripts are also called with the
+.Ev PKG_METADATA_DIR
+environment variable set to the location of the
+.Ar +*
+meta-data files, and with the
+.Ev PKG_REFCOUNT_DBDIR
+environment variable set to the location of the package reference counts
+database directory.
.Sh ENVIRONMENT
.Bl -tag -width PKG_TMPDIR
.It Ev LOCALBASE
@@ -543,6 +551,12 @@ Each entry consists of a directory name or URL.
The current directory may be indicated implicitly by an empty directory
name, or explicitly by a single period.
FTP URLs may not end with a slash.
+.It Ev PKG_REFCOUNT_DBDIR
+Location of the package reference counts database directory.
+The default location is the path to the package database directory with
+.Do .refcount Dc
+appended to the path, e.g.
+.Pa /var/db/pkg.refcount .
.It Ev PKG_TMPDIR
Staging directory for installing packages, defaults to /var/tmp.
Set to directory with lots of free disk if you run out of
diff --git a/pkgtools/pkg_install/files/add/pkg_add.cat1 b/pkgtools/pkg_install/files/add/pkg_add.cat1
index 82520bcd95e..e7325ccf26b 100644
--- a/pkgtools/pkg_install/files/add/pkg_add.cat1
+++ b/pkgtools/pkg_install/files/add/pkg_add.cat1
@@ -285,7 +285,11 @@ TTEECCHHNNIICCAALL DDEETTAAIILLSS
PKG_PREFIX set to the installation prefix (see the --pp option above).
This allows a package author to write a script that reliably performs
some action on the directory where the package is installed, even if the
- user might change it with the --pp flag to ppkkgg__aadddd.
+ user might change it with the --pp flag to ppkkgg__aadddd. The scripts are also
+ called with the PKG_METADATA_DIR environment variable set to the location
+ of the _+_* meta-data files, and with the PKG_REFCOUNT_DBDIR environment
+ variable set to the location of the package reference counts database
+ directory.
EENNVVIIRROONNMMEENNTT
LOCALBASE This is the location of the _v_i_e_w_b_a_s_e directory in which all
@@ -304,6 +308,12 @@ EENNVVIIRROONNMMEENNTT
empty directory name, or explicitly by a single period. FTP
URLs may not end with a slash.
+ PKG_REFCOUNT_DBDIR
+ Location of the package reference counts database directory.
+ The default location is the path to the package database
+ directory with ``.refcount'' appended to the path, e.g.
+ _/_v_a_r_/_d_b_/_p_k_g_._r_e_f_c_o_u_n_t.
+
PKG_TMPDIR Staging directory for installing packages, defaults to
/var/tmp. Set to directory with lots of free disk if you run
out of space when installing a binary package.
@@ -359,4 +369,4 @@ BBUUGGSS
Sure to be others.
-NetBSD 2.0 December 10, 2004 NetBSD 2.0
+NetBSD 2.0 February 4, 2005 NetBSD 2.0
diff --git a/pkgtools/pkg_install/files/delete/perform.c b/pkgtools/pkg_install/files/delete/perform.c
index 14c5fb9f3ea..314415cc205 100644
--- a/pkgtools/pkg_install/files/delete/perform.c
+++ b/pkgtools/pkg_install/files/delete/perform.c
@@ -1,4 +1,4 @@
-/* $NetBSD: perform.c,v 1.13 2004/12/29 12:16:56 agc Exp $ */
+/* $NetBSD: perform.c,v 1.14 2005/02/04 09:10:13 jlam Exp $ */
#if HAVE_CONFIG_H
#include "config.h"
@@ -11,7 +11,7 @@
#if 0
static const char *rcsid = "from FreeBSD Id: perform.c,v 1.15 1997/10/13 15:03:52 jkh Exp";
#else
-__RCSID("$NetBSD: perform.c,v 1.13 2004/12/29 12:16:56 agc Exp $");
+__RCSID("$NetBSD: perform.c,v 1.14 2005/02/04 09:10:13 jlam Exp $");
#endif
#endif
@@ -657,6 +657,7 @@ pkg_do(char *pkg)
return 0;
}
+ setenv(PKG_REFCOUNT_DBDIR_VNAME, pkgdb_refcount_dir(), 1);
if (!getcwd(home, MaxPathSize)) {
cleanup(0);
errx(2, "unable to get current working directory!");
@@ -738,6 +739,7 @@ pkg_do(char *pkg)
return 1;
}
setenv(PKG_PREFIX_VNAME, p->name, 1);
+ setenv(PKG_METADATA_DIR_VNAME, LogDir, 1);
if (fexists(REQUIRE_FNAME)) {
if (Verbose)
printf("Executing 'require' script.\n");
diff --git a/pkgtools/pkg_install/files/delete/pkg_delete.1 b/pkgtools/pkg_install/files/delete/pkg_delete.1
index 11d1018d6ea..c6fad81be23 100644
--- a/pkgtools/pkg_install/files/delete/pkg_delete.1
+++ b/pkgtools/pkg_install/files/delete/pkg_delete.1
@@ -1,4 +1,4 @@
-.\" $NetBSD: pkg_delete.1,v 1.9 2005/02/04 01:19:03 jlam Exp $
+.\" $NetBSD: pkg_delete.1,v 1.10 2005/02/04 09:10:13 jlam Exp $
.\"
.\" FreeBSD install - a package for the installation and maintenance
.\" of non-core utilities.
@@ -17,7 +17,7 @@
.\"
.\" from FreeBSD: @(#)pkg_delete.1
.\"
-.Dd November 2, 2004
+.Dd February 4, 2005
.Dt PKG_DELETE 1
.Os
.Sh NAME
@@ -263,6 +263,31 @@ option when running
.Nm
or
.Xr pkg_add 1 .
+The scripts are also called with the
+.Ev PKG_METADATA_DIR
+environment variable set to the location of the
+.Ar +*
+meta-data files, and with the
+.Ev PKG_REFCOUNT_DBDIR
+environment variable set to the location of the package reference counts
+database directory.
+.Sh ENVIRONMENT
+.Bl -tag -width PKG_DBDIR
+.It Ev PKG_DBDIR
+If the
+.Fl K
+flag isn't given, then
+.Ev PKG_DBDIR
+is the location of the package database directory.
+The default package database directory is
+.Pa /var/db/pkg .
+.It Ev PKG_REFCOUNT_DBDIR
+Location of the package reference counts database directory.
+The default location is the path to the package database directory with
+.Do .refcount Dc
+appended to the path, e.g.
+.Pa /var/db/pkg.refcount .
+.El
.Sh SEE ALSO
.Xr pkg_add 1 ,
.Xr pkg_admin 1 ,
diff --git a/pkgtools/pkg_install/files/delete/pkg_delete.cat1 b/pkgtools/pkg_install/files/delete/pkg_delete.cat1
index f0f28546d98..36defe12d24 100644
--- a/pkgtools/pkg_install/files/delete/pkg_delete.cat1
+++ b/pkgtools/pkg_install/files/delete/pkg_delete.cat1
@@ -139,6 +139,21 @@ TTEECCHHNNIICCAALL DDEETTAAIILLSS
author to write a script that reliably performs some action on the direc-
tory where the package is installed, even if the user might have changed
it by specifying the --pp option when running ppkkgg__ddeelleettee or pkg_add(1).
+ The scripts are also called with the PKG_METADATA_DIR environment vari-
+ able set to the location of the _+_* meta-data files, and with the
+ PKG_REFCOUNT_DBDIR environment variable set to the location of the pack-
+ age reference counts database directory.
+
+EENNVVIIRROONNMMEENNTT
+ PKG_DBDIR If the --KK flag isn't given, then PKG_DBDIR is the location of
+ the package database directory. The default package database
+ directory is _/_v_a_r_/_d_b_/_p_k_g.
+
+ PKG_REFCOUNT_DBDIR
+ Location of the package reference counts database directory.
+ The default location is the path to the package database
+ directory with ``.refcount'' appended to the path, e.g.
+ _/_v_a_r_/_d_b_/_p_k_g_._r_e_f_c_o_u_n_t.
SSEEEE AALLSSOO
pkg_add(1), pkg_admin(1), pkg_create(1), pkg_info(1), mktemp(3),
@@ -153,4 +168,4 @@ AAUUTTHHOORRSS
NetBSD wildcard dependency processing, pkgdb, recursive "down"
delete, etc.
-NetBSD 2.0 November 2, 2004 NetBSD 2.0
+NetBSD 2.0 February 4, 2005 NetBSD 2.0
diff --git a/pkgtools/pkg_install/files/lib/file.c b/pkgtools/pkg_install/files/lib/file.c
index b335fbc495d..5b97fbacf2a 100644
--- a/pkgtools/pkg_install/files/lib/file.c
+++ b/pkgtools/pkg_install/files/lib/file.c
@@ -1,4 +1,4 @@
-/* $NetBSD: file.c,v 1.13 2004/12/29 12:16:56 agc Exp $ */
+/* $NetBSD: file.c,v 1.14 2005/02/04 09:10:13 jlam Exp $ */
#if HAVE_CONFIG_H
#include "config.h"
@@ -11,7 +11,7 @@
#if 0
static const char *rcsid = "from FreeBSD Id: file.c,v 1.29 1997/10/08 07:47:54 charnier Exp";
#else
-__RCSID("$NetBSD: file.c,v 1.13 2004/12/29 12:16:56 agc Exp $");
+__RCSID("$NetBSD: file.c,v 1.14 2005/02/04 09:10:13 jlam Exp $");
#endif
#endif
@@ -543,6 +543,42 @@ move_file(char *dir, char *fname, char *to)
}
void
+move_files(const char *dir, const char *pattern, const char *to)
+{
+ char fpath[MaxPathSize];
+ glob_t globbed;
+ int i;
+
+ (void) snprintf(fpath, sizeof(fpath), "%s/%s", dir, pattern);
+ if ((i=glob(fpath, GLOB_NOSORT, NULL, &globbed)) != 0) {
+ switch(i) {
+ case GLOB_NOMATCH:
+ warn("no files matching ``%s'' found", fpath);
+ break;
+ case GLOB_ABORTED:
+ warn("globbing aborted");
+ break;
+ case GLOB_NOSPACE:
+ warn("out-of-memory during globbing");
+ break;
+ default:
+ warn("unknown error during globbing");
+ break;
+ }
+ return;
+ }
+
+ /* Moving globbed files -- we just use mv(1) to do the job */
+ for (i=0; i<globbed.gl_pathc; i++)
+ if (fexec("mv", globbed.gl_pathv[i], to, NULL)) {
+ cleanup(0);
+ errx(2, "could not perform 'mv %s %s'", globbed.gl_pathv[i], to);
+ }
+
+ return;
+}
+
+void
remove_files(const char *path, const char *pattern)
{
char fpath[MaxPathSize];
diff --git a/pkgtools/pkg_install/files/lib/lib.h b/pkgtools/pkg_install/files/lib/lib.h
index eb4debb13eb..5e52701c6b2 100644
--- a/pkgtools/pkg_install/files/lib/lib.h
+++ b/pkgtools/pkg_install/files/lib/lib.h
@@ -1,4 +1,4 @@
-/* $NetBSD: lib.h,v 1.15 2004/12/29 12:16:56 agc Exp $ */
+/* $NetBSD: lib.h,v 1.16 2005/02/04 09:10:13 jlam Exp $ */
/* from FreeBSD Id: lib.h,v 1.25 1997/10/08 07:48:03 charnier Exp */
@@ -169,6 +169,18 @@ enum {
/* The name of the "prefix" environment variable given to scripts */
#define PKG_PREFIX_VNAME "PKG_PREFIX"
+/*
+ * The name of the "metadatadir" environment variable given to scripts.
+ * This variable holds the location of the +-files for this package.
+ */
+#define PKG_METADATA_DIR_VNAME "PKG_METADATA_DIR"
+
+/*
+ * The name of the environment variable holding the location to the
+ * reference-counts database directory.
+ */
+#define PKG_REFCOUNT_DBDIR_VNAME "PKG_REFCOUNT_DBDIR"
+
#define PKG_PATTERN_MAX MaxPathSize /* max length of pattern, including nul */
#define PKG_SUFFIX_MAX 10 /* max length of suffix, including nul */
@@ -308,6 +320,7 @@ Boolean make_preserve_name(char *, size_t, char *, char *);
void write_file(char *, char *);
void copy_file(char *, char *, char *);
void move_file(char *, char *, char *);
+void move_files(const char *, const char *, const char *);
void remove_files(const char *, const char *);
int delete_hierarchy(char *, Boolean, Boolean);
int unpack(const char *, const char *);
@@ -345,6 +358,7 @@ char *pkgdb_retrieve(const char *);
void pkgdb_dump(void);
int pkgdb_remove(const char *);
int pkgdb_remove_pkg(const char *);
+char *pkgdb_refcount_dir(void);
char *_pkgdb_getPKGDB_FILE(char *, unsigned);
char *_pkgdb_getPKGDB_DIR(void);
void _pkgdb_setPKGDB_DIR(const char *);
diff --git a/pkgtools/pkg_install/files/lib/pkgdb.c b/pkgtools/pkg_install/files/lib/pkgdb.c
index 2d48d344c75..ae88f0465e4 100644
--- a/pkgtools/pkg_install/files/lib/pkgdb.c
+++ b/pkgtools/pkg_install/files/lib/pkgdb.c
@@ -1,4 +1,4 @@
-/* $NetBSD: pkgdb.c,v 1.22 2004/12/29 12:16:56 agc Exp $ */
+/* $NetBSD: pkgdb.c,v 1.23 2005/02/04 09:10:13 jlam Exp $ */
#if HAVE_CONFIG_H
#include "config.h"
@@ -8,7 +8,7 @@
#include <sys/cdefs.h>
#endif
#ifndef lint
-__RCSID("$NetBSD: pkgdb.c,v 1.22 2004/12/29 12:16:56 agc Exp $");
+__RCSID("$NetBSD: pkgdb.c,v 1.23 2005/02/04 09:10:13 jlam Exp $");
#endif
/*
@@ -61,6 +61,9 @@ __RCSID("$NetBSD: pkgdb.c,v 1.22 2004/12/29 12:16:56 agc Exp $");
#if HAVE_STDIO_H
#include <stdio.h>
#endif
+#if HAVE_STRING_H
+#include <string.h>
+#endif
#include "lib.h"
@@ -275,6 +278,22 @@ int pkgdb_remove_pkg(const char *pkg) { return 1; }
#endif /* HAVE_DBOPEN */
/*
+ * Return the location of the package reference counts database directory.
+ */
+char *
+pkgdb_refcount_dir(void)
+{
+ static char buf[MaxPathSize];
+ char *tmp;
+
+ if (tmp = getenv(PKG_REFCOUNT_DBDIR_VNAME))
+ strlcpy(buf, tmp, sizeof(buf));
+ else
+ snprintf(buf, sizeof(buf), "%s.refcount", _pkgdb_getPKGDB_DIR());
+ return buf;
+}
+
+/*
* Return name of cache file in the buffer that was passed.
*/
char *
diff --git a/pkgtools/pkg_install/files/lib/version.h b/pkgtools/pkg_install/files/lib/version.h
index a7fade9494c..67bea6f9102 100644
--- a/pkgtools/pkg_install/files/lib/version.h
+++ b/pkgtools/pkg_install/files/lib/version.h
@@ -1,4 +1,4 @@
-/* $NetBSD: version.h,v 1.39 2005/01/07 11:58:12 agc Exp $ */
+/* $NetBSD: version.h,v 1.40 2005/02/04 09:10:13 jlam Exp $ */
/*
* Copyright (c) 2001 Thomas Klausner. All rights reserved.
@@ -33,6 +33,6 @@
#ifndef _INST_LIB_VERSION_H_
#define _INST_LIB_VERSION_H_
-#define PKGTOOLS_VERSION "20050106"
+#define PKGTOOLS_VERSION "20050204"
#endif /* _INST_LIB_VERSION_H_ */