xbps-bin: add the 'list' target, and remove it from xbps-pkgdb.

--HG--
extra : convert_revision : 411b27525082c2ff7a766490b00056cc7c78d78f
This commit is contained in:
Juan RP 2008-12-26 11:30:19 +01:00
parent 159d9852a7
commit cbe0046537
3 changed files with 41 additions and 125 deletions

View File

@ -50,18 +50,22 @@ usage(void)
{ {
printf("Usage: xbps-bin [action] [arguments]\n\n" printf("Usage: xbps-bin [action] [arguments]\n\n"
" Available actions:\n" " Available actions:\n"
" install, repo-add, repo-list, repo-rm, search, show\n" " install, list, repo-add, repo-list, repo-rm, search, show\n"
" Action arguments:\n" " Action arguments:\n"
" install\t[<pkgname>] [<rootdir>]\n" " install\t[<pkgname>] [<rootdir>]\n"
" list\n"
" repo-add\t[<URI>]\n" " repo-add\t[<URI>]\n"
" repo-list\t[none]\n" " repo-list\t[none]\n"
" repo-rm\t[<URI>]\n" " repo-rm\t[<URI>]\n"
" search\t[<string>]\n" " search\t[<string>]\n"
" show\t[<pkgname>]\n" " show\t[<pkgname>]\n"
" Environment:\n"
" XBPS_META_PATH\tPath to the xbps metadata directory\n"
"\n" "\n"
" Examples:\n" " Examples:\n"
" $ xbps-bin install klibc\n" " $ xbps-bin install klibc\n"
" $ xbps-bin install klibc /path/to/directory\n" " $ xbps-bin install klibc /path/to/directory\n"
" $ xbps-bin list\n"
" $ xbps-bin repo-add /path/to/directory\n" " $ xbps-bin repo-add /path/to/directory\n"
" $ xbps-bin repo-add http://www.location.org/xbps-repo\n" " $ xbps-bin repo-add http://www.location.org/xbps-repo\n"
" $ xbps-bin repo-list\n" " $ xbps-bin repo-list\n"
@ -271,6 +275,27 @@ main(int argc, char **argv)
} }
prop_object_release(dict); prop_object_release(dict);
} else if (strcasecmp(argv[1], "list") == 0) {
/* Lists packages currently registered in database. */
if (argc != 2)
usage();
if (!xbps_append_full_path(dpkgidx, NULL, XBPS_REGPKGDB))
exit(EINVAL);
dict = prop_dictionary_internalize_from_file(dpkgidx);
if (dict == NULL) {
printf("No packages currently registered.\n");
exit(0);
}
if (!xbps_callback_array_iter_in_dict(dict, "packages",
xbps_list_pkgs_in_dict, NULL)) {
prop_object_release(dict);
exit(EINVAL);
}
prop_object_release(dict);
} else if (strcasecmp(argv[1], "install") == 0) { } else if (strcasecmp(argv[1], "install") == 0) {
/* Installs a binary package and required deps. */ /* Installs a binary package and required deps. */
if (argc < 3 || argc > 4) if (argc < 3 || argc > 4)

View File

@ -32,56 +32,6 @@
#include <xbps_api.h> #include <xbps_api.h>
typedef struct pkg_data {
const char *pkgname;
const char *version;
const char *short_desc;
} pkg_data_t;
static prop_dictionary_t make_dict_from_pkg(pkg_data_t *);
static void register_pkg(prop_dictionary_t, pkg_data_t *, const char *);
static void write_plist_file(prop_dictionary_t, const char *);
static prop_dictionary_t
make_dict_from_pkg(pkg_data_t *pkg)
{
prop_dictionary_t dict;
assert(pkg != NULL || pkg->pkgname != NULL);
assert(pkg->version != NULL || pkg->short_desc != NULL);
dict = prop_dictionary_create();
assert(dict != NULL);
prop_dictionary_set_cstring_nocopy(dict, "pkgname", pkg->pkgname);
prop_dictionary_set_cstring_nocopy(dict, "version", pkg->version);
prop_dictionary_set_cstring_nocopy(dict, "short_desc", pkg->short_desc);
return dict;
}
static void
register_pkg(prop_dictionary_t dict, pkg_data_t *pkg, const char *dbfile)
{
prop_dictionary_t pkgdict;
prop_array_t array;
assert(dict != NULL || pkg != NULL || dbfile != NULL);
pkgdict = make_dict_from_pkg(pkg);
assert(pkgdict != NULL);
array = prop_dictionary_get(dict, "packages");
assert(array != NULL);
assert(prop_object_type(array) == PROP_TYPE_ARRAY);
if (!xbps_add_obj_to_array(array, pkgdict)) {
printf("ERROR: couldn't register '%s-%s' in database!\n",
pkg->pkgname, pkg->version);
exit(1);
}
write_plist_file(dict, dbfile);
}
static void static void
write_plist_file(prop_dictionary_t dict, const char *file) write_plist_file(prop_dictionary_t dict, const char *file)
{ {
@ -100,9 +50,8 @@ usage(void)
{ {
printf("usage: xbps-pkgdb <action> [args]\n\n" printf("usage: xbps-pkgdb <action> [args]\n\n"
" Available actions:\n" " Available actions:\n"
" list, register, sanitize-plist, unregister, version\n" " register, sanitize-plist, unregister, version\n"
" Action arguments:\n" " Action arguments:\n"
" list\t[none]\n"
" register\t[<pkgname> <version> <shortdesc>]\n" " register\t[<pkgname> <version> <shortdesc>]\n"
" sanitize-plist\t[<plist>]\n" " sanitize-plist\t[<plist>]\n"
" unregister\t[<pkgname> <version>]\n" " unregister\t[<pkgname> <version>]\n"
@ -110,7 +59,6 @@ usage(void)
" Environment:\n" " Environment:\n"
" XBPS_META_PATH\tPath to xbps metadata root directory\n\n" " XBPS_META_PATH\tPath to xbps metadata root directory\n\n"
" Examples:\n" " Examples:\n"
" $ xbps-pkgdb list\n"
" $ xbps-pkgdb register pkgname 2.0 \"A short description\"\n" " $ xbps-pkgdb register pkgname 2.0 \"A short description\"\n"
" $ xbps-pkgdb sanitize-plist /blah/foo.plist\n" " $ xbps-pkgdb sanitize-plist /blah/foo.plist\n"
" $ xbps-pkgdb unregister pkgname 2.0\n" " $ xbps-pkgdb unregister pkgname 2.0\n"
@ -122,11 +70,10 @@ int
main(int argc, char **argv) main(int argc, char **argv)
{ {
prop_dictionary_t dbdict = NULL, pkgdict; prop_dictionary_t dbdict = NULL, pkgdict;
prop_array_t dbarray = NULL;
pkg_data_t pkg;
const char *version; const char *version;
char dbfile[PATH_MAX], *in_chroot_env; char dbfile[PATH_MAX], *in_chroot_env;
bool in_chroot = false; bool in_chroot = false;
int rv = 0;
if (argc < 2) if (argc < 2)
usage(); usage();
@ -146,60 +93,19 @@ main(int argc, char **argv)
if (argc != 5) if (argc != 5)
usage(); usage();
dbdict = prop_dictionary_internalize_from_file(dbfile); rv = xbps_register_pkg(argv[2], argv[3], argv[4]);
if (dbdict == NULL) { if (rv == EEXIST) {
/* Create package dictionary and add its objects. */ printf("%s=> %s-%s already registered.\n",
pkg.pkgname = argv[2]; in_chroot ? "[chroot] " : "", argv[2], argv[3]);
pkg.version = argv[3]; } else if (rv != 0) {
pkg.short_desc = argv[4]; printf("%s=> couldn't register %s-%s (%s).\n",
pkgdict = make_dict_from_pkg(&pkg); in_chroot ? "[chroot] " : "" , argv[2], argv[3],
assert(pkgdict != NULL); strerror(rv));
/* Add pkg dictionary into array. */
dbarray = prop_array_create();
if (!xbps_add_obj_to_array(dbarray, pkgdict)) {
printf("=> ERROR: couldn't register "
"%s-%s (%s)\n", pkg.pkgname, pkg.version,
strerror(errno));
exit(1);
}
/* Add array into main dictionary. */
dbdict = prop_dictionary_create();
if (!xbps_add_obj_to_dict(dbdict, dbarray,
"packages")) {
printf("=> ERROR: couldn't register "
"%s-%s (%s)\n", pkg.pkgname, pkg.version,
strerror(errno));
exit(1);
}
/* Write main dictionary to file. */
write_plist_file(dbdict, dbfile);
printf("%s==> Package database file not found, "
"creating it.\n", in_chroot ? "[chroot] " : "");
prop_object_release(dbdict);
} else { } else {
/* Check if pkg is already registered. */ printf("%s=> %s-%s registered successfully.\n",
pkgdict = xbps_find_pkg_in_dict(dbdict, argv[2]); in_chroot ? "[chroot] " : "", argv[2], argv[3]);
if (pkgdict != NULL) {
printf("%s=> Package %s-%s already registered.\n",
in_chroot ? "[chroot] " : "",
argv[2], argv[3]);
exit(0);
}
pkg.pkgname = argv[2];
pkg.version = argv[3];
pkg.short_desc = argv[4];
register_pkg(dbdict, &pkg, dbfile);
} }
printf("%s=> %s-%s registered successfully.\n",
in_chroot ? "[chroot] " : "", argv[2], argv[3]);
} else if (strcasecmp(argv[1], "unregister") == 0) { } else if (strcasecmp(argv[1], "unregister") == 0) {
/* Unregisters a package from the database */ /* Unregisters a package from the database */
if (argc != 4) if (argc != 4)
@ -219,22 +125,6 @@ main(int argc, char **argv)
printf("%s=> %s-%s unregistered successfully.\n", printf("%s=> %s-%s unregistered successfully.\n",
in_chroot ? "[chroot] " : "", argv[2], argv[3]); in_chroot ? "[chroot] " : "", argv[2], argv[3]);
} else if (strcasecmp(argv[1], "list") == 0) {
/* Lists packages currently registered in database */
if (argc != 2)
usage();
dbdict = prop_dictionary_internalize_from_file(dbfile);
if (dbdict == NULL) {
printf("=> ERROR: cannot read database file (%s)\n",
strerror(errno));
exit(EINVAL);
}
if (!xbps_callback_array_iter_in_dict(dbdict,
"packages", xbps_list_pkgs_in_dict, NULL))
exit(EINVAL);
} else if (strcasecmp(argv[1], "version") == 0) { } else if (strcasecmp(argv[1], "version") == 0) {
/* Prints version of an installed package */ /* Prints version of an installed package */
if (argc != 3) if (argc != 3)

View File

@ -111,6 +111,7 @@ set_defvars()
done done
XBPS_REGPKGDB_CMD="env XBPS_META_PATH=$XBPS_META_PATH xbps-pkgdb" XBPS_REGPKGDB_CMD="env XBPS_META_PATH=$XBPS_META_PATH xbps-pkgdb"
XBPS_BIN_CMD="env XBPS_META_PATH=$XBPS_META_PATH xbps-bin"
} }
# #
@ -226,7 +227,7 @@ build-pkg)
. $XBPS_SHUTILSDIR/binpkg.sh . $XBPS_SHUTILSDIR/binpkg.sh
. $XBPS_SHUTILSDIR/tmpl_funcs.sh . $XBPS_SHUTILSDIR/tmpl_funcs.sh
if [ "$2" = "all" ]; then if [ "$2" = "all" ]; then
for f in $($XBPS_REGPKGDB_CMD list|awk '{print $1}'); do for f in $($XBPS_BIN_CMD list|awk '{print $1}'); do
setup_tmpl $f setup_tmpl $f
xbps_make_binpkg xbps_make_binpkg
reset_tmpl_vars reset_tmpl_vars
@ -268,7 +269,7 @@ install|install-destdir)
;; ;;
list|listfiles) list|listfiles)
if [ "$target" = "list" ]; then if [ "$target" = "list" ]; then
$XBPS_REGPKGDB_CMD list $XBPS_BIN_CMD list
exit $? exit $?
fi fi
. $XBPS_SHUTILSDIR/pkgtarget_funcs.sh . $XBPS_SHUTILSDIR/pkgtarget_funcs.sh