/*
- * browser-switchboard-config.c -- command-line configuration utility for
+ * browser-switchboard-config.c -- command-line configuration utility for
* Browser Switchboard
- *
+ *
* Copyright (C) 2009-2010 Steven Luo
- *
+ *
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
#include <stdlib.h>
+#include <stddef.h>
#include <string.h>
#include <stdio.h>
+#include <unistd.h>
#include <getopt.h>
#include "config.h"
+#include "browsers.h"
extern struct swb_config_option swb_config_options[];
static int get_config_value(char *name) {
struct swb_config cfg;
- int i;
- struct swb_config_option optinfo;
+ struct swb_config_option *optinfo;
+ ptrdiff_t i;
int retval = 1;
swb_config_init(&cfg);
if (!swb_config_load(&cfg))
return 1;
- for (i = 0; swb_config_options[i].name; ++i) {
- optinfo = swb_config_options[i];
- if (strcmp(name, optinfo.name))
+ for (optinfo = swb_config_options; optinfo->name; ++optinfo) {
+ if (strcmp(name, optinfo->name))
continue;
- switch (optinfo.type) {
+ i = optinfo - swb_config_options;
+ switch (optinfo->type) {
case SWB_CONFIG_OPT_STRING:
- printf("%s\n", *(char **)cfg.entries[i]);
+ if (*(char **)cfg.entries[i])
+ printf("%s\n", *(char **)cfg.entries[i]);
break;
case SWB_CONFIG_OPT_INT:
printf("%d\n", *(int *)cfg.entries[i]);
return retval;
}
-static int set_config_value(char *name, char *value) {
+static int get_default_browser(void) {
struct swb_config cfg;
int i;
- struct swb_config_option optinfo;
+
+ swb_config_init(&cfg);
+
+ if (!swb_config_load(&cfg))
+ return 1;
+
+ /* Check to see if the configured default browser is installed
+ If not, report the default default browser */
+ for (i = 0; browsers[i].config; ++i) {
+ if (strcmp(browsers[i].config, cfg.default_browser))
+ continue;
+
+ if (browsers[i].binary && access(browsers[i].binary, X_OK))
+ printf("%s\n", browsers[0].config);
+ else
+ printf("%s\n", browsers[i].config);
+
+ break;
+ }
+
+ if (!browsers[i].config)
+ /* Unknown browser configured as default, report the default
+ default browser */
+ printf("%s\n", browsers[0].config);
+
+ swb_config_free(&cfg);
+
+ return 0;
+}
+
+static int set_config_value(char *name, char *value) {
+ struct swb_config cfg;
+ struct swb_config_option *optinfo;
+ ptrdiff_t i;
int retval = 1;
swb_config_init(&cfg);
if (!swb_config_load(&cfg))
return 1;
- for (i = 0; swb_config_options[i].name; ++i) {
- optinfo = swb_config_options[i];
- if (strcmp(name, optinfo.name))
+ for (optinfo = swb_config_options; optinfo->name; ++optinfo) {
+ if (strcmp(name, optinfo->name))
continue;
- switch (optinfo.type) {
+ i = optinfo - swb_config_options;
+ switch (optinfo->type) {
case SWB_CONFIG_OPT_STRING:
/* Free any existing string */
- if (cfg.flags & optinfo.set_mask)
+ if (cfg.flags & optinfo->set_mask)
free(*(char **)cfg.entries[i]);
if (strlen(value) == 0) {
/* If the new value is empty, clear the config
setting */
*(char **)cfg.entries[i] = NULL;
- cfg.flags &= ~optinfo.set_mask;
+ cfg.flags &= ~optinfo->set_mask;
} else {
/* Make a copy of the string -- it's not safe
to free value, which comes from argv */
if (!(*(char **)cfg.entries[i] =
strdup(value)))
exit(1);
- cfg.flags |= optinfo.set_mask;
+ cfg.flags |= optinfo->set_mask;
}
break;
case SWB_CONFIG_OPT_INT:
if (strlen(value) == 0) {
/* If the new value is empty, clear the config
setting */
- cfg.flags &= ~optinfo.set_mask;
+ cfg.flags &= ~optinfo->set_mask;
} else {
*(int *)cfg.entries[i] = atoi(value);
- cfg.flags |= optinfo.set_mask;
+ cfg.flags |= optinfo->set_mask;
}
break;
}
int opt, done = 0;
int set = 0;
char *selected_opt = NULL;
-
+
while (!done && (opt = getopt(argc, argv, "hsbcmo:")) != -1) {
switch (opt) {
case 'h':
exit(1);
}
return set_config_value(selected_opt, argv[optind]);
- } else
+ } else if (!strcmp(selected_opt, "default_browser"))
+ /* Default browser value needs special handling */
+ return get_default_browser();
+ else
return get_config_value(selected_opt);
}