+#define _POSIX_C_SOURCE 200809L
+
#include <stdarg.h>
#include <string.h>
#include "zpm.h"
#define SQLERROR(x) fprintf(stderr, "%s %d: %s\n", __func__, __LINE__, (x))
-sqlite3_stmt *zpm_dbquery(struct zpm *zpm, char *query, ...) {
+
+sqlite3_stmt *zpm_dbqueryv(struct zpm *zpm, char *query, va_list args) {
sqlite3 *db;
char *sql;
- va_list args;
sqlite3_stmt *st;
int rv;
db = zpm->db;
- va_start(args, query);
sql = sqlite3_vmprintf(query, args);
- va_end(args);
if (!sql) {
zpm->error = 1;
return st;
}
+
+sqlite3_stmt *zpm_dbquery(struct zpm *zpm, char *query, ...) {
+ va_list args;
+ sqlite3_stmt *st;
+
+ if (!zpm || zpm->error) {
+ return 0;
+ }
+
+ if (!zpm->db) {
+ zpm->error = 1;
+ return 0;
+ }
+
+ va_start(args, query);
+ st = zpm_dbqueryv(zpm, query, args);
+ va_end(args);
+
+ return st;
+}
+
+char *zpm_db_string(struct zpm *zpm, char *query, ...) {
+ sqlite3_stmt *st;
+ va_list args;
+ int rv;
+ char *result = 0;
+
+ va_start(args, query);
+ st = zpm_dbqueryv(zpm, query, args);
+ va_end(args);
+
+ rv = sqlite3_step(st);
+
+ if (rv == SQLITE_ROW) {
+ result = (char *)sqlite3_column_text(st, 0);
+ if (result) {
+ result = strdup(result);
+ }
+ }
+
+ sqlite3_finalize(st);
+ return result;
+}
#include <stdio.h>
#include <time.h>
#include <limits.h>
+#include <stdarg.h>
#include <sqlite3.h>
int zpm_package_hash(struct zpm *zpm, char *pkgid, char *hash);
int zpm_package_sethash(struct zpm *zpm, char *pkgid, char *hash);
+sqlite3_stmt *zpm_dbqueryv(struct zpm *zpm, char *query, va_list args);
sqlite3_stmt *zpm_dbquery(struct zpm *zpm, char *query, ...);
+char *zpm_db_string(struct zpm *zpm, char *query, ...);
+
struct zpm *zpm_clearmem(struct zpm *zpm);
#endif