summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@pengaru.com>2021-08-26 01:02:20 -0700
committerVito Caputo <vcaputo@pengaru.com>2021-08-26 01:02:20 -0700
commit97960b1f4c080d1d26d44061a76e62102b30bea4 (patch)
tree83bece94736e0488f206a89f18777fdf25a548f9
parent44753a9e39bb081a76c5b5cf53a25460d1f0e533 (diff)
vmon: implement --output-dir
Preparatory commit; saved PNGs need a place to go, and the user needs a way to control that. Defaults to CWD (".")
-rw-r--r--src/vmon.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/vmon.c b/src/vmon.c
index 8c7cb28..6880889 100644
--- a/src/vmon.c
+++ b/src/vmon.c
@@ -47,6 +47,7 @@ typedef struct vmon_t {
int done;
int linger;
time_t start_time;
+ char *output_dir;
} vmon_t;
@@ -115,6 +116,39 @@ static int parse_flag_int(char * const *flag, char * const *end, char * const *o
}
+/* parse string out of opt, stores parsed opt in newly allocated *res on success */
+static int parse_flag_str(char * const *flag, char * const *end, char * const *opt, int min_len, char **res)
+{
+ char *tmp;
+
+ assert(flag);
+ assert(end);
+ assert(opt);
+ assert(res);
+
+ if (flag == end || (!min_len || **opt == '\0')) {
+ VWM_ERROR("flag \"%s\" expects an argument", *flag);
+ return 0;
+ }
+
+ if (strlen(*opt) < min_len) {
+ VWM_ERROR("flag \"%s\" argument must be longer than %i, got \"%s\"", *flag, min_len, *opt);
+ return 0;
+ }
+
+ tmp = strdup(*opt);
+ if (!tmp) {
+ VWM_ERROR("unable to duplicate argument \"%s\"", *opt);
+ return 0;
+ }
+
+ free(*res);
+ *res = tmp;
+
+ return 1;
+}
+
+
/* set vmon->{width,height} to fullscreen dimensions */
static int set_fullscreen(vmon_t *vmon)
{
@@ -151,6 +185,7 @@ static void print_help(void)
" -x --width Window width\n"
" -y --height Window height\n"
" -z --hertz Sample rate in hertz\n"
+ " -o --output-dir Directory to store saved output to (\".\" if unspecified)\n"
"-----------------------------------------------------------------------------"
);
}
@@ -208,6 +243,11 @@ static int vmon_handle_argv(vmon_t *vmon, int argc, char * const argv[])
return 0;
last = ++argv;
+ } else if (is_flag(*argv, "-o", "--output-dir")) {
+ if (!parse_flag_str(argv, end, argv + 1, 1, &vmon->output_dir))
+ return 0;
+
+ last = ++argv;
} else if (is_flag(*argv, "-f", "--fullscreen")) {
if (!set_fullscreen(vmon)) {
VWM_ERROR("unable to set fullscreen dimensions");
@@ -307,6 +347,11 @@ static vmon_t * vmon_startup(int argc, char * const argv[])
vmon->start_time = time(NULL);
vmon->width = WIDTH_DEFAULT;
vmon->height = HEIGHT_DEFAULT;
+ vmon->output_dir = strdup(".");
+ if (!vmon->output_dir) {
+ VWM_ERROR("unable to alloc output dir");
+ goto _err_free;
+ }
vmon->xserver = vwm_xserver_open();
if (!vmon->xserver) {
© All Rights Reserved