diff options
author | Max Kellermann <max@duempel.org> | 2012-01-31 22:12:14 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2012-02-02 18:06:33 +0100 |
commit | ef5cf40fa6d3e2f50ad916be8e5bd99affe7d2e3 (patch) | |
tree | bffd4ea35f30f96e8dc8d1ac74184bd4dab5d5d6 /src/directory.h | |
parent | 837bd79b20d4b9b8525a42999a9d1911f8980aa4 (diff) | |
download | mpd-ef5cf40fa6d3e2f50ad916be8e5bd99affe7d2e3.tar.gz mpd-ef5cf40fa6d3e2f50ad916be8e5bd99affe7d2e3.tar.xz mpd-ef5cf40fa6d3e2f50ad916be8e5bd99affe7d2e3.zip |
directory: require the caller to lock the db_mutex
Reduce the number of lock/unlock cycles, and make database handling
safer.
Diffstat (limited to 'src/directory.h')
-rw-r--r-- | src/directory.h | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/directory.h b/src/directory.h index 5460cb46a..769260436 100644 --- a/src/directory.h +++ b/src/directory.h @@ -118,6 +118,8 @@ directory_free(struct directory *directory); /** * Remove this #directory object from its parent and free it. This * must not be called with the root directory. + * + * Caller must lock the #db_mutex. */ void directory_delete(struct directory *directory); @@ -152,6 +154,9 @@ G_GNUC_PURE const char * directory_get_name(const struct directory *directory); +/** + * Caller must lock the #db_mutex. + */ G_GNUC_PURE struct directory * directory_get_child(const struct directory *directory, const char *name); @@ -159,6 +164,8 @@ directory_get_child(const struct directory *directory, const char *name); /** * Create a new #directory object as a child of the given one. * + * Caller must lock the #db_mutex. + * * @param parent the parent directory the new one will be added to * @param name_utf8 the UTF-8 encoded name of the new sub directory */ @@ -169,6 +176,8 @@ directory_new_child(struct directory *parent, const char *name_utf8); /** * Look up a sub directory, and create the object if it does not * exist. + * + * Caller must lock the #db_mutex. */ static inline struct directory * directory_make_child(struct directory *directory, const char *name_utf8) @@ -179,6 +188,9 @@ directory_make_child(struct directory *directory, const char *name_utf8) return child; } +/** + * Caller must lock the #db_mutex. + */ void directory_prune_empty(struct directory *directory); @@ -209,6 +221,8 @@ directory_remove_song(struct directory *directory, struct song *song); /** * Look up a song in this directory by its name. + * + * Caller must lock the #db_mutex. */ G_GNUC_PURE struct song * @@ -217,6 +231,8 @@ directory_get_song(const struct directory *directory, const char *name_utf8); /** * Looks up a song by its relative URI. * + * Caller must lock the #db_mutex. + * * @param directory the parent (or grandparent, ...) directory * @param uri the relative URI * @return the song, or NULL if none was found @@ -224,6 +240,11 @@ directory_get_song(const struct directory *directory, const char *name_utf8); struct song * directory_lookup_song(struct directory *directory, const char *uri); +/** + * Sort all directory entries recursively. + * + * Caller must lock the #db_mutex. + */ void directory_sort(struct directory *directory); |