X-Git-Url: https://pd.if.org/git/?p=zpackage;a=blobdiff_plain;f=zpm.h;h=b090b3ad50ce5bed6fbd071926c238c744942975;hp=f8ce56bf598609efb4388da4379c1c8e722e8a3f;hb=09c80a1f8918d888063f4d1a75921a99fe5f0b5c;hpb=c907b8ec08b06a4a256fd12b79b4bcf5088fbb19 diff --git a/zpm.h b/zpm.h index f8ce56b..b090b3a 100644 --- a/zpm.h +++ b/zpm.h @@ -7,9 +7,11 @@ #include #include #include +#include +#include -#include -#include +#include "sqlite3.h" +#include "lib/jsw/jsw_atree.h" #define ZPM_HASH_STRLEN 64 @@ -41,6 +43,14 @@ struct zpm { struct zpm_package *current_package; }; +struct zpm_stat { + struct stat st; + int configuration; + char hash[65]; /* length + room for a nul byte */ + char diskhash[65]; /* hash of actual file on disk */ + char *target; /* malloced link target */ +}; + struct zpm_dependency { char minpkg[ZPM_PACKAGE_ID_MAX+1]; char maxpkg[ZPM_PACKAGE_ID_MAX+1]; @@ -78,18 +88,36 @@ struct zpm_package { int zpm_parse_package(char *pstr, char *name, char *ver, int *rel); char *zpm_findpkg(struct zpm *zpm, char *pkgstr, char *where); +int zpm_findhash(struct zpm *zpm, char *find, char *dest); char *zpm_findlib(struct zpm *zpm, char *soname, char *where); int zpm_libraries_needed(struct zpm *zpm, char *pkgid, jsw_atree_t *list); int zpm_quote(char *value, char *dest, size_t n); struct zpm_file { - char path[ZPM_PATH_MAX]; - int mode; + char *package; + char *version; + int release; + + char *status; + char *path; + char *target; + + mode_t mode; + //struct zpm_tree *tags; - char owner[32]; - char group[32]; + + char *owner; + char *group; + gid_t gid; + uid_t uid; + + int configuration; time_t mtime; + char type; + dev_t device; char hash[ZPM_HASH_STRLEN+1]; + char confhash[ZPM_HASH_STRLEN+1]; + void *data; /* hook for applications to attach data */ struct zpm_file *next; /* so you can make a linked list */ }; @@ -135,8 +163,9 @@ int zpm_package(struct zpm *zp, int n); /* get file information */ int zpm_stat(struct zpm *z, struct zpm_file *f, int n); -/* will also set the package context to the new package */ -int zpm_newpkg(struct zpm *z, char *base, char *version, int release); +//int zpm_newpkg(struct zpm *z, char *base, char *version, int release); +int zpm_create_package(struct zpm *zpm, char *name, char *ver, int rel); +int zpm_create_pkgid(struct zpm *zpm, char *pkgstr); /* transactions */ int zpm_begin(struct zpm *z); @@ -177,6 +206,10 @@ int zpm_exec(struct zpm *z, const char *sql, int(*callback)(void *, int, char ** int zpm_foreach_path(struct zpm *zpm, char *pkgid, char *where, int (*callback)(void *f, int ncols, char **vals, char **cols), void *data, char **errmsg); + +int zpm_foreach_path_ds(struct zpm *zpm, char *pkgid, char *where, +int (*callback)(struct zpm *, struct zpm_file *, void *), void *cbd); + int zpm_foreach_package(struct zpm *zpm, char *where, int (*callback)(void *cbdata, int ncols, char **vals, char **cols), void *data, char **errmsg); @@ -200,7 +233,7 @@ struct zpm *zpm_clearmem(struct zpm *zpm); struct zpm_note { int64_t id; - time_t ts; /* or timespec */ + char *ts; /* applications can parse it if they need to */ char *note; char *pkgid; char *path;