X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=lib%2Fscript_hash.c;h=ebca5508d4c65f80fc335c1d20b51ee8fa89173e;hb=f657628fd0709886002fdb0e2d8bde6873a34eb8;hp=60c87ede8eb4e1b23ab107f40f93de479d0f01bd;hpb=0187a28d81a65b5b92c6c2dbaacce07d6277ba33;p=zpackage diff --git a/lib/script_hash.c b/lib/script_hash.c index 60c87ed..ebca550 100644 --- a/lib/script_hash.c +++ b/lib/script_hash.c @@ -7,12 +7,35 @@ #include "sqlite3.h" #include "zpm.h" +int zpm_script_set(struct zpm *zpm, char *pkgstr, char *phase, char *hash) { + char package[64]; + char version[32]; + int release; + char *insert = "insert into scripts (package,version,release,stage,hash) values (%Q,%Q,%d,%Q,%Q) on conflict (package,version,release,stage) do update set hash = excluded.hash "; + char *delete = "delete from scripts where package = ? and version = ? and release = ? and stage = ?"; + + if (!zpm || !zpm->db || !phase) { + return 0; + } + + if (zpm_parse_package(pkgstr, package, version, &release)) { + if (hash) { + zpm_db_run(zpm, insert, package, version, release, phase, hash); + } else { + zpm_db_run(zpm, delete, package, version, release, phase); + + } + } + + return !zpm->error; +} + int zpm_script_hash(struct zpm *zpm, char *pkgstr, char *phase, char *hash) { char *pkgid = 0; char *template = "select hash from scripts_pkgid where pkgid = %Q and stage = %Q"; sqlite3_stmt *st; - pkgid = zpm_findpkg(zpm, pkgstr); + pkgid = zpm_findpkg(zpm, pkgstr, NULL); st = zpm_dbquery(zpm, template, pkgid, phase);