Rewrite real_path, try to find an existing directory in the given path
Never throw, return the given filename in the worst case.
This commit is contained in:
parent
6e4b0f5781
commit
06fc329739
35
src/file.cc
35
src/file.cc
|
@ -50,21 +50,28 @@ String parse_filename(StringView filename)
|
||||||
|
|
||||||
String real_path(StringView filename)
|
String real_path(StringView filename)
|
||||||
{
|
{
|
||||||
StringView dirname = ".";
|
|
||||||
StringView basename = filename;
|
|
||||||
|
|
||||||
auto it = find(filename.rbegin(), filename.rend(), '/');
|
|
||||||
if (it != filename.rend())
|
|
||||||
{
|
|
||||||
dirname = StringView{filename.begin(), it.base()};
|
|
||||||
basename = StringView{it.base(), filename.end()};
|
|
||||||
}
|
|
||||||
|
|
||||||
char buffer[PATH_MAX+1];
|
char buffer[PATH_MAX+1];
|
||||||
char* res = realpath(dirname.zstr(), buffer);
|
|
||||||
if (not res)
|
StringView existing = filename;
|
||||||
throw file_not_found{dirname};
|
StringView non_existing;
|
||||||
return res + "/"_str + basename;
|
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
char* res = realpath(existing.zstr(), buffer);
|
||||||
|
if (res)
|
||||||
|
{
|
||||||
|
if (non_existing.empty())
|
||||||
|
return res;
|
||||||
|
return res + "/"_str + non_existing;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto it = find(existing.rbegin(), existing.rend(), '/');
|
||||||
|
if (it == existing.rend())
|
||||||
|
return filename;
|
||||||
|
|
||||||
|
existing = StringView{existing.begin(), it.base()-1};
|
||||||
|
non_existing = StringView{it.base(), filename.end()};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
String compact_path(StringView filename)
|
String compact_path(StringView filename)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user