diff options
| author | Dana Jansens <danakj@orodu.net> | 2007-05-13 22:57:42 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2007-05-13 22:57:42 +0000 |
| commit | 5c96972bfffacb7dc24c96673f85e413e5c87b94 (patch) | |
| tree | 10dac41b7257f5769613d863695071583ce81cc7 /openbox/openbox.c | |
| parent | 6171dbf970c2c4f8d9736a8ae5184eb9ac38d7ce (diff) | |
save the config type in the session command line arguments
Diffstat (limited to 'openbox/openbox.c')
| -rw-r--r-- | openbox/openbox.c | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/openbox/openbox.c b/openbox/openbox.c index dfcda4b3..0006f438 100644 --- a/openbox/openbox.c +++ b/openbox/openbox.c @@ -89,6 +89,7 @@ gboolean ob_replace_wm = FALSE; gboolean ob_sm_use = TRUE; gchar *ob_sm_id = NULL; gchar *ob_sm_save_file = NULL; +gchar *ob_config_type = NULL; static ObState state; static gboolean xsync = FALSE; @@ -100,7 +101,6 @@ static KeyCode keys[OB_NUM_KEYS]; static gint exitcode = 0; static guint remote_control = 0; static gboolean being_replaced = FALSE; -static gchar *config_type = NULL; static void signal_handler(gint signal, gpointer data); static void remove_args(gint *argc, gchar **argv, gint index, gint num); @@ -237,15 +237,15 @@ gint main(gint argc, gchar **argv) config_startup(i); /* parse/load user options */ - if (parse_load_rc(config_type, &doc, &node)) { + if (parse_load_rc(ob_config_type, &doc, &node)) { parse_tree(i, doc, node->xmlChildrenNode); parse_close(doc); } else g_message(_("Unable to find a valid config file, using some simple defaults")); - if (config_type != NULL) + if (ob_config_type != NULL) PROP_SETS(RootWindow(ob_display, ob_screen), - ob_config, config_type); + ob_config, ob_config_type); /* we're done with parsing now, kill it */ parse_shutdown(i); @@ -409,8 +409,8 @@ gint main(gint argc, gchar **argv) } /* we also remove some environment variables, so put them back */ - if (config_type) - setenv("OPENBOX_CONFIG_NAMESPACE", config_type, 1); + if (ob_config_type) + setenv("OPENBOX_CONFIG_NAMESPACE", ob_config_type, 1); /* re-run me */ execvp(argv[0], argv); /* try how we were run */ @@ -420,7 +420,7 @@ gint main(gint argc, gchar **argv) /* free stuff passed in from the command line or environment */ g_free(ob_sm_save_file); g_free(ob_sm_id); - g_free(config_type); + g_free(ob_config_type); g_free(program_name); return exitcode; @@ -494,7 +494,7 @@ static void parse_env() unsetenv("DESKTOP_STARTUP_ID"); if (getenv("OPENBOX_CONFIG_NAMESPACE")) { - config_type = g_strdup(getenv("OPENBOX_CONFIG_NAMESPACE")); + ob_config_type = g_strdup(getenv("OPENBOX_CONFIG_NAMESPACE")); /* don't pass it on except if we restart */ unsetenv("OPENBOX_CONFIG_NAMESPACE"); } @@ -542,6 +542,18 @@ static void parse_args(gint *argc, gchar **argv) remote_control = 2; */ } + else if (!strcmp(argv[i], "--config-namespace")) { + if (i == *argc - 1) /* no args left */ + /* not translated cuz it's sekret */ + g_printerr("--config-namespace requires an argument\n"); + else { + ob_config_type = g_strdup(argv[i+1]); + remove_args(argc, argv, i, 2); + --i; /* this arg was removed so go back */ + ob_debug_type(OB_DEBUG_SM, "--config-namespace %s\n", + ob_sm_save_file); + } + } else if (!strcmp(argv[i], "--sm-save-file")) { if (i == *argc - 1) /* no args left */ /* not translated cuz it's sekret */ |
