X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=lib%2Fscript_hash.c;h=60c87ede8eb4e1b23ab107f40f93de479d0f01bd;hb=0187a28d81a65b5b92c6c2dbaacce07d6277ba33;hp=c559e877dfbcaa3d72e3a6d0bedc9b983551764a;hpb=45a98e17c91c5617328859416de44fed8298f295;p=zpackage diff --git a/lib/script_hash.c b/lib/script_hash.c index c559e87..60c87ed 100644 --- a/lib/script_hash.c +++ b/lib/script_hash.c @@ -1,3 +1,5 @@ +#define _POSIX_C_SOURCE 200809L + #include #include #include @@ -7,15 +9,18 @@ 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 phase = %Q"; + char *template = "select hash from scripts_pkgid where pkgid = %Q and stage = %Q"; sqlite3_stmt *st; pkgid = zpm_findpkg(zpm, pkgstr); st = zpm_dbquery(zpm, template, pkgid, phase); + free(pkgid); if (!st) { + zpm->error = 1; + zpm->errmsg = strdup(sqlite3_errmsg(zpm->db)); return 0; } @@ -26,6 +31,7 @@ int zpm_script_hash(struct zpm *zpm, char *pkgstr, char *phase, char *hash) { hash[ZPM_HASH_STRLEN] = 0; break; default: zpm->error = 1; /* fall through */ + zpm->errmsg = strdup(sqlite3_errmsg(zpm->db)); case SQLITE_DONE: sqlite3_finalize(st); return 0; break; /* not found */