From 3fb83977247641e73e4852fcf3dc0d52ecc27b84 Mon Sep 17 00:00:00 2001
From: taiyu <taiyu.len@gmail.com>
Date: Mon, 7 Sep 2015 06:52:27 -0700
Subject: free config stuff

---
 sway/config.c | 64 ++++++++++++++++++++++++++++++++++-------------------------
 1 file changed, 37 insertions(+), 27 deletions(-)

(limited to 'sway')

diff --git a/sway/config.c b/sway/config.c
index d2986a77..b64dd4b1 100644
--- a/sway/config.c
+++ b/sway/config.c
@@ -13,6 +13,39 @@
 
 struct sway_config *config = NULL;
 
+static void free_variable(struct sway_variable *var) {
+	free(var->name);
+	free(var->value);
+	free(var);
+}
+
+static void free_binding(struct sway_binding *bind) {
+	free_flat_list(bind->keys);
+	free(bind->command);
+	free(bind);
+}
+
+static void free_mode(struct sway_mode *mode) {
+	free(mode->name);
+	int i;
+	for (i = 0; i < mode->bindings->length; ++i) {
+		free_binding(mode->bindings->items[i]);
+	}
+	list_free(mode->bindings);
+	free(mode);
+}
+
+static void free_outut_config(struct output_config *oc) {
+	free(oc->name);
+	free(oc);
+}
+
+static void free_workspace_output(struct workspace_output *wo) {
+	free(wo->output);
+	free(wo->workspace);
+	free(wo);
+}
+
 static bool file_exists(const char *path) {
 	return access(path, R_OK) != -1;
 }
@@ -45,25 +78,10 @@ static void config_defaults(struct sway_config *config) {
 	config->gaps_outer = 0;
 }
 
-void free_mode(struct sway_mode *mode) {
-	free(mode->name);
-	int i;
-	for (i = 0; i < mode->bindings->length; ++i) {
-		struct sway_binding *bind = mode->bindings->items[i];
-		list_free(bind->keys);
-		free(bind->command);
-		free(bind);
-	}
-	list_free(mode->bindings);
-}
-
 void free_config(struct sway_config *config) {
 	int i;
 	for (i = 0; i < config->symbols->length; ++i) {
-		struct sway_variable *var = config->symbols->items[i];
-		free(var->name);
-		free(var->value);
-		free(var);
+		free_variable(config->symbols->items[i]);
 	}
 	list_free(config->symbols);
 
@@ -72,23 +90,15 @@ void free_config(struct sway_config *config) {
 	}
 	list_free(config->modes);
 
-	for (i = 0; i < config->cmd_queue->length; ++i) {
-		free(config->cmd_queue->items[i]);
-	}
-	list_free(config->cmd_queue);
+	free_flat_list(config->cmd_queue);
 
 	for (i = 0; i < config->workspace_outputs->length; ++i) {
-		struct workspace_output *wso = config->workspace_outputs->items[i];
-		free(wso->output);
-		free(wso->workspace);
-		free(wso);
+		free_workspace_output(config->workspace_outputs->items[i]);
 	}
 	list_free(config->workspace_outputs);
 
 	for (i = 0; i < config->output_configs->length; ++i) {
-		struct output_config *oc = config->output_configs->items[i];
-		free(oc->name);
-		free(oc);
+		free_outut_config(config->output_configs->items[i]);
 	}
 	list_free(config->output_configs);
 	free(config);
-- 
cgit v1.2.3