diff options
author | 2wayne <[email protected]> | 2016-08-30 18:36:17 +0200 |
---|---|---|
committer | John Stebbins <[email protected]> | 2016-08-30 09:36:17 -0700 |
commit | aed230d055ce0e64dfc0a41e401a7a3e7e7fd7bb (patch) | |
tree | 2488cf5f261150b9b4c873f02346028f6464e521 /gtk/src | |
parent | 5cc544302e6596239ff01ef3b35502a013d67de8 (diff) |
add ghb_override_user_config_dir function (#304)
Allow selection of the config file directory from the command line
Diffstat (limited to 'gtk/src')
-rw-r--r-- | gtk/src/main.c | 8 | ||||
-rw-r--r-- | gtk/src/presets.c | 16 | ||||
-rw-r--r-- | gtk/src/presets.h | 1 |
3 files changed, 24 insertions, 1 deletions
diff --git a/gtk/src/main.c b/gtk/src/main.c index 6e12ed344..5b4eae3e4 100644 --- a/gtk/src/main.c +++ b/gtk/src/main.c @@ -661,6 +661,7 @@ typedef struct static gchar *dvd_device = NULL; static gchar *arg_preset = NULL; static gboolean ghb_debug = FALSE; +static gchar *arg_config_dir = NULL; #if defined(_WIN32) static gboolean win32_console = FALSE; #endif @@ -670,6 +671,7 @@ static GOptionEntry entries[] = { "device", 'd', 0, G_OPTION_ARG_FILENAME, &dvd_device, N_("The device or file to encode"), NULL }, { "preset", 'p', 0, G_OPTION_ARG_STRING, &arg_preset, N_("The preset values to use for encoding"), NULL }, { "debug", 'x', 0, G_OPTION_ARG_NONE, &ghb_debug, N_("Spam a lot"), NULL }, + { "config", 'o', 0, G_OPTION_ARG_STRING, &arg_config_dir, N_("The path to override user config dir"), NULL }, #if defined(_WIN32) { "console",'c', 0, G_OPTION_ARG_NONE, &win32_console, N_("Open a console for debug output"), NULL }, #endif @@ -911,6 +913,12 @@ main(int argc, char *argv[]) #endif ghb_udev_init(); + // Override user config dir + if (arg_config_dir != NULL) + { + ghb_override_user_config_dir(arg_config_dir); + } + ghb_write_pid_file(); ud = g_malloc0(sizeof(signal_user_data_t)); ud->debug = ghb_debug; diff --git a/gtk/src/presets.c b/gtk/src/presets.c index c0e238405..e6813e9a6 100644 --- a/gtk/src/presets.c +++ b/gtk/src/presets.c @@ -54,6 +54,7 @@ enum static GhbValue *prefsDict = NULL; static gboolean prefs_modified = FALSE; +static gchar *override_user_config_dir = NULL; static void store_prefs(void); static void store_presets(void); @@ -596,7 +597,14 @@ ghb_get_user_config_dir(gchar *subdir) const gchar *dir; gchar *config; - dir = g_get_user_config_dir(); + if (override_user_config_dir != NULL) + { + dir = override_user_config_dir; + } + else + { + dir = g_get_user_config_dir(); + } if (!g_file_test(dir, G_FILE_TEST_IS_DIR)) { dir = g_get_home_dir(); @@ -631,6 +639,12 @@ ghb_get_user_config_dir(gchar *subdir) return config; } +void +ghb_override_user_config_dir(char *dir) +{ + override_user_config_dir = dir; +} + static void write_config_file(const gchar *name, GhbValue *dict) { diff --git a/gtk/src/presets.h b/gtk/src/presets.h index 3587543fd..aa3eb2e1b 100644 --- a/gtk/src/presets.h +++ b/gtk/src/presets.h @@ -39,6 +39,7 @@ void ghb_save_queue(GhbValue *queue); GhbValue* ghb_load_old_queue(int pid); void ghb_remove_old_queue_file(int pid); gchar* ghb_get_user_config_dir(gchar *subdir); +void ghb_override_user_config_dir(char *dir); void ghb_settings_to_ui(signal_user_data_t *ud, GhbValue *dict); void ghb_clear_presets_selection(signal_user_data_t *ud); void ghb_select_preset(GtkBuilder *builder, const char *name); |