Commit 0b27ac2f authored by Max Kellermann's avatar Max Kellermann

fs/Path: add method RelativeFS()

Move code from map_fs_to_utf8().
parent 6fd481df
...@@ -251,17 +251,11 @@ map_song_fs(const Song *song) ...@@ -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() ...@@ -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: ...@@ -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
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment