aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2016-04-29 14:08:43 -0400
committerDrew DeVault <sir@cmpwn.com>2016-04-29 14:08:43 -0400
commited8c67e2908f0370b8d665ebc09f75e784dafeac (patch)
tree1f10e0f9ed77b680ca1f5cf151df3e4b4c707817
parentfb41371444110949c54d5a60e917a0bb6fa9d366 (diff)
parente1fa51a152bc417e1085867dc6fc00e197f26a0f (diff)
downloadsway-ed8c67e2908f0370b8d665ebc09f75e784dafeac.tar.xz
Merge pull request #615 from neosilky/memleak
Cleaned up some un-free'd memory
-rw-r--r--common/stringop.c2
-rw-r--r--sway/config.c8
2 files changed, 7 insertions, 3 deletions
diff --git a/common/stringop.c b/common/stringop.c
index 61324458..432bee7f 100644
--- a/common/stringop.c
+++ b/common/stringop.c
@@ -144,7 +144,7 @@ char **split_args(const char *start, int *argc) {
}
void free_argv(int argc, char **argv) {
- while (--argc > 0) {
+ while (argc-- > 0) {
free(argv[argc]);
}
free(argv);
diff --git a/sway/config.c b/sway/config.c
index ebcee95b..f520cc88 100644
--- a/sway/config.c
+++ b/sway/config.c
@@ -268,6 +268,7 @@ static char *get_config_path(void) {
strcat(config_home, "/.config");
setenv("XDG_CONFIG_HOME", config_home, 1);
sway_log(L_DEBUG, "Set XDG_CONFIG_HOME to %s", config_home);
+ free(config_home);
}
wordexp_t p;
@@ -276,7 +277,8 @@ static char *get_config_path(void) {
int i;
for (i = 0; i < (int)(sizeof(config_paths) / sizeof(char *)); ++i) {
if (wordexp(config_paths[i], &p, 0) == 0) {
- path = p.we_wordv[0];
+ path = strdup(p.we_wordv[0]);
+ wordfree(&p);
if (file_exists(path)) {
return path;
}
@@ -355,6 +357,8 @@ bool load_main_config(const char *file, bool is_active) {
update_active_bar_modifiers();
}
+ free(path);
+
return success;
}
@@ -532,7 +536,7 @@ bool read_config(FILE *file, struct sway_config *config) {
default:;
}
free(line);
- free(res);
+ free_cmd_results(res);
}
return success;