Mapper: obtain music directory from Storage

Eliminate duplicate variable.
This commit is contained in:
Max Kellermann 2014-02-07 23:34:29 +01:00
parent 4d5ebafa6d
commit 6798af52b6
3 changed files with 19 additions and 31 deletions

View File

@ -161,7 +161,7 @@ glue_mapper_init(Error &error)
} }
#endif #endif
mapper_init(std::move(music_dir), std::move(playlist_dir)); mapper_init(std::move(playlist_dir));
return true; return true;
} }

View File

@ -28,36 +28,20 @@
#include "fs/Charset.hxx" #include "fs/Charset.hxx"
#include "fs/CheckFile.hxx" #include "fs/CheckFile.hxx"
#include <assert.h>
#ifdef ENABLE_DATABASE #ifdef ENABLE_DATABASE
#include "storage/StorageInterface.hxx"
/** #include "Instance.hxx"
* The absolute path of the music directory encoded in the filesystem #include "Main.hxx"
* character set.
*/
static AllocatedPath music_dir_fs = AllocatedPath::Null();
#endif #endif
#include <assert.h>
/** /**
* The absolute path of the playlist directory encoded in the * The absolute path of the playlist directory encoded in the
* filesystem character set. * filesystem character set.
*/ */
static AllocatedPath playlist_dir_fs = AllocatedPath::Null(); static AllocatedPath playlist_dir_fs = AllocatedPath::Null();
#ifdef ENABLE_DATABASE
static void
mapper_set_music_dir(AllocatedPath &&path)
{
assert(!path.IsNull());
music_dir_fs = std::move(path);
}
#endif
static void static void
mapper_set_playlist_dir(AllocatedPath &&path) mapper_set_playlist_dir(AllocatedPath &&path)
{ {
@ -69,15 +53,8 @@ mapper_set_playlist_dir(AllocatedPath &&path)
} }
void void
mapper_init(AllocatedPath &&_music_dir, AllocatedPath &&_playlist_dir) mapper_init(AllocatedPath &&_playlist_dir)
{ {
#ifdef ENABLE_DATABASE
if (!_music_dir.IsNull())
mapper_set_music_dir(std::move(_music_dir));
#else
(void)_music_dir;
#endif
if (!_playlist_dir.IsNull()) if (!_playlist_dir.IsNull())
mapper_set_playlist_dir(std::move(_playlist_dir)); mapper_set_playlist_dir(std::move(_playlist_dir));
} }
@ -94,6 +71,10 @@ map_uri_fs(const char *uri)
assert(uri != nullptr); assert(uri != nullptr);
assert(*uri != '/'); assert(*uri != '/');
if (instance->storage == nullptr)
return AllocatedPath::Null();
const auto music_dir_fs = instance->storage->MapFS("");
if (music_dir_fs.IsNull()) if (music_dir_fs.IsNull())
return AllocatedPath::Null(); return AllocatedPath::Null();
@ -108,6 +89,13 @@ std::string
map_fs_to_utf8(const char *path_fs) map_fs_to_utf8(const char *path_fs)
{ {
if (PathTraitsFS::IsSeparator(path_fs[0])) { if (PathTraitsFS::IsSeparator(path_fs[0])) {
if (instance->storage == nullptr)
return std::string();
const auto music_dir_fs = instance->storage->MapFS("");
if (music_dir_fs.IsNull())
return std::string();
path_fs = music_dir_fs.RelativeFS(path_fs); path_fs = music_dir_fs.RelativeFS(path_fs);
if (path_fs == nullptr || *path_fs == 0) if (path_fs == nullptr || *path_fs == 0)
return std::string(); return std::string();

View File

@ -33,7 +33,7 @@
class AllocatedPath; class AllocatedPath;
void void
mapper_init(AllocatedPath &&music_dir, AllocatedPath &&playlist_dir); mapper_init(AllocatedPath &&playlist_dir);
void mapper_finish(void); void mapper_finish(void);