Directory: rename struct directory to Directory

This commit is contained in:
Max Kellermann 2013-01-02 23:06:20 +01:00
parent 440ac51cf0
commit 3e8047e583
36 changed files with 180 additions and 184 deletions

View File

@ -109,7 +109,7 @@ db_is_simple(void)
return is_simple; return is_simple;
} }
struct directory * Directory *
db_get_root(void) db_get_root(void)
{ {
assert(db != NULL); assert(db != NULL);
@ -118,13 +118,13 @@ db_get_root(void)
return ((SimpleDatabase *)db)->GetRoot(); return ((SimpleDatabase *)db)->GetRoot();
} }
struct directory * Directory *
db_get_directory(const char *name) db_get_directory(const char *name)
{ {
if (db == NULL) if (db == NULL)
return NULL; return NULL;
struct directory *music_root = db_get_root(); Directory *music_root = db_get_root();
if (name == NULL) if (name == NULL)
return music_root; return music_root;

View File

@ -38,7 +38,7 @@ extern "C" {
#include <functional> #include <functional>
static bool static bool
PrintDirectory(struct client *client, const directory &directory) PrintDirectory(struct client *client, const Directory &directory)
{ {
if (!directory.IsRoot()) if (!directory.IsRoot())
client_printf(client, "directory: %s\n", directory.GetPath()); client_printf(client, "directory: %s\n", directory.GetPath());
@ -48,7 +48,7 @@ PrintDirectory(struct client *client, const directory &directory)
static void static void
print_playlist_in_directory(struct client *client, print_playlist_in_directory(struct client *client,
const directory &directory, const Directory &directory,
const char *name_utf8) const char *name_utf8)
{ {
if (directory.IsRoot()) if (directory.IsRoot())
@ -89,7 +89,7 @@ PrintSongFull(struct client *client, song &song)
static bool static bool
PrintPlaylistBrief(struct client *client, PrintPlaylistBrief(struct client *client,
const PlaylistInfo &playlist, const PlaylistInfo &playlist,
const directory &directory) const Directory &directory)
{ {
print_playlist_in_directory(client, directory, playlist.name.c_str()); print_playlist_in_directory(client, directory, playlist.name.c_str());
return true; return true;
@ -98,7 +98,7 @@ PrintPlaylistBrief(struct client *client,
static bool static bool
PrintPlaylistFull(struct client *client, PrintPlaylistFull(struct client *client,
const PlaylistInfo &playlist, const PlaylistInfo &playlist,
const directory &directory) const Directory &directory)
{ {
print_playlist_in_directory(client, directory, playlist.name.c_str()); print_playlist_in_directory(client, directory, playlist.name.c_str());

View File

@ -58,7 +58,7 @@ db_quark(void)
} }
void void
db_save_internal(FILE *fp, const struct directory *music_root) db_save_internal(FILE *fp, const Directory *music_root)
{ {
assert(music_root != NULL); assert(music_root != NULL);
@ -77,7 +77,7 @@ db_save_internal(FILE *fp, const struct directory *music_root)
} }
bool bool
db_load_internal(FILE *fp, struct directory *music_root, GError **error) db_load_internal(FILE *fp, Directory *music_root, GError **error)
{ {
GString *buffer = g_string_sized_new(1024); GString *buffer = g_string_sized_new(1024);
char *line; char *line;

View File

@ -24,12 +24,12 @@
#include <stdio.h> #include <stdio.h>
struct directory; struct Directory;
void void
db_save_internal(FILE *file, const struct directory *root); db_save_internal(FILE *file, const Directory *root);
bool bool
db_load_internal(FILE *file, struct directory *root, GError **error); db_load_internal(FILE *file, Directory *root, GError **error);
#endif #endif

View File

@ -28,7 +28,7 @@
#include <stdbool.h> #include <stdbool.h>
struct config_param; struct config_param;
struct directory; struct Directory;
struct db_selection; struct db_selection;
struct db_visitor; struct db_visitor;
@ -47,7 +47,7 @@ db_is_simple(void);
* May only be used if db_is_simple() returns true. * May only be used if db_is_simple() returns true.
*/ */
gcc_pure gcc_pure
struct directory * Directory *
db_get_root(void); db_get_root(void);
/** /**
@ -55,7 +55,7 @@ db_get_root(void);
*/ */
gcc_nonnull(1) gcc_nonnull(1)
gcc_pure gcc_pure
struct directory * Directory *
db_get_directory(const char *name); db_get_directory(const char *name);
/** /**

View File

@ -24,13 +24,13 @@
#include <functional> #include <functional>
struct directory; struct Directory;
struct song; struct song;
struct PlaylistInfo; struct PlaylistInfo;
typedef std::function<bool(const directory &, GError **)> VisitDirectory; typedef std::function<bool(const Directory &, GError **)> VisitDirectory;
typedef std::function<bool(struct song &, GError **)> VisitSong; typedef std::function<bool(struct song &, GError **)> VisitSong;
typedef std::function<bool(const PlaylistInfo &, const directory &, typedef std::function<bool(const PlaylistInfo &, const Directory &,
GError **)> VisitPlaylist; GError **)> VisitPlaylist;
typedef std::function<bool(const char *, GError **)> VisitString; typedef std::function<bool(const char *, GError **)> VisitString;

View File

@ -36,16 +36,16 @@ extern "C" {
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
static directory * static Directory *
directory_allocate(const char *path) directory_allocate(const char *path)
{ {
assert(path != NULL); assert(path != NULL);
const size_t path_size = strlen(path) + 1; const size_t path_size = strlen(path) + 1;
directory *directory = Directory *directory =
(struct directory *)g_malloc0(sizeof(*directory) (Directory *)g_malloc0(sizeof(*directory)
- sizeof(directory->path) - sizeof(directory->path)
+ path_size); + path_size);
INIT_LIST_HEAD(&directory->children); INIT_LIST_HEAD(&directory->children);
INIT_LIST_HEAD(&directory->songs); INIT_LIST_HEAD(&directory->songs);
INIT_LIST_HEAD(&directory->playlists); INIT_LIST_HEAD(&directory->playlists);
@ -55,13 +55,13 @@ directory_allocate(const char *path)
return directory; return directory;
} }
struct directory * Directory *
directory::NewGeneric(const char *path, struct directory *parent) Directory::NewGeneric(const char *path, Directory *parent)
{ {
assert(path != NULL); assert(path != NULL);
assert((*path == 0) == (parent == NULL)); assert((*path == 0) == (parent == NULL));
directory *directory = directory_allocate(path); Directory *directory = directory_allocate(path);
directory->parent = parent; directory->parent = parent;
@ -69,7 +69,7 @@ directory::NewGeneric(const char *path, struct directory *parent)
} }
void void
directory::Free() Directory::Free()
{ {
playlist_vector_deinit(&playlists); playlist_vector_deinit(&playlists);
@ -77,7 +77,7 @@ directory::Free()
directory_for_each_song_safe(song, ns, this) directory_for_each_song_safe(song, ns, this)
song_free(song); song_free(song);
struct directory *child, *n; Directory *child, *n;
directory_for_each_child_safe(child, n, this) directory_for_each_child_safe(child, n, this)
child->Free(); child->Free();
@ -85,7 +85,7 @@ directory::Free()
} }
void void
directory::Delete() Directory::Delete()
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(parent != nullptr); assert(parent != nullptr);
@ -95,7 +95,7 @@ directory::Delete()
} }
const char * const char *
directory::GetName() const Directory::GetName() const
{ {
assert(!IsRoot()); assert(!IsRoot());
assert(path != nullptr); assert(path != nullptr);
@ -108,8 +108,8 @@ directory::GetName() const
: path; : path;
} }
struct directory * Directory *
directory::CreateChild(const char *name_utf8) Directory::CreateChild(const char *name_utf8)
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(name_utf8 != NULL); assert(name_utf8 != NULL);
@ -126,19 +126,19 @@ directory::CreateChild(const char *name_utf8)
path_utf8 = allocated; path_utf8 = allocated;
} }
directory *child = NewGeneric(path_utf8, this); Directory *child = NewGeneric(path_utf8, this);
g_free(allocated); g_free(allocated);
list_add_tail(&child->siblings, &children); list_add_tail(&child->siblings, &children);
return child; return child;
} }
const directory * const Directory *
directory::FindChild(const char *name) const Directory::FindChild(const char *name) const
{ {
assert(holding_db_lock()); assert(holding_db_lock());
const struct directory *child; const Directory *child;
directory_for_each_child(child, this) directory_for_each_child(child, this)
if (strcmp(child->GetName(), name) == 0) if (strcmp(child->GetName(), name) == 0)
return child; return child;
@ -147,11 +147,11 @@ directory::FindChild(const char *name) const
} }
void void
directory::PruneEmpty() Directory::PruneEmpty()
{ {
assert(holding_db_lock()); assert(holding_db_lock());
struct directory *child, *n; Directory *child, *n;
directory_for_each_child_safe(child, n, this) { directory_for_each_child_safe(child, n, this) {
child->PruneEmpty(); child->PruneEmpty();
@ -160,8 +160,8 @@ directory::PruneEmpty()
} }
} }
struct directory * Directory *
directory::LookupDirectory(const char *uri) Directory::LookupDirectory(const char *uri)
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(uri != NULL); assert(uri != NULL);
@ -171,7 +171,7 @@ directory::LookupDirectory(const char *uri)
char *duplicated = g_strdup(uri), *name = duplicated; char *duplicated = g_strdup(uri), *name = duplicated;
struct directory *d = this; Directory *d = this;
while (1) { while (1) {
char *slash = strchr(name, '/'); char *slash = strchr(name, '/');
if (slash == name) { if (slash == name) {
@ -195,7 +195,7 @@ directory::LookupDirectory(const char *uri)
} }
void void
directory::AddSong(struct song *song) Directory::AddSong(struct song *song)
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(song != NULL); assert(song != NULL);
@ -205,7 +205,7 @@ directory::AddSong(struct song *song)
} }
void void
directory::RemoveSong(struct song *song) Directory::RemoveSong(struct song *song)
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(song != NULL); assert(song != NULL);
@ -215,7 +215,7 @@ directory::RemoveSong(struct song *song)
} }
const song * const song *
directory::FindSong(const char *name_utf8) const Directory::FindSong(const char *name_utf8) const
{ {
assert(holding_db_lock()); assert(holding_db_lock());
assert(name_utf8 != NULL); assert(name_utf8 != NULL);
@ -232,7 +232,7 @@ directory::FindSong(const char *name_utf8) const
} }
struct song * struct song *
directory::LookupSong(const char *uri) Directory::LookupSong(const char *uri)
{ {
char *duplicated, *base; char *duplicated, *base;
@ -242,7 +242,7 @@ directory::LookupSong(const char *uri)
duplicated = g_strdup(uri); duplicated = g_strdup(uri);
base = strrchr(duplicated, '/'); base = strrchr(duplicated, '/');
struct directory *d = this; Directory *d = this;
if (base != NULL) { if (base != NULL) {
*base++ = 0; *base++ = 0;
d = d->LookupDirectory(duplicated); d = d->LookupDirectory(duplicated);
@ -265,26 +265,26 @@ static int
directory_cmp(G_GNUC_UNUSED void *priv, directory_cmp(G_GNUC_UNUSED void *priv,
struct list_head *_a, struct list_head *_b) struct list_head *_a, struct list_head *_b)
{ {
const struct directory *a = (const struct directory *)_a; const Directory *a = (const Directory *)_a;
const struct directory *b = (const struct directory *)_b; const Directory *b = (const Directory *)_b;
return g_utf8_collate(a->path, b->path); return g_utf8_collate(a->path, b->path);
} }
void void
directory::Sort() Directory::Sort()
{ {
assert(holding_db_lock()); assert(holding_db_lock());
list_sort(NULL, &children, directory_cmp); list_sort(NULL, &children, directory_cmp);
song_list_sort(&songs); song_list_sort(&songs);
struct directory *child; Directory *child;
directory_for_each_child(child, this) directory_for_each_child(child, this)
child->Sort(); child->Sort();
} }
bool bool
directory::Walk(bool recursive, const SongFilter *filter, Directory::Walk(bool recursive, const SongFilter *filter,
VisitDirectory visit_directory, VisitSong visit_song, VisitDirectory visit_directory, VisitSong visit_song,
VisitPlaylist visit_playlist, VisitPlaylist visit_playlist,
GError **error_r) const GError **error_r) const
@ -306,7 +306,7 @@ directory::Walk(bool recursive, const SongFilter *filter,
return false; return false;
} }
struct directory *child; Directory *child;
directory_for_each_child(child, this) { directory_for_each_child(child, this) {
if (visit_directory && if (visit_directory &&
!visit_directory(*child, error_r)) !visit_directory(*child, error_r))

View File

@ -54,7 +54,7 @@ struct song;
struct db_visitor; struct db_visitor;
class SongFilter; class SongFilter;
struct directory { struct Directory {
/** /**
* Pointers to the siblings of this directory within the * Pointers to the siblings of this directory within the
* parent directory. It is unused (undefined) in the root * parent directory. It is unused (undefined) in the root
@ -83,7 +83,7 @@ struct directory {
struct list_head playlists; struct list_head playlists;
struct directory *parent; Directory *parent;
time_t mtime; time_t mtime;
ino_t inode; ino_t inode;
dev_t device; dev_t device;
@ -91,53 +91,53 @@ struct directory {
char path[sizeof(long)]; char path[sizeof(long)];
/** /**
* Generic constructor for #directory object. * Generic constructor for #Directory object.
*/ */
gcc_malloc gcc_malloc
static directory *NewGeneric(const char *path_utf8, directory *parent); static Directory *NewGeneric(const char *path_utf8, Directory *parent);
/** /**
* Create a new root #directory object. * Create a new root #Directory object.
*/ */
gcc_malloc gcc_malloc
static directory *NewRoot() { static Directory *NewRoot() {
return NewGeneric("", nullptr); return NewGeneric("", nullptr);
} }
/** /**
* Free this #directory object (and the whole object tree within it), * Free this #Directory object (and the whole object tree within it),
* assuming it was already removed from the parent. * assuming it was already removed from the parent.
*/ */
void Free(); void Free();
/** /**
* Remove this #directory object from its parent and free it. This * Remove this #Directory object from its parent and free it. This
* must not be called with the root directory. * must not be called with the root Directory.
* *
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
void Delete(); void Delete();
/** /**
* Create a new #directory object as a child of the given one. * Create a new #Directory object as a child of the given one.
* *
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
* *
* @param name_utf8 the UTF-8 encoded name of the new sub directory * @param name_utf8 the UTF-8 encoded name of the new sub directory
*/ */
gcc_malloc gcc_malloc
directory *CreateChild(const char *name_utf8); Directory *CreateChild(const char *name_utf8);
/** /**
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
gcc_pure gcc_pure
const directory *FindChild(const char *name) const; const Directory *FindChild(const char *name) const;
gcc_pure gcc_pure
directory *FindChild(const char *name) { Directory *FindChild(const char *name) {
const directory *cthis = this; const Directory *cthis = this;
return const_cast<directory *>(cthis->FindChild(name)); return const_cast<Directory *>(cthis->FindChild(name));
} }
/** /**
@ -146,8 +146,8 @@ struct directory {
* *
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
struct directory *MakeChild(const char *name_utf8) { Directory *MakeChild(const char *name_utf8) {
struct directory *child = FindChild(name_utf8); Directory *child = FindChild(name_utf8);
if (child == nullptr) if (child == nullptr)
child = CreateChild(name_utf8); child = CreateChild(name_utf8);
return child; return child;
@ -157,10 +157,10 @@ struct directory {
* Looks up a directory by its relative URI. * Looks up a directory by its relative URI.
* *
* @param uri the relative URI * @param uri the relative URI
* @return the directory, or NULL if none was found * @return the Directory, or NULL if none was found
*/ */
gcc_pure gcc_pure
directory *LookupDirectory(const char *uri); Directory *LookupDirectory(const char *uri);
gcc_pure gcc_pure
bool IsEmpty() const { bool IsEmpty() const {
@ -198,7 +198,7 @@ struct directory {
gcc_pure gcc_pure
song *FindSong(const char *name_utf8) { song *FindSong(const char *name_utf8) {
const directory *cthis = this; const Directory *cthis = this;
return const_cast<song *>(cthis->FindSong(name_utf8)); return const_cast<song *>(cthis->FindSong(name_utf8));
} }

View File

@ -46,7 +46,7 @@ directory_quark(void)
} }
void void
directory_save(FILE *fp, const struct directory *directory) directory_save(FILE *fp, const Directory *directory)
{ {
if (!directory->IsRoot()) { if (!directory->IsRoot()) {
fprintf(fp, DIRECTORY_MTIME "%lu\n", fprintf(fp, DIRECTORY_MTIME "%lu\n",
@ -55,7 +55,7 @@ directory_save(FILE *fp, const struct directory *directory)
fprintf(fp, "%s%s\n", DIRECTORY_BEGIN, directory->GetPath()); fprintf(fp, "%s%s\n", DIRECTORY_BEGIN, directory->GetPath());
} }
struct directory *cur; Directory *cur;
directory_for_each_child(cur, directory) { directory_for_each_child(cur, directory) {
char *base = g_path_get_basename(cur->path); char *base = g_path_get_basename(cur->path);
@ -78,8 +78,8 @@ directory_save(FILE *fp, const struct directory *directory)
fprintf(fp, DIRECTORY_END "%s\n", directory->GetPath()); fprintf(fp, DIRECTORY_END "%s\n", directory->GetPath());
} }
static struct directory * static Directory *
directory_load_subdir(FILE *fp, struct directory *parent, const char *name, directory_load_subdir(FILE *fp, Directory *parent, const char *name,
GString *buffer, GError **error_r) GString *buffer, GError **error_r)
{ {
const char *line; const char *line;
@ -91,7 +91,7 @@ directory_load_subdir(FILE *fp, struct directory *parent, const char *name,
return NULL; return NULL;
} }
struct directory *directory = parent->CreateChild(name); Directory *directory = parent->CreateChild(name);
line = read_text_line(fp, buffer); line = read_text_line(fp, buffer);
if (line == NULL) { if (line == NULL) {
@ -132,7 +132,7 @@ directory_load_subdir(FILE *fp, struct directory *parent, const char *name,
} }
bool bool
directory_load(FILE *fp, struct directory *directory, directory_load(FILE *fp, Directory *directory,
GString *buffer, GError **error) GString *buffer, GError **error)
{ {
const char *line; const char *line;
@ -140,7 +140,7 @@ directory_load(FILE *fp, struct directory *directory,
while ((line = read_text_line(fp, buffer)) != NULL && while ((line = read_text_line(fp, buffer)) != NULL &&
!g_str_has_prefix(line, DIRECTORY_END)) { !g_str_has_prefix(line, DIRECTORY_END)) {
if (g_str_has_prefix(line, DIRECTORY_DIR)) { if (g_str_has_prefix(line, DIRECTORY_DIR)) {
struct directory *subdir = Directory *subdir =
directory_load_subdir(fp, directory, directory_load_subdir(fp, directory,
line + sizeof(DIRECTORY_DIR) - 1, line + sizeof(DIRECTORY_DIR) - 1,
buffer, error); buffer, error);

View File

@ -24,13 +24,13 @@
#include <stdio.h> #include <stdio.h>
struct directory; struct Directory;
void void
directory_save(FILE *fp, const struct directory *directory); directory_save(FILE *fp, const Directory *directory);
bool bool
directory_load(FILE *fp, struct directory *directory, directory_load(FILE *fp, Directory *directory,
GString *buffer, GError **error); GString *buffer, GError **error);
#endif #endif

View File

@ -181,7 +181,7 @@ map_uri_fs(const char *uri)
} }
char * char *
map_directory_fs(const struct directory *directory) map_directory_fs(const Directory *directory)
{ {
assert(music_dir_utf8 != NULL); assert(music_dir_utf8 != NULL);
assert(music_dir_fs != NULL); assert(music_dir_fs != NULL);
@ -193,7 +193,7 @@ map_directory_fs(const struct directory *directory)
} }
char * char *
map_directory_child_fs(const struct directory *directory, const char *name) map_directory_child_fs(const Directory *directory, const char *name)
{ {
assert(music_dir_utf8 != NULL); assert(music_dir_utf8 != NULL);
assert(music_dir_fs != NULL); assert(music_dir_fs != NULL);

View File

@ -29,7 +29,7 @@
#define PLAYLIST_FILE_SUFFIX ".m3u" #define PLAYLIST_FILE_SUFFIX ".m3u"
struct directory; struct Directory;
struct song; struct song;
void mapper_init(const char *_music_dir, const char *_playlist_dir); void mapper_init(const char *_music_dir, const char *_playlist_dir);
@ -87,7 +87,7 @@ map_uri_fs(const char *uri);
*/ */
gcc_malloc gcc_malloc
char * char *
map_directory_fs(const struct directory *directory); map_directory_fs(const Directory *directory);
/** /**
* Determines the file system path of a directory's child (may be a * Determines the file system path of a directory's child (may be a
@ -99,7 +99,7 @@ map_directory_fs(const struct directory *directory);
*/ */
gcc_malloc gcc_malloc
char * char *
map_directory_child_fs(const struct directory *directory, const char *name); map_directory_child_fs(const Directory *directory, const char *name);
/** /**
* Determines the file system path of a song. This must not be a * Determines the file system path of a song. This must not be a

View File

@ -29,10 +29,10 @@ extern "C" {
#include <assert.h> #include <assert.h>
struct directory detached_root; Directory detached_root;
static struct song * static struct song *
song_alloc(const char *uri, struct directory *parent) song_alloc(const char *uri, Directory *parent)
{ {
size_t uri_length; size_t uri_length;
@ -59,7 +59,7 @@ song_remote_new(const char *uri)
} }
struct song * struct song *
song_file_new(const char *path, struct directory *parent) song_file_new(const char *path, Directory *parent)
{ {
assert((parent == nullptr) == (*path == '/')); assert((parent == nullptr) == (*path == '/'));
@ -117,14 +117,14 @@ song_free(struct song *song)
gcc_pure gcc_pure
static inline bool static inline bool
directory_equals(const struct directory &a, const struct directory &b) directory_equals(const Directory &a, const Directory &b)
{ {
return strcmp(a.path, b.path) == 0; return strcmp(a.path, b.path) == 0;
} }
gcc_pure gcc_pure
static inline bool static inline bool
directory_is_same(const struct directory *a, const struct directory *b) directory_is_same(const Directory *a, const Directory *b)
{ {
return a == b || return a == b ||
(a != nullptr && b != nullptr && (a != nullptr && b != nullptr &&

View File

@ -63,7 +63,7 @@ song_save(FILE *fp, const struct song *song)
} }
struct song * struct song *
song_load(FILE *fp, struct directory *parent, const char *uri, song_load(FILE *fp, Directory *parent, const char *uri,
GString *buffer, GError **error_r) GString *buffer, GError **error_r)
{ {
struct song *song = parent != NULL struct song *song = parent != NULL

View File

@ -27,7 +27,7 @@
#define SONG_BEGIN "song_begin: " #define SONG_BEGIN "song_begin: "
struct song; struct song;
struct directory; struct Directory;
void void
song_save(FILE *fp, const struct song *song); song_save(FILE *fp, const struct song *song);
@ -41,7 +41,7 @@ song_save(FILE *fp, const struct song *song);
* @return true on success, false on error * @return true on success, false on error
*/ */
struct song * struct song *
song_load(FILE *fp, struct directory *parent, const char *uri, song_load(FILE *fp, Directory *parent, const char *uri,
GString *buffer, GError **error_r); GString *buffer, GError **error_r);
#endif #endif

View File

@ -109,7 +109,7 @@ sticker_song_get(const struct song *song)
} }
struct sticker_song_find_data { struct sticker_song_find_data {
struct directory *directory; Directory *directory;
const char *base_uri; const char *base_uri;
size_t base_uri_length; size_t base_uri_length;
@ -134,7 +134,7 @@ sticker_song_find_cb(const char *uri, const char *value, gpointer user_data)
} }
bool bool
sticker_song_find(struct directory *directory, const char *name, sticker_song_find(Directory *directory, const char *name,
void (*func)(struct song *song, const char *value, void (*func)(struct song *song, const char *value,
gpointer user_data), gpointer user_data),
gpointer user_data) gpointer user_data)

View File

@ -23,7 +23,7 @@
#include <glib.h> #include <glib.h>
struct song; struct song;
struct directory; struct Directory;
struct sticker; struct sticker;
/** /**
@ -75,7 +75,7 @@ sticker_song_get(const struct song *song);
* failure * failure
*/ */
bool bool
sticker_song_find(struct directory *directory, const char *name, sticker_song_find(Directory *directory, const char *name,
void (*func)(struct song *song, const char *value, void (*func)(struct song *song, const char *value,
gpointer user_data), gpointer user_data),
gpointer user_data); gpointer user_data);

View File

@ -45,7 +45,7 @@ extern "C" {
#include <stdio.h> #include <stdio.h>
struct song * struct song *
song_file_load(const char *path, struct directory *parent) song_file_load(const char *path, Directory *parent)
{ {
struct song *song; struct song *song;
bool ret; bool ret;

View File

@ -127,7 +127,6 @@ handle_sticker_song(struct client *client, int argc, char *argv[])
/* find song dir key */ /* find song dir key */
} else if (argc == 5 && strcmp(argv[1], "find") == 0) { } else if (argc == 5 && strcmp(argv[1], "find") == 0) {
/* "sticker find song a/directory name" */ /* "sticker find song a/directory name" */
struct directory *directory;
bool success; bool success;
struct sticker_song_find_data data = { struct sticker_song_find_data data = {
client, client,
@ -135,7 +134,7 @@ handle_sticker_song(struct client *client, int argc, char *argv[])
}; };
db_lock(); db_lock();
directory = db_get_directory(argv[3]); Directory *directory = db_get_directory(argv[3]);
if (directory == NULL) { if (directory == NULL) {
db_unlock(); db_unlock();
command_error(client, ACK_ERROR_NO_EXIST, command_error(client, ACK_ERROR_NO_EXIST,

View File

@ -35,14 +35,14 @@ extern "C" {
#include <string.h> #include <string.h>
static void static void
update_archive_tree(struct directory *directory, char *name) update_archive_tree(Directory *directory, char *name)
{ {
char *tmp = strchr(name, '/'); char *tmp = strchr(name, '/');
if (tmp) { if (tmp) {
*tmp = 0; *tmp = 0;
//add dir is not there already //add dir is not there already
db_lock(); db_lock();
struct directory *subdir = Directory *subdir =
directory->MakeChild(name); directory->MakeChild(name);
subdir->device = DEVICE_INARCHIVE; subdir->device = DEVICE_INARCHIVE;
db_unlock(); db_unlock();
@ -82,12 +82,12 @@ update_archive_tree(struct directory *directory, char *name)
* @param plugin the archive plugin which fits this archive type * @param plugin the archive plugin which fits this archive type
*/ */
static void static void
update_archive_file2(struct directory *parent, const char *name, update_archive_file2(Directory *parent, const char *name,
const struct stat *st, const struct stat *st,
const struct archive_plugin *plugin) const struct archive_plugin *plugin)
{ {
db_lock(); db_lock();
directory *directory = parent->FindChild(name); Directory *directory = parent->FindChild(name);
db_unlock(); db_unlock();
if (directory != NULL && directory->mtime == st->st_mtime && if (directory != NULL && directory->mtime == st->st_mtime &&
@ -136,7 +136,7 @@ update_archive_file2(struct directory *parent, const char *name,
} }
bool bool
update_archive_file(struct directory *directory, update_archive_file(Directory *directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const struct stat *st) const struct stat *st)
{ {

View File

@ -25,13 +25,13 @@
#include <sys/stat.h> #include <sys/stat.h>
struct directory; struct Directory;
struct archive_plugin; struct archive_plugin;
#ifdef ENABLE_ARCHIVE #ifdef ENABLE_ARCHIVE
bool bool
update_archive_file(struct directory *directory, update_archive_file(Directory *directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const struct stat *st); const struct stat *st);
@ -40,7 +40,7 @@ update_archive_file(struct directory *directory,
#include <glib.h> #include <glib.h>
static inline bool static inline bool
update_archive_file(gcc_unused struct directory *directory, update_archive_file(gcc_unused Directory *directory,
gcc_unused const char *name, gcc_unused const char *name,
gcc_unused const char *suffix, gcc_unused const char *suffix,
gcc_unused const struct stat *st) gcc_unused const struct stat *st)

View File

@ -42,11 +42,11 @@ extern "C" {
* *
* The caller must lock the database. * The caller must lock the database.
*/ */
static struct directory * static Directory *
make_directory_if_modified(struct directory *parent, const char *name, make_directory_if_modified(Directory *parent, const char *name,
const struct stat *st) const struct stat *st)
{ {
directory *directory = parent->FindChild(name); Directory *directory = parent->FindChild(name);
// directory exists already // directory exists already
if (directory != NULL) { if (directory != NULL) {
@ -66,7 +66,7 @@ make_directory_if_modified(struct directory *parent, const char *name,
} }
bool bool
update_container_file(struct directory *directory, update_container_file(Directory *directory,
const char *name, const char *name,
const struct stat *st, const struct stat *st,
const struct decoder_plugin *plugin) const struct decoder_plugin *plugin)
@ -75,8 +75,7 @@ update_container_file(struct directory *directory,
return false; return false;
db_lock(); db_lock();
struct directory *contdir = Directory *contdir = make_directory_if_modified(directory, name, st);
make_directory_if_modified(directory, name, st);
if (contdir == NULL) { if (contdir == NULL) {
/* not modified */ /* not modified */
db_unlock(); db_unlock();

View File

@ -24,11 +24,11 @@
#include <sys/stat.h> #include <sys/stat.h>
struct directory; struct Directory;
struct decoder_plugin; struct decoder_plugin;
bool bool
update_container_file(struct directory *directory, update_container_file(Directory *directory,
const char *name, const char *name,
const struct stat *st, const struct stat *st,
const struct decoder_plugin *plugin); const struct decoder_plugin *plugin);

View File

@ -29,7 +29,7 @@
#include <assert.h> #include <assert.h>
void void
delete_song(struct directory *dir, struct song *del) delete_song(Directory *dir, struct song *del)
{ {
assert(del->parent == dir); assert(del->parent == dir);
@ -54,9 +54,9 @@ delete_song(struct directory *dir, struct song *del)
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
static void static void
clear_directory(struct directory *directory) clear_directory(Directory *directory)
{ {
struct directory *child, *n; Directory *child, *n;
directory_for_each_child_safe(child, n, directory) directory_for_each_child_safe(child, n, directory)
delete_directory(child); delete_directory(child);
@ -68,7 +68,7 @@ clear_directory(struct directory *directory)
} }
void void
delete_directory(struct directory *directory) delete_directory(Directory *directory)
{ {
assert(directory->parent != NULL); assert(directory->parent != NULL);
@ -78,12 +78,12 @@ delete_directory(struct directory *directory)
} }
bool bool
delete_name_in(struct directory *parent, const char *name) delete_name_in(Directory *parent, const char *name)
{ {
bool modified = false; bool modified = false;
db_lock(); db_lock();
directory *directory = parent->FindChild(name); Directory *directory = parent->FindChild(name);
if (directory != NULL) { if (directory != NULL) {
delete_directory(directory); delete_directory(directory);

View File

@ -22,14 +22,14 @@
#include "check.h" #include "check.h"
struct directory; struct Directory;
struct song; struct song;
/** /**
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
void void
delete_song(struct directory *parent, struct song *song); delete_song(Directory *parent, struct song *song);
/** /**
* Recursively free a directory and all its contents. * Recursively free a directory and all its contents.
@ -37,7 +37,7 @@ delete_song(struct directory *parent, struct song *song);
* Caller must lock the #db_mutex. * Caller must lock the #db_mutex.
*/ */
void void
delete_directory(struct directory *directory); delete_directory(Directory *directory);
/** /**
* Caller must NOT lock the #db_mutex. * Caller must NOT lock the #db_mutex.
@ -45,6 +45,6 @@ delete_directory(struct directory *directory);
* @return true if the database was modified * @return true if the database was modified
*/ */
bool bool
delete_name_in(struct directory *parent, const char *name); delete_name_in(Directory *parent, const char *name);
#endif #endif

View File

@ -29,7 +29,7 @@
#include <unistd.h> #include <unistd.h>
int int
stat_directory(const struct directory *directory, struct stat *st) stat_directory(const Directory *directory, struct stat *st)
{ {
char *path_fs = map_directory_fs(directory); char *path_fs = map_directory_fs(directory);
if (path_fs == NULL) if (path_fs == NULL)
@ -44,7 +44,7 @@ stat_directory(const struct directory *directory, struct stat *st)
} }
int int
stat_directory_child(const struct directory *parent, const char *name, stat_directory_child(const Directory *parent, const char *name,
struct stat *st) struct stat *st)
{ {
char *path_fs = map_directory_child_fs(parent, name); char *path_fs = map_directory_child_fs(parent, name);
@ -60,7 +60,7 @@ stat_directory_child(const struct directory *parent, const char *name,
} }
bool bool
directory_exists(const struct directory *directory) directory_exists(const Directory *directory)
{ {
char *path_fs = map_directory_fs(directory); char *path_fs = map_directory_fs(directory);
if (path_fs == NULL) if (path_fs == NULL)
@ -79,7 +79,7 @@ directory_exists(const struct directory *directory)
} }
bool bool
directory_child_is_regular(const struct directory *directory, directory_child_is_regular(const Directory *directory,
const char *name_utf8) const char *name_utf8)
{ {
char *path_fs = map_directory_child_fs(directory, name_utf8); char *path_fs = map_directory_child_fs(directory, name_utf8);
@ -94,7 +94,7 @@ directory_child_is_regular(const struct directory *directory,
} }
bool bool
directory_child_access(const struct directory *directory, directory_child_access(const Directory *directory,
const char *name, int mode) const char *name, int mode)
{ {
#ifdef WIN32 #ifdef WIN32

View File

@ -24,27 +24,27 @@
#include <sys/stat.h> #include <sys/stat.h>
struct directory; struct Directory;
int int
stat_directory(const struct directory *directory, struct stat *st); stat_directory(const Directory *directory, struct stat *st);
int int
stat_directory_child(const struct directory *parent, const char *name, stat_directory_child(const Directory *parent, const char *name,
struct stat *st); struct stat *st);
bool bool
directory_exists(const struct directory *directory); directory_exists(const Directory *directory);
bool bool
directory_child_is_regular(const struct directory *directory, directory_child_is_regular(const Directory *directory,
const char *name_utf8); const char *name_utf8);
/** /**
* Checks if the given permissions on the mapped file are given. * Checks if the given permissions on the mapped file are given.
*/ */
bool bool
directory_child_access(const struct directory *directory, directory_child_access(const Directory *directory,
const char *name, int mode); const char *name, int mode);
#endif #endif

View File

@ -37,7 +37,7 @@ extern "C" {
#include <unistd.h> #include <unistd.h>
static void static void
update_song_file2(struct directory *directory, update_song_file2(Directory *directory,
const char *name, const struct stat *st, const char *name, const struct stat *st,
const struct decoder_plugin *plugin) const struct decoder_plugin *plugin)
{ {
@ -101,7 +101,7 @@ update_song_file2(struct directory *directory,
} }
bool bool
update_song_file(struct directory *directory, update_song_file(Directory *directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const struct stat *st) const struct stat *st)
{ {

View File

@ -24,10 +24,10 @@
#include <sys/stat.h> #include <sys/stat.h>
struct directory; struct Directory;
bool bool
update_song_file(struct directory *directory, update_song_file(Directory *directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const struct stat *st); const struct stat *st);

View File

@ -87,7 +87,7 @@ update_walk_global_finish(void)
} }
static void static void
directory_set_stat(struct directory *dir, const struct stat *st) directory_set_stat(Directory *dir, const struct stat *st)
{ {
dir->inode = st->st_ino; dir->inode = st->st_ino;
dir->device = st->st_dev; dir->device = st->st_dev;
@ -95,12 +95,11 @@ directory_set_stat(struct directory *dir, const struct stat *st)
} }
static void static void
remove_excluded_from_directory(struct directory *directory, remove_excluded_from_directory(Directory *directory, GSList *exclude_list)
GSList *exclude_list)
{ {
db_lock(); db_lock();
struct directory *child, *n; Directory *child, *n;
directory_for_each_child_safe(child, n, directory) { directory_for_each_child_safe(child, n, directory) {
char *name_fs = utf8_to_fs_charset(child->GetName()); char *name_fs = utf8_to_fs_charset(child->GetName());
@ -129,9 +128,9 @@ remove_excluded_from_directory(struct directory *directory,
} }
static void static void
purge_deleted_from_directory(struct directory *directory) purge_deleted_from_directory(Directory *directory)
{ {
struct directory *child, *n; Directory *child, *n;
directory_for_each_child_safe(child, n, directory) { directory_for_each_child_safe(child, n, directory) {
if (directory_exists(child)) if (directory_exists(child))
continue; continue;
@ -172,7 +171,7 @@ purge_deleted_from_directory(struct directory *directory)
#ifndef G_OS_WIN32 #ifndef G_OS_WIN32
static int static int
update_directory_stat(struct directory *directory) update_directory_stat(Directory *directory)
{ {
struct stat st; struct stat st;
if (stat_directory(directory, &st) < 0) if (stat_directory(directory, &st) < 0)
@ -184,7 +183,7 @@ update_directory_stat(struct directory *directory)
#endif #endif
static int static int
find_inode_ancestor(struct directory *parent, ino_t inode, dev_t device) find_inode_ancestor(Directory *parent, ino_t inode, dev_t device)
{ {
#ifndef G_OS_WIN32 #ifndef G_OS_WIN32
while (parent) { while (parent) {
@ -208,7 +207,7 @@ find_inode_ancestor(struct directory *parent, ino_t inode, dev_t device)
} }
static bool static bool
update_playlist_file2(struct directory *directory, update_playlist_file2(Directory *directory,
const char *name, const char *suffix, const char *name, const char *suffix,
const struct stat *st) const struct stat *st)
{ {
@ -226,7 +225,7 @@ update_playlist_file2(struct directory *directory,
} }
static bool static bool
update_regular_file(struct directory *directory, update_regular_file(Directory *directory,
const char *name, const struct stat *st) const char *name, const struct stat *st)
{ {
const char *suffix = uri_get_suffix(name); const char *suffix = uri_get_suffix(name);
@ -239,10 +238,10 @@ update_regular_file(struct directory *directory,
} }
static bool static bool
update_directory(struct directory *directory, const struct stat *st); update_directory(Directory *directory, const struct stat *st);
static void static void
update_directory_child(struct directory *directory, update_directory_child(Directory *directory,
const char *name, const struct stat *st) const char *name, const struct stat *st)
{ {
assert(strchr(name, '/') == NULL); assert(strchr(name, '/') == NULL);
@ -254,7 +253,7 @@ update_directory_child(struct directory *directory,
return; return;
db_lock(); db_lock();
struct directory *subdir = directory->MakeChild(name); Directory *subdir = directory->MakeChild(name);
db_unlock(); db_unlock();
assert(directory == subdir->parent); assert(directory == subdir->parent);
@ -280,7 +279,7 @@ static bool skip_path(const char *path)
G_GNUC_PURE G_GNUC_PURE
static bool static bool
skip_symlink(const struct directory *directory, const char *utf8_name) skip_symlink(const Directory *directory, const char *utf8_name)
{ {
#ifndef WIN32 #ifndef WIN32
char *path_fs = map_directory_child_fs(directory, utf8_name); char *path_fs = map_directory_child_fs(directory, utf8_name);
@ -353,7 +352,7 @@ skip_symlink(const struct directory *directory, const char *utf8_name)
} }
static bool static bool
update_directory(struct directory *directory, const struct stat *st) update_directory(Directory *directory, const struct stat *st)
{ {
assert(S_ISDIR(st->st_mode)); assert(S_ISDIR(st->st_mode));
@ -418,11 +417,11 @@ update_directory(struct directory *directory, const struct stat *st)
return true; return true;
} }
static struct directory * static Directory *
directory_make_child_checked(struct directory *parent, const char *name_utf8) directory_make_child_checked(Directory *parent, const char *name_utf8)
{ {
db_lock(); db_lock();
directory *directory = parent->FindChild(name_utf8); Directory *directory = parent->FindChild(name_utf8);
db_unlock(); db_unlock();
if (directory != NULL) if (directory != NULL)
@ -450,10 +449,10 @@ directory_make_child_checked(struct directory *parent, const char *name_utf8)
return directory; return directory;
} }
static struct directory * static Directory *
directory_make_uri_parent_checked(const char *uri) directory_make_uri_parent_checked(const char *uri)
{ {
struct directory *directory = db_get_root(); Directory *directory = db_get_root();
char *duplicated = g_strdup(uri); char *duplicated = g_strdup(uri);
char *name_utf8 = duplicated, *slash; char *name_utf8 = duplicated, *slash;
@ -477,7 +476,7 @@ directory_make_uri_parent_checked(const char *uri)
static void static void
update_uri(const char *uri) update_uri(const char *uri)
{ {
struct directory *parent = directory_make_uri_parent_checked(uri); Directory *parent = directory_make_uri_parent_checked(uri);
if (parent == NULL) if (parent == NULL)
return; return;
@ -502,7 +501,7 @@ update_walk(const char *path, bool discard)
if (path != NULL && !isRootDirectory(path)) { if (path != NULL && !isRootDirectory(path)) {
update_uri(path); update_uri(path);
} else { } else {
struct directory *directory = db_get_root(); Directory *directory = db_get_root();
struct stat st; struct stat st;
if (stat_directory(directory, &st) == 0) if (stat_directory(directory, &st) == 0)

View File

@ -45,7 +45,7 @@ class ProxyDatabase : public Database {
unsigned port; unsigned port;
struct mpd_connection *connection; struct mpd_connection *connection;
struct directory *root; Directory *root;
public: public:
static Database *Create(const struct config_param *param, static Database *Create(const struct config_param *param,
@ -168,7 +168,7 @@ ProxyDatabase::Open(GError **error_r)
return false; return false;
} }
root = directory::NewRoot(); root = Directory::NewRoot();
return true; return true;
} }
@ -240,8 +240,7 @@ Visit(struct mpd_connection *connection,
const char *path = mpd_directory_get_path(directory); const char *path = mpd_directory_get_path(directory);
if (visit_directory) { if (visit_directory) {
struct directory *d = Directory *d = Directory::NewGeneric(path, &detached_root);
directory::NewGeneric(path, &detached_root);
bool success = visit_directory(*d, error_r); bool success = visit_directory(*d, error_r);
d->Free(); d->Free();
if (!success) if (!success)

View File

@ -180,7 +180,7 @@ SimpleDatabase::Load(GError **error_r)
bool bool
SimpleDatabase::Open(GError **error_r) SimpleDatabase::Open(GError **error_r)
{ {
root = directory::NewRoot(); root = Directory::NewRoot();
mtime = 0; mtime = 0;
#ifndef NDEBUG #ifndef NDEBUG
@ -197,7 +197,7 @@ SimpleDatabase::Open(GError **error_r)
if (!Check(error_r)) if (!Check(error_r))
return false; return false;
root = directory::NewRoot(); root = Directory::NewRoot();
} }
return true; return true;
@ -243,7 +243,7 @@ SimpleDatabase::ReturnSong(gcc_unused struct song *song) const
} }
G_GNUC_PURE G_GNUC_PURE
const struct directory * const Directory *
SimpleDatabase::LookupDirectory(const char *uri) const SimpleDatabase::LookupDirectory(const char *uri) const
{ {
assert(root != NULL); assert(root != NULL);
@ -262,7 +262,7 @@ SimpleDatabase::Visit(const DatabaseSelection &selection,
{ {
ScopeDatabaseLock protect; ScopeDatabaseLock protect;
const directory *directory = root->LookupDirectory(selection.uri); const Directory *directory = root->LookupDirectory(selection.uri);
if (directory == NULL) { if (directory == NULL) {
if (visit_song) { if (visit_song) {
song *song = root->LookupSong(selection.uri); song *song = root->LookupSong(selection.uri);

View File

@ -28,12 +28,12 @@
#include <time.h> #include <time.h>
struct directory; struct Directory;
class SimpleDatabase : public Database { class SimpleDatabase : public Database {
std::string path; std::string path;
struct directory *root; Directory *root;
time_t mtime; time_t mtime;
@ -43,7 +43,7 @@ class SimpleDatabase : public Database {
public: public:
gcc_pure gcc_pure
struct directory *GetRoot() { Directory *GetRoot() {
assert(root != NULL); assert(root != NULL);
return root; return root;
@ -90,7 +90,7 @@ protected:
bool Load(GError **error_r); bool Load(GError **error_r);
gcc_pure gcc_pure
const struct directory *LookupDirectory(const char *uri) const; const Directory *LookupDirectory(const char *uri) const;
}; };
extern const DatabasePlugin simple_db_plugin; extern const DatabasePlugin simple_db_plugin;

View File

@ -43,7 +43,7 @@ struct song {
struct list_head siblings; struct list_head siblings;
struct tag *tag; struct tag *tag;
struct directory *parent; struct Directory *parent;
time_t mtime; time_t mtime;
/** /**
@ -64,7 +64,7 @@ struct song {
* A dummy #directory instance that is used for "detached" song * A dummy #directory instance that is used for "detached" song
* copies. * copies.
*/ */
extern struct directory detached_root; extern struct Directory detached_root;
G_BEGIN_DECLS G_BEGIN_DECLS
@ -74,7 +74,7 @@ song_remote_new(const char *uri);
/** allocate a new song with a local file name */ /** allocate a new song with a local file name */
struct song * struct song *
song_file_new(const char *path, struct directory *parent); song_file_new(const char *path, struct Directory *parent);
/** /**
* allocate a new song structure with a local file name and attempt to * allocate a new song structure with a local file name and attempt to
@ -82,7 +82,7 @@ song_file_new(const char *path, struct directory *parent);
* data, NULL is returned. * data, NULL is returned.
*/ */
struct song * struct song *
song_file_load(const char *path, struct directory *parent); song_file_load(const char *path, struct Directory *parent);
/** /**
* Replaces the URI of a song object. The given song object is * Replaces the URI of a song object. The given song object is

View File

@ -48,7 +48,7 @@ my_log_func(const gchar *log_domain, G_GNUC_UNUSED GLogLevelFlags log_level,
} }
static bool static bool
DumpDirectory(const directory &directory, GError **) DumpDirectory(const Directory &directory, GError **)
{ {
cout << "D " << directory.path << endl; cout << "D " << directory.path << endl;
return true; return true;
@ -63,7 +63,7 @@ DumpSong(song &song, GError **)
static bool static bool
DumpPlaylist(const PlaylistInfo &playlist, DumpPlaylist(const PlaylistInfo &playlist,
const directory &directory, GError **) const Directory &directory, GError **)
{ {
cout << "P " << directory.path << "/" << playlist.name.c_str() << endl; cout << "P " << directory.path << "/" << playlist.name.c_str() << endl;
return true; return true;

View File

@ -5,7 +5,7 @@ extern "C" {
#include "song.h" #include "song.h"
#include "Directory.hxx" #include "Directory.hxx"
struct directory detached_root; Directory detached_root;
struct song * struct song *
song_dup_detached(const struct song *src) song_dup_detached(const struct song *src)