PlaylistInfo: rename class, use std::string
This commit is contained in:
parent
98dbdf72b3
commit
8331de424a
@ -303,7 +303,7 @@ src_mpd_SOURCES = \
|
|||||||
src/PlaylistState.cxx src/PlaylistState.hxx \
|
src/PlaylistState.cxx src/PlaylistState.hxx \
|
||||||
src/PlaylistQueue.cxx src/PlaylistQueue.hxx \
|
src/PlaylistQueue.cxx src/PlaylistQueue.hxx \
|
||||||
src/PlaylistVector.cxx src/PlaylistVector.hxx \
|
src/PlaylistVector.cxx src/PlaylistVector.hxx \
|
||||||
src/PlaylistInfo.cxx src/PlaylistInfo.hxx \
|
src/PlaylistInfo.hxx \
|
||||||
src/PlaylistDatabase.cxx \
|
src/PlaylistDatabase.cxx \
|
||||||
src/queue.c \
|
src/queue.c \
|
||||||
src/QueuePrint.cxx src/QueuePrint.hxx \
|
src/QueuePrint.cxx src/QueuePrint.hxx \
|
||||||
@ -1072,7 +1072,7 @@ test_DumpDatabase_SOURCES = test/DumpDatabase.cxx \
|
|||||||
src/DatabaseRegistry.cxx \
|
src/DatabaseRegistry.cxx \
|
||||||
src/DatabaseSelection.cxx \
|
src/DatabaseSelection.cxx \
|
||||||
src/Directory.cxx src/DirectorySave.cxx \
|
src/Directory.cxx src/DirectorySave.cxx \
|
||||||
src/PlaylistVector.cxx src/PlaylistInfo.cxx src/PlaylistDatabase.cxx \
|
src/PlaylistVector.cxx src/PlaylistDatabase.cxx \
|
||||||
src/DatabaseLock.cxx src/DatabaseSave.cxx \
|
src/DatabaseLock.cxx src/DatabaseSave.cxx \
|
||||||
src/Song.cxx src/song_sort.c src/SongSave.cxx \
|
src/Song.cxx src/song_sort.c src/SongSave.cxx \
|
||||||
src/tag.c src/tag_pool.c src/TagSave.cxx \
|
src/tag.c src/tag_pool.c src/TagSave.cxx \
|
||||||
|
@ -91,19 +91,19 @@ PrintSongFull(struct client *client, song &song)
|
|||||||
|
|
||||||
static bool
|
static bool
|
||||||
PrintPlaylistBrief(struct client *client,
|
PrintPlaylistBrief(struct client *client,
|
||||||
const playlist_metadata &playlist,
|
const PlaylistInfo &playlist,
|
||||||
const directory &directory)
|
const directory &directory)
|
||||||
{
|
{
|
||||||
print_playlist_in_directory(client, directory, playlist.name);
|
print_playlist_in_directory(client, directory, playlist.name.c_str());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
PrintPlaylistFull(struct client *client,
|
PrintPlaylistFull(struct client *client,
|
||||||
const playlist_metadata &playlist,
|
const PlaylistInfo &playlist,
|
||||||
const directory &directory)
|
const directory &directory)
|
||||||
{
|
{
|
||||||
print_playlist_in_directory(client, directory, playlist.name);
|
print_playlist_in_directory(client, directory, playlist.name.c_str());
|
||||||
|
|
||||||
if (playlist.mtime > 0)
|
if (playlist.mtime > 0)
|
||||||
time_print(client, "Last-Modified", playlist.mtime);
|
time_print(client, "Last-Modified", playlist.mtime);
|
||||||
|
@ -26,11 +26,11 @@
|
|||||||
|
|
||||||
struct directory;
|
struct directory;
|
||||||
struct song;
|
struct song;
|
||||||
struct playlist_metadata;
|
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 playlist_metadata &, 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;
|
||||||
|
@ -307,7 +307,7 @@ directory::Walk(bool recursive, const SongFilter *filter,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (visit_playlist) {
|
if (visit_playlist) {
|
||||||
struct playlist_metadata *i;
|
PlaylistInfo *i;
|
||||||
directory_for_each_playlist(i, this)
|
directory_for_each_playlist(i, this)
|
||||||
if (!visit_playlist(*i, *this, error_r))
|
if (!visit_playlist(*i, *this, error_r))
|
||||||
return false;
|
return false;
|
||||||
|
@ -38,20 +38,19 @@ playlist_database_quark(void)
|
|||||||
void
|
void
|
||||||
playlist_vector_save(FILE *fp, const struct list_head *pv)
|
playlist_vector_save(FILE *fp, const struct list_head *pv)
|
||||||
{
|
{
|
||||||
struct playlist_metadata *pm;
|
PlaylistInfo *pm;
|
||||||
playlist_vector_for_each(pm, pv)
|
playlist_vector_for_each(pm, pv)
|
||||||
fprintf(fp, PLAYLIST_META_BEGIN "%s\n"
|
fprintf(fp, PLAYLIST_META_BEGIN "%s\n"
|
||||||
"mtime: %li\n"
|
"mtime: %li\n"
|
||||||
"playlist_end\n",
|
"playlist_end\n",
|
||||||
pm->name, (long)pm->mtime);
|
pm->name.c_str(), (long)pm->mtime);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
playlist_metadata_load(FILE *fp, struct list_head *pv, const char *name,
|
playlist_metadata_load(FILE *fp, struct list_head *pv, const char *name,
|
||||||
GString *buffer, GError **error_r)
|
GString *buffer, GError **error_r)
|
||||||
{
|
{
|
||||||
struct playlist_metadata pm;
|
PlaylistInfo pm(name, 0);
|
||||||
pm.mtime = 0;
|
|
||||||
|
|
||||||
char *line, *colon;
|
char *line, *colon;
|
||||||
const char *value;
|
const char *value;
|
||||||
@ -77,6 +76,6 @@ playlist_metadata_load(FILE *fp, struct list_head *pv, const char *name,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
playlist_vector_update_or_add(pv, name, pm.mtime);
|
playlist_vector_update_or_add(pv, std::move(pm));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1,46 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2003-2013 The Music Player Daemon Project
|
|
||||||
* http://www.musicpd.org
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along
|
|
||||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
#include "PlaylistInfo.hxx"
|
|
||||||
|
|
||||||
#include <glib.h>
|
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
|
|
||||||
struct playlist_metadata *
|
|
||||||
playlist_metadata_new(const char *name, time_t mtime)
|
|
||||||
{
|
|
||||||
assert(name != NULL);
|
|
||||||
|
|
||||||
struct playlist_metadata *pm = g_slice_new(struct playlist_metadata);
|
|
||||||
pm->name = g_strdup(name);
|
|
||||||
pm->mtime = mtime;
|
|
||||||
return pm;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
playlist_metadata_free(struct playlist_metadata *pm)
|
|
||||||
{
|
|
||||||
assert(pm != NULL);
|
|
||||||
assert(pm->name != NULL);
|
|
||||||
|
|
||||||
g_free(pm->name);
|
|
||||||
g_slice_free(struct playlist_metadata, pm);
|
|
||||||
}
|
|
@ -23,26 +23,29 @@
|
|||||||
#include "check.h"
|
#include "check.h"
|
||||||
#include "util/list.h"
|
#include "util/list.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A directory entry pointing to a playlist file.
|
* A directory entry pointing to a playlist file.
|
||||||
*/
|
*/
|
||||||
struct playlist_metadata {
|
struct PlaylistInfo {
|
||||||
struct list_head siblings;
|
struct list_head siblings;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The UTF-8 encoded name of the playlist file.
|
* The UTF-8 encoded name of the playlist file.
|
||||||
*/
|
*/
|
||||||
char *name;
|
std::string name;
|
||||||
|
|
||||||
time_t mtime;
|
time_t mtime;
|
||||||
|
|
||||||
|
template<typename N>
|
||||||
|
PlaylistInfo(N &&_name, time_t _mtime)
|
||||||
|
:name(std::forward<N>(_name)), mtime(_mtime) {}
|
||||||
|
|
||||||
|
PlaylistInfo(const PlaylistInfo &other) = delete;
|
||||||
|
PlaylistInfo(PlaylistInfo &&) = default;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct playlist_metadata *
|
|
||||||
playlist_metadata_new(const char *name, time_t mtime);
|
|
||||||
|
|
||||||
void
|
|
||||||
playlist_metadata_free(struct playlist_metadata *pm);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -30,50 +30,48 @@ playlist_vector_deinit(struct list_head *pv)
|
|||||||
{
|
{
|
||||||
assert(pv != NULL);
|
assert(pv != NULL);
|
||||||
|
|
||||||
struct playlist_metadata *pm, *n;
|
PlaylistInfo *pm, *n;
|
||||||
playlist_vector_for_each_safe(pm, n, pv)
|
playlist_vector_for_each_safe(pm, n, pv)
|
||||||
playlist_metadata_free(pm);
|
delete pm;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct playlist_metadata *
|
PlaylistInfo *
|
||||||
playlist_vector_find(struct list_head *pv, const char *name)
|
playlist_vector_find(struct list_head *pv, const char *name)
|
||||||
{
|
{
|
||||||
assert(holding_db_lock());
|
assert(holding_db_lock());
|
||||||
assert(pv != NULL);
|
assert(pv != NULL);
|
||||||
assert(name != NULL);
|
assert(name != NULL);
|
||||||
|
|
||||||
struct playlist_metadata *pm;
|
PlaylistInfo *pm;
|
||||||
playlist_vector_for_each(pm, pv)
|
playlist_vector_for_each(pm, pv)
|
||||||
if (strcmp(pm->name, name) == 0)
|
if (pm->name.compare(name) == 0)
|
||||||
return pm;
|
return pm;
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
playlist_vector_add(struct list_head *pv,
|
playlist_vector_add(struct list_head *pv, PlaylistInfo &&pi)
|
||||||
const char *name, time_t mtime)
|
|
||||||
{
|
{
|
||||||
assert(holding_db_lock());
|
assert(holding_db_lock());
|
||||||
|
|
||||||
struct playlist_metadata *pm = playlist_metadata_new(name, mtime);
|
PlaylistInfo *pm = new PlaylistInfo(std::move(pi));
|
||||||
list_add_tail(&pm->siblings, pv);
|
list_add_tail(&pm->siblings, pv);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
playlist_vector_update_or_add(struct list_head *pv,
|
playlist_vector_update_or_add(struct list_head *pv, PlaylistInfo &&pi)
|
||||||
const char *name, time_t mtime)
|
|
||||||
{
|
{
|
||||||
assert(holding_db_lock());
|
assert(holding_db_lock());
|
||||||
|
|
||||||
struct playlist_metadata *pm = playlist_vector_find(pv, name);
|
PlaylistInfo *pm = playlist_vector_find(pv, pi.name.c_str());
|
||||||
if (pm != NULL) {
|
if (pm != NULL) {
|
||||||
if (mtime == pm->mtime)
|
if (pi.mtime == pm->mtime)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
pm->mtime = mtime;
|
pm->mtime = pi.mtime;
|
||||||
} else
|
} else
|
||||||
playlist_vector_add(pv, name, mtime);
|
playlist_vector_add(pv, std::move(pi));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -83,11 +81,11 @@ playlist_vector_remove(struct list_head *pv, const char *name)
|
|||||||
{
|
{
|
||||||
assert(holding_db_lock());
|
assert(holding_db_lock());
|
||||||
|
|
||||||
struct playlist_metadata *pm = playlist_vector_find(pv, name);
|
PlaylistInfo *pm = playlist_vector_find(pv, name);
|
||||||
if (pm == NULL)
|
if (pm == NULL)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
list_del(&pm->siblings);
|
list_del(&pm->siblings);
|
||||||
playlist_metadata_free(pm);
|
delete pm;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -37,15 +37,14 @@ playlist_vector_deinit(struct list_head *pv);
|
|||||||
/**
|
/**
|
||||||
* Caller must lock the #db_mutex.
|
* Caller must lock the #db_mutex.
|
||||||
*/
|
*/
|
||||||
struct playlist_metadata *
|
PlaylistInfo *
|
||||||
playlist_vector_find(struct list_head *pv, const char *name);
|
playlist_vector_find(struct list_head *pv, const char *name);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Caller must lock the #db_mutex.
|
* Caller must lock the #db_mutex.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
playlist_vector_add(struct list_head *pv,
|
playlist_vector_add(struct list_head *pv, PlaylistInfo &&pi);
|
||||||
const char *name, time_t mtime);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Caller must lock the #db_mutex.
|
* Caller must lock the #db_mutex.
|
||||||
@ -53,8 +52,7 @@ playlist_vector_add(struct list_head *pv,
|
|||||||
* @return true if the vector or one of its items was modified
|
* @return true if the vector or one of its items was modified
|
||||||
*/
|
*/
|
||||||
bool
|
bool
|
||||||
playlist_vector_update_or_add(struct list_head *pv,
|
playlist_vector_update_or_add(struct list_head *pv, PlaylistInfo &&pi);
|
||||||
const char *name, time_t mtime);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Caller must lock the #db_mutex.
|
* Caller must lock the #db_mutex.
|
||||||
|
@ -159,11 +159,12 @@ purge_deleted_from_directory(struct directory *directory)
|
|||||||
g_free(path);
|
g_free(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct playlist_metadata *pm, *np;
|
PlaylistInfo *pm, *np;
|
||||||
directory_for_each_playlist_safe(pm, np, directory) {
|
directory_for_each_playlist_safe(pm, np, directory) {
|
||||||
if (!directory_child_is_regular(directory, pm->name)) {
|
if (!directory_child_is_regular(directory, pm->name.c_str())) {
|
||||||
db_lock();
|
db_lock();
|
||||||
playlist_vector_remove(&directory->playlists, pm->name);
|
playlist_vector_remove(&directory->playlists,
|
||||||
|
pm->name.c_str());
|
||||||
db_unlock();
|
db_unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -214,9 +215,11 @@ update_playlist_file2(struct directory *directory,
|
|||||||
if (!playlist_suffix_supported(suffix))
|
if (!playlist_suffix_supported(suffix))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
PlaylistInfo pi(name, st->st_mtime);
|
||||||
|
|
||||||
db_lock();
|
db_lock();
|
||||||
if (playlist_vector_update_or_add(&directory->playlists, name,
|
if (playlist_vector_update_or_add(&directory->playlists,
|
||||||
st->st_mtime))
|
std::move(pi)))
|
||||||
modified = true;
|
modified = true;
|
||||||
db_unlock();
|
db_unlock();
|
||||||
return true;
|
return true;
|
||||||
|
@ -314,14 +314,10 @@ Visit(const struct mpd_playlist *playlist,
|
|||||||
if (!visit_playlist)
|
if (!visit_playlist)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
struct playlist_metadata p;
|
PlaylistInfo p(mpd_playlist_get_path(playlist),
|
||||||
p.name = g_strdup(mpd_playlist_get_path(playlist));
|
mpd_playlist_get_last_modified(playlist));
|
||||||
p.mtime = mpd_playlist_get_last_modified(playlist);
|
|
||||||
|
|
||||||
bool success = visit_playlist(p, detached_root, error_r);
|
return visit_playlist(p, detached_root, error_r);
|
||||||
g_free(p.name);
|
|
||||||
|
|
||||||
return success;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class ProxyEntity {
|
class ProxyEntity {
|
||||||
|
@ -62,10 +62,10 @@ DumpSong(song &song, GError **)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
DumpPlaylist(const playlist_metadata &playlist,
|
DumpPlaylist(const PlaylistInfo &playlist,
|
||||||
const directory &directory, GError **)
|
const directory &directory, GError **)
|
||||||
{
|
{
|
||||||
cout << "P " << directory.path << "/" << playlist.name << endl;
|
cout << "P " << directory.path << "/" << playlist.name.c_str() << endl;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user