aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/InotifyUpdate.cxx20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/InotifyUpdate.cxx b/src/InotifyUpdate.cxx
index 734f46a06..37b2107dd 100644
--- a/src/InotifyUpdate.cxx
+++ b/src/InotifyUpdate.cxx
@@ -55,6 +55,13 @@ struct WatchDirectory {
int descriptor;
GList *children;
+
+ WatchDirectory() = default;
+ WatchDirectory(WatchDirectory *_parent, const char *_name,
+ int _descriptor)
+ :parent(_parent), name(g_strdup(_name)),
+ descriptor(_descriptor),
+ children(nullptr) {}
};
static InotifySource *inotify_source;
@@ -112,7 +119,7 @@ remove_watch_directory(WatchDirectory *directory)
inotify_source->Remove(directory->descriptor);
g_free(directory->name);
- g_slice_free(WatchDirectory, directory);
+ delete directory;
}
static char *
@@ -169,7 +176,6 @@ recursive_watch_subdirectories(WatchDirectory *directory,
char *child_path_fs;
struct stat st;
int ret;
- WatchDirectory *child;
if (skip_path(ent->d_name))
continue;
@@ -198,18 +204,14 @@ recursive_watch_subdirectories(WatchDirectory *directory,
continue;
}
- child = tree_find_watch_directory(ret);
+ WatchDirectory *child = tree_find_watch_directory(ret);
if (child != NULL) {
/* already being watched */
g_free(child_path_fs);
continue;
}
- child = g_slice_new(WatchDirectory);
- child->parent = directory;
- child->name = g_strdup(ent->d_name);
- child->descriptor = ret;
- child->children = NULL;
+ child = new WatchDirectory(directory, ent->d_name, ret);
directory->children = g_list_prepend(directory->children,
child);
@@ -356,7 +358,7 @@ mpd_inotify_finish(void)
g_list_free(directory->children);
if (directory != &inotify_root)
- g_slice_free(WatchDirectory, directory);
+ delete directory;
}
inotify_directories.clear();