X-Git-Url: https://pd.if.org/git/?p=zpackage;a=blobdiff_plain;f=zpm.h;h=b090b3ad50ce5bed6fbd071926c238c744942975;hp=05b8fe9bb7de58140bcf5912f2a9279ec3ab88ba;hb=09c80a1f8918d888063f4d1a75921a99fe5f0b5c;hpb=343423780e984fd9188b55b688190decda19f94c diff --git a/zpm.h b/zpm.h index 05b8fe9..b090b3a 100644 --- a/zpm.h +++ b/zpm.h @@ -7,8 +7,11 @@ #include #include #include +#include +#include -#include +#include "sqlite3.h" +#include "lib/jsw/jsw_atree.h" #define ZPM_HASH_STRLEN 64 @@ -40,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]; @@ -53,7 +64,7 @@ struct zpm_tag { struct zpm_package { struct zpm *zpm; - struct jsw_hash *ht; + struct jsw_hash_t *ht; /* char pointers are just pointers into the hash table */ /* integers/times and such are passed through atoi */ @@ -76,17 +87,37 @@ struct zpm_package { }; int zpm_parse_package(char *pstr, char *name, char *ver, int *rel); -char *zpm_findpkg(struct zpm *zpm, char *pkgstr); +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 */ }; @@ -132,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); @@ -175,8 +207,18 @@ 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); int zpm_script_hash(struct zpm *zpm, char *pkgstr, char *phase, char *hash); +int zpm_script_set(struct zpm *zpm, char *pkgstr, char *phase, char *hash); +int zpm_foreach_script(struct zpm *zpm, char *pkgstr, char *stage, void *cbd, + int (*cb)(void *ud, const char *pkg, const char *stage, const char *hash)); + int zpm_package_hash(struct zpm *zpm, char *pkgid, char *hash); int zpm_package_sethash(struct zpm *zpm, char *pkgid, char *hash); @@ -191,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;