diff imgpasterd-clean.c @ 0:f41e1b48510d

misc: initial import
author David Demelier <markand@malikania.fr>
date Wed, 25 Nov 2020 21:13:03 +0100
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/imgpasterd-clean.c	Wed Nov 25 21:13:03 2020 +0100
@@ -0,0 +1,64 @@
+/*
+ * pasterd-clean.c -- main pasterd-clean(8) file
+ *
+ * Copyright (c) 2020 David Demelier <markand@malikania.fr>
+ * 
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ * 
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <limits.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <stdnoreturn.h>
+#include <unistd.h>
+
+#include "database.h"
+#include "util.h"
+
+static noreturn void
+usage(void)
+{
+	fprintf(stderr, "usage: imgpasterd-clean [-d database-path]\n");
+	exit(1);
+}
+
+int
+main(int argc, char **argv)
+{
+	const char *value;
+	char path[PATH_MAX] = VARDIR "/imgpaster/imgpaster.db";
+	int ch;
+
+	/* Seek environment first. */
+	if ((value = getenv("IMGPASTERD_DATABASE_PATH")))
+		snprintf(path, sizeof (path), "%s", value);
+
+	while ((ch = getopt(argc, argv, "d:")) != -1) {
+		switch (ch) {
+		case 'd':
+			snprintf(path, sizeof (path), "%s", optarg);
+			break;
+		default:
+			usage();
+			break;
+		}
+	}
+
+	if (!path[0])
+		die("abort: no database specified");
+	if (!database_open(path))
+		die("abort: could not open database");
+
+	database_clear();
+	database_finish();
+}