Merge pull request #52744 from theraot/3.x
[3.x] Fix get_base_dir windows top level directory logic
This commit is contained in:
commit
4850e7eaca
1 changed files with 32 additions and 16 deletions
|
@ -3967,26 +3967,42 @@ bool String::is_rel_path() const {
|
|||
}
|
||||
|
||||
String String::get_base_dir() const {
|
||||
int basepos = find(":/");
|
||||
if (basepos == -1) {
|
||||
basepos = find(":\\");
|
||||
}
|
||||
String rs;
|
||||
String base;
|
||||
int end = 0;
|
||||
|
||||
// url scheme style base
|
||||
int basepos = find("://");
|
||||
if (basepos != -1) {
|
||||
int end = basepos + 3;
|
||||
rs = substr(end, length());
|
||||
base = substr(0, end);
|
||||
} else {
|
||||
if (begins_with("/")) {
|
||||
rs = substr(1, length());
|
||||
base = "/";
|
||||
} else {
|
||||
rs = *this;
|
||||
end = basepos + 3;
|
||||
}
|
||||
|
||||
// windows top level directory base
|
||||
if (end == 0) {
|
||||
basepos = find(":/");
|
||||
if (basepos == -1) {
|
||||
basepos = find(":\\");
|
||||
}
|
||||
if (basepos != -1) {
|
||||
end = basepos + 2;
|
||||
}
|
||||
}
|
||||
|
||||
int sep = MAX(rs.find_last("/"), rs.find_last("\\"));
|
||||
// unix root directory base
|
||||
if (end == 0) {
|
||||
if (begins_with("/")) {
|
||||
end = 1;
|
||||
}
|
||||
}
|
||||
|
||||
String rs;
|
||||
String base;
|
||||
if (end != 0) {
|
||||
rs = substr(end, length());
|
||||
base = substr(0, end);
|
||||
} else {
|
||||
rs = *this;
|
||||
}
|
||||
|
||||
int sep = MAX(rs.rfind("/"), rs.rfind("\\"));
|
||||
if (sep == -1) {
|
||||
return base;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue