aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkremlin <ian@kremlin.cc>2014-06-26 14:30:17 +0800
committerkremlin <ian@kremlin.cc>2014-06-26 14:30:17 +0800
commit8636b04c9edbf044c195c516ba751ea76b90f57e (patch)
tree2a1f8655fcf5c0e4d906097583ff697fea77fca2
parentdc20e918f1f7baf2a349e0352bf6658e5daf6a23 (diff)
downloadsystembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar.gz
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar.bz2
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar.lz
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar.xz
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.tar.zst
systembsd-8636b04c9edbf044c195c516ba751ea76b90f57e.zip
clean up config.c
-rw-r--r--src/config.c130
1 files changed, 67 insertions, 63 deletions
diff --git a/src/config.c b/src/config.c
index 3731bcb..5cbecb1 100644
--- a/src/config.c
+++ b/src/config.c
@@ -49,14 +49,18 @@ gboolean set_option(gchar *key, gchar *value, gchar *group) {
/* initial load/check */
gboolean config_init() {
+ /* config is already set */
+ if(config)
+ return TRUE;
+
config = g_key_file_new();
const gchar *config_path;
GStatBuf *config_lstat;
- int config_lstat_ret;
+ int config_lstat_ret;
config_path = "/etc/systemd_compat.conf";
- config_lstat_ret = g_lstat(config_path, config_lstat);
+ config_lstat_ret = g_lstat(config_path, config_lstat);
/* does conf exist? */
if(config_lstat_ret) {
@@ -67,7 +71,7 @@ gboolean config_init() {
return FALSE;
}
- int config_descr;
+ int config_descr; /*TODO add to descr array for sigints, etc */
config_descr = g_open(config_path, O_CREAT, 644);
gchar *posix_hostname;
@@ -78,7 +82,7 @@ gboolean config_init() {
g_key_file_set_string(config, "hostnamed", "Hostname", posix_hostname);
g_key_file_set_string(config, "hostnamed", "PrettyHostname", "");
g_key_file_set_string(config, "hostnamed", "IconName", "Computer");
- g_key_file_set_string(config, "hostnamed", "ChassisType", "laptop"); //TODO set these correctly
+ g_key_file_set_string(config, "hostnamed", "ChassisType","laptop"); /*TODO set these correctly */
if(!g_key_file_save_to_file(config, config_path, NULL)) {
g_printf("failed to write config to %s!\n", config_path);
@@ -108,67 +112,67 @@ gboolean config_init() {
gboolean init_xml() {
- const gchar * const *data_dir_prefix;
- int xml_lstat_ret;
- GStatBuf *xml_lstat;
-
- data_dir_prefix = g_get_system_data_dirs();
- data_dir = g_strconcat(data_dir_prefix[0], "systemd_compat", NULL);
-
- xml_lstat_ret = g_lstat(data_dir, xml_lstat);
-
- /* does xml dir exist? */
- if(xml_lstat_ret) {
-
- /* if not, can we write to where it should be? */
- if(g_access(data_dir_prefix[0], W_OK)) {
- g_printf("no write permissions for %s! exiting...\n", data_dir_prefix[0]);
- return FALSE;
- }
-
- g_printf("creating xml data directory %s...\n", data_dir);
-
- if(g_mkdir(data_dir, 644) || g_access) {
- g_printf("failed to create dir %s...\n", data_dir);
- return FALSE;
- }
-
- /* read in xml files from conf/ */
- if(!read_xml_from_installconf()) {
- g_printf("failed to read xml configs in conf/...\n");
- return FALSE;
- }
-
- /* write our configs to system data dir */
- if(!populate_xml_data_dir()) {
- g_printf("failed to write xml configs to %s...\n", data_dir);
- return FALSE;
- }
-
- /* get descriptors from freshly-installed configs */
- if(!set_xml_descriptors()) {
- g_printf("failed to fopen xml configs...\n");
- return FALSE;
- }
-
- return TRUE;
-
- /* it does exist, read it */
- } else {
-
- if(!set_xml_descriptors()) {
- g_printf("failed to fopen xml configs...\n");
- return FALSE;
- }
-
- return TRUE;
- }
+ const gchar * const *data_dir_prefix;
+ int xml_lstat_ret;
+ GStatBuf *xml_lstat;
+
+ data_dir_prefix = g_get_system_data_dirs();
+ data_dir = g_strconcat(data_dir_prefix[0], "systemd_compat", NULL);
+
+ xml_lstat_ret = g_lstat(data_dir, xml_lstat);
+
+ /* does xml dir exist? */
+ if(xml_lstat_ret) {
+
+ /* if not, can we write to where it should be? */
+ if(g_access(data_dir_prefix[0], W_OK)) {
+ g_printf("no write permissions for %s! exiting...\n", data_dir_prefix[0]);
+ return FALSE;
+ }
+
+ g_printf("creating xml data directory %s...\n", data_dir);
+
+ if(g_mkdir(data_dir, 644) || g_access) {
+ g_printf("failed to create dir %s...\n", data_dir);
+ return FALSE;
+ }
+
+ /* read in xml files from conf/ */
+ if(!read_xml_from_installconf()) {
+ g_printf("failed to read xml configs in conf/...\n");
+ return FALSE;
+ }
+
+ /* write our configs to system data dir */
+ if(!populate_xml_data_dir()) {
+ g_printf("failed to write xml configs to %s...\n", data_dir);
+ return FALSE;
+ }
+
+ /* get descriptors from freshly-installed configs */
+ if(!set_xml_descriptors()) {
+ g_printf("failed to fopen xml configs...\n");
+ return FALSE;
+ }
+
+ return TRUE;
+
+ /* it does exist, read it */
+ } else {
+
+ if(!set_xml_descriptors()) {
+ g_printf("failed to fopen xml configs...\n");
+ return FALSE;
+ }
+
+ return TRUE;
+ }
}
void clean_config() {
- //TODO g_ptr_array all of this
- g_free(config);
- g_free(data_dir);
- g_close(config_descr, NULL);
+ //TODO g_ptr_array all of this
+ g_free(config);
+ g_free(data_dir);
+ g_close(config_descr, NULL);
}