Mapper: use std::string
This commit is contained in:
parent
c85af12d45
commit
196ec25682
@ -31,8 +31,6 @@
|
|||||||
#include "util/Domain.hxx"
|
#include "util/Domain.hxx"
|
||||||
#include "Log.hxx"
|
#include "Log.hxx"
|
||||||
|
|
||||||
#include <glib.h>
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
@ -45,7 +43,7 @@ static constexpr Domain mapper_domain("mapper");
|
|||||||
/**
|
/**
|
||||||
* The absolute path of the music directory encoded in UTF-8.
|
* The absolute path of the music directory encoded in UTF-8.
|
||||||
*/
|
*/
|
||||||
static char *music_dir_utf8;
|
static std::string music_dir_utf8;
|
||||||
static size_t music_dir_utf8_length;
|
static size_t music_dir_utf8_length;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -99,11 +97,10 @@ mapper_set_music_dir(Path &&path)
|
|||||||
music_dir_fs = std::move(path);
|
music_dir_fs = std::move(path);
|
||||||
music_dir_fs.ChopSeparators();
|
music_dir_fs.ChopSeparators();
|
||||||
|
|
||||||
const auto utf8 = music_dir_fs.ToUTF8();
|
music_dir_utf8 = music_dir_fs.ToUTF8();
|
||||||
music_dir_utf8 = g_strdup(utf8.c_str());
|
music_dir_utf8_length = music_dir_utf8.length();
|
||||||
music_dir_utf8_length = strlen(music_dir_utf8);
|
|
||||||
|
|
||||||
check_directory(music_dir_utf8, music_dir_fs);
|
check_directory(music_dir_utf8.c_str(), music_dir_fs);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -129,13 +126,12 @@ mapper_init(Path &&_music_dir, Path &&_playlist_dir)
|
|||||||
|
|
||||||
void mapper_finish(void)
|
void mapper_finish(void)
|
||||||
{
|
{
|
||||||
g_free(music_dir_utf8);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
mapper_get_music_directory_utf8(void)
|
mapper_get_music_directory_utf8(void)
|
||||||
{
|
{
|
||||||
return music_dir_utf8;
|
return music_dir_utf8.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
const Path &
|
const Path &
|
||||||
@ -147,8 +143,8 @@ mapper_get_music_directory_fs(void)
|
|||||||
const char *
|
const char *
|
||||||
map_to_relative_path(const char *path_utf8)
|
map_to_relative_path(const char *path_utf8)
|
||||||
{
|
{
|
||||||
return music_dir_utf8 != NULL &&
|
return !music_dir_utf8.empty() &&
|
||||||
memcmp(path_utf8, music_dir_utf8,
|
memcmp(path_utf8, music_dir_utf8.c_str(),
|
||||||
music_dir_utf8_length) == 0 &&
|
music_dir_utf8_length) == 0 &&
|
||||||
Path::IsSeparatorUTF8(path_utf8[music_dir_utf8_length])
|
Path::IsSeparatorUTF8(path_utf8[music_dir_utf8_length])
|
||||||
? path_utf8 + music_dir_utf8_length + 1
|
? path_utf8 + music_dir_utf8_length + 1
|
||||||
@ -174,7 +170,6 @@ map_uri_fs(const char *uri)
|
|||||||
Path
|
Path
|
||||||
map_directory_fs(const Directory *directory)
|
map_directory_fs(const Directory *directory)
|
||||||
{
|
{
|
||||||
assert(music_dir_utf8 != NULL);
|
|
||||||
assert(!music_dir_fs.IsNull());
|
assert(!music_dir_fs.IsNull());
|
||||||
|
|
||||||
if (directory->IsRoot())
|
if (directory->IsRoot())
|
||||||
@ -186,7 +181,6 @@ map_directory_fs(const Directory *directory)
|
|||||||
Path
|
Path
|
||||||
map_directory_child_fs(const Directory *directory, const char *name)
|
map_directory_child_fs(const Directory *directory, const char *name)
|
||||||
{
|
{
|
||||||
assert(music_dir_utf8 != NULL);
|
|
||||||
assert(!music_dir_fs.IsNull());
|
assert(!music_dir_fs.IsNull());
|
||||||
|
|
||||||
/* check for invalid or unauthorized base names */
|
/* check for invalid or unauthorized base names */
|
||||||
@ -257,9 +251,10 @@ map_spl_utf8_to_fs(const char *name)
|
|||||||
if (playlist_dir_fs.IsNull())
|
if (playlist_dir_fs.IsNull())
|
||||||
return Path::Null();
|
return Path::Null();
|
||||||
|
|
||||||
char *filename_utf8 = g_strconcat(name, PLAYLIST_FILE_SUFFIX, NULL);
|
std::string filename_utf8 = name;
|
||||||
const Path filename_fs = Path::FromUTF8(filename_utf8);
|
filename_utf8.append(PLAYLIST_FILE_SUFFIX);
|
||||||
g_free(filename_utf8);
|
|
||||||
|
const Path filename_fs = Path::FromUTF8(filename_utf8.c_str());
|
||||||
if (filename_fs.IsNull())
|
if (filename_fs.IsNull())
|
||||||
return Path::Null();
|
return Path::Null();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user