char * pkgdb_pkg_file(const char *pkg, const char *file) { char *buf; if (asprintf(&buf, "%s/%s/%s", _pkgdb_getPKGDB_DIR(), pkg, file) == -1) err(EXIT_FAILURE, "asprintf failed"); return buf; }
/* * 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 * _pkgdb_getPKGDB_FILE(char *buf, unsigned size) { (void) snprintf(buf, size, "%s/%s", _pkgdb_getPKGDB_DIR(), PKGDB_FILE); return buf; }
/* * add1pkg(<pkg>) * adds the files listed in the +CONTENTS of <pkg> into the * pkgdb.byfile.db database file in the current package dbdir. It * returns the number of files added to the database file. */ static int add_pkg(const char *pkgdir, void *vp) { FILE *f; plist_t *p; package_t Plist; char *contents; const char *PkgDBDir; char *PkgName, *dirp; char file[MaxPathSize]; char dir[MaxPathSize]; int tmp, *cnt; if (!pkgdb_open(ReadWrite)) err(EXIT_FAILURE, "cannot open pkgdb"); cnt = vp != NULL ? vp : &tmp; PkgDBDir = _pkgdb_getPKGDB_DIR(); contents = pkgdb_pkg_file(pkgdir, CONTENTS_FNAME); if ((f = fopen(contents, "r")) == NULL) errx(EXIT_FAILURE, "%s: can't open `%s'", pkgdir, CONTENTS_FNAME); free(contents); read_plist(&Plist, f); if ((p = find_plist(&Plist, PLIST_NAME)) == NULL) { errx(EXIT_FAILURE, "Package `%s' has no @name, aborting.", pkgdir); } PkgName = p->name; dirp = NULL; for (p = Plist.head; p; p = p->next) { switch(p->type) { case PLIST_FILE: if (dirp == NULL) { errx(EXIT_FAILURE, "@cwd not yet found, please send-pr!"); } (void) snprintf(file, sizeof(file), "%s/%s", dirp, p->name); if (!(isfile(file) || islinktodir(file))) { if (isbrokenlink(file)) { warnx("%s: Symlink `%s' exists and is in %s but target does not exist!", PkgName, file, CONTENTS_FNAME); } else { warnx("%s: File `%s' is in %s but not on filesystem!", PkgName, file, CONTENTS_FNAME); } } else { pkgdb_store(file, PkgName); (*cnt)++; } break; case PLIST_PKGDIR: add_pkgdir(PkgName, dirp, p->name); (*cnt)++; break; case PLIST_CWD: if (strcmp(p->name, ".") != 0) { dirp = p->name; } else { (void) snprintf(dir, sizeof(dir), "%s/%s", PkgDBDir, pkgdir); dirp = dir; } break; case PLIST_IGNORE: p = p->next; break; case PLIST_SHOW_ALL: case PLIST_SRC: case PLIST_CMD: case PLIST_CHMOD: case PLIST_CHOWN: case PLIST_CHGRP: case PLIST_COMMENT: case PLIST_NAME: case PLIST_UNEXEC: case PLIST_DISPLAY: case PLIST_PKGDEP: case PLIST_DIR_RM: case PLIST_OPTION: case PLIST_PKGCFL: case PLIST_BLDDEP: break; } } free_plist(&Plist); fclose(f); pkgdb_close(); return 0; }