fs/Path: add method RelativeFS()
Move code from map_fs_to_utf8().
This commit is contained in:
@@ -251,17 +251,11 @@ map_song_fs(const Song *song)
|
|||||||
std::string
|
std::string
|
||||||
map_fs_to_utf8(const char *path_fs)
|
map_fs_to_utf8(const char *path_fs)
|
||||||
{
|
{
|
||||||
if (!music_dir_fs.IsNull() &&
|
if (G_IS_DIR_SEPARATOR(path_fs[0])) {
|
||||||
memcmp(path_fs, music_dir_fs.data(), music_dir_fs_length) == 0 &&
|
path_fs = music_dir_fs.RelativeFS(path_fs);
|
||||||
G_IS_DIR_SEPARATOR(path_fs[music_dir_fs_length]))
|
if (path_fs == nullptr || *path_fs == 0)
|
||||||
/* remove musicDir prefix */
|
return std::string();
|
||||||
path_fs += music_dir_fs_length + 1;
|
}
|
||||||
else if (G_IS_DIR_SEPARATOR(path_fs[0]))
|
|
||||||
/* not within musicDir */
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
while (path_fs[0] == G_DIR_SEPARATOR)
|
|
||||||
++path_fs;
|
|
||||||
|
|
||||||
return Path::ToUTF8(path_fs);
|
return Path::ToUTF8(path_fs);
|
||||||
}
|
}
|
||||||
|
@@ -184,3 +184,25 @@ void Path::GlobalInit()
|
|||||||
SetFSCharset("ISO-8859-1");
|
SetFSCharset("ISO-8859-1");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *
|
||||||
|
Path::RelativeFS(const char *other_fs) const
|
||||||
|
{
|
||||||
|
const size_t l = length();
|
||||||
|
if (memcmp(data(), other_fs, l) != 0)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
other_fs += l;
|
||||||
|
if (*other_fs != 0) {
|
||||||
|
if (!G_IS_DIR_SEPARATOR(*other_fs))
|
||||||
|
/* mismatch */
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
/* skip remaining path separators */
|
||||||
|
do {
|
||||||
|
++other_fs;
|
||||||
|
} while (G_IS_DIR_SEPARATOR(*other_fs));
|
||||||
|
}
|
||||||
|
|
||||||
|
return other_fs;
|
||||||
|
}
|
||||||
|
@@ -223,6 +223,15 @@ public:
|
|||||||
*/
|
*/
|
||||||
gcc_pure
|
gcc_pure
|
||||||
Path GetDirectoryName() const;
|
Path GetDirectoryName() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine the relative part of the given path to this
|
||||||
|
* object, not including the directory separator. Returns an
|
||||||
|
* empty string if the given path equals this object or
|
||||||
|
* nullptr on mismatch.
|
||||||
|
*/
|
||||||
|
gcc_pure
|
||||||
|
const char *RelativeFS(const char *other_fs) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user