Commit a34f5b0d by Edward Thomson

win32: refactor `git_win32_path_remove_namespace`

Update `git_win32_path_remove_namespace` to disambiguate the prefix
being removed versus the prefix being added.  Now we remove the
"namespace", and (may) add a "prefix" in its place.  Eg, we remove the
`\\?\` namespace.  We remove the `\\?\UNC\` namespace, and replace it
with the `\\` prefix.  This aids readability somewhat.

Additionally, use pointer arithmetic instead of offsets, which seems to
also help readability.
parent 16fd9ba9
...@@ -418,46 +418,57 @@ size_t git_win32_path_trim_end(wchar_t *str, size_t len) ...@@ -418,46 +418,57 @@ size_t git_win32_path_trim_end(wchar_t *str, size_t len)
*/ */
size_t git_win32_path_remove_namespace(wchar_t *str, size_t len) size_t git_win32_path_remove_namespace(wchar_t *str, size_t len)
{ {
static const wchar_t dosdevices_prefix[] = L"\\\?\?\\"; static const wchar_t dosdevices_namespace[] = L"\\\?\?\\";
static const wchar_t nt_prefix[] = L"\\\\?\\"; static const wchar_t nt_namespace[] = L"\\\\?\\";
static const wchar_t unc_prefix[] = L"UNC\\"; static const wchar_t unc_namespace_remainder[] = L"UNC\\";
static const wchar_t unc_canonicalized_prefix[] = L"\\\\"; static const wchar_t unc_prefix[] = L"\\\\";
size_t to_advance = 0; const wchar_t *prefix = NULL, *remainder = NULL;
size_t prefix_len = 0, remainder_len = 0;
/* "\??\" -- DOS Devices prefix */ /* "\??\" -- DOS Devices prefix */
if (len >= CONST_STRLEN(dosdevices_prefix) && if (len >= CONST_STRLEN(dosdevices_namespace) &&
!wcsncmp(str, dosdevices_prefix, CONST_STRLEN(dosdevices_prefix))) { !wcsncmp(str, dosdevices_namespace, CONST_STRLEN(dosdevices_namespace))) {
to_advance += CONST_STRLEN(dosdevices_prefix); remainder = str + CONST_STRLEN(dosdevices_namespace);
len -= CONST_STRLEN(dosdevices_prefix); remainder_len = len - CONST_STRLEN(dosdevices_namespace);
} }
/* "\\?\" -- NT namespace prefix */ /* "\\?\" -- NT namespace prefix */
else if (len >= CONST_STRLEN(nt_prefix) && else if (len >= CONST_STRLEN(nt_namespace) &&
!wcsncmp(str, nt_prefix, CONST_STRLEN(nt_prefix))) { !wcsncmp(str, nt_namespace, CONST_STRLEN(nt_namespace))) {
to_advance += CONST_STRLEN(nt_prefix); remainder = str + CONST_STRLEN(nt_namespace);
len -= CONST_STRLEN(nt_prefix); remainder_len = len - CONST_STRLEN(nt_namespace);
} }
/* "\??\UNC\", "\\?\UNC\" -- UNC prefix */ /* "\??\UNC\", "\\?\UNC\" -- UNC prefix */
if (to_advance && len >= CONST_STRLEN(unc_prefix) && if (remainder_len >= CONST_STRLEN(unc_namespace_remainder) &&
!wcsncmp(str + to_advance, unc_prefix, CONST_STRLEN(unc_prefix))) { !wcsncmp(remainder, unc_namespace_remainder, CONST_STRLEN(unc_namespace_remainder))) {
/* /*
* The proper Win32 path for a UNC share has "\\" at beginning of it * The proper Win32 path for a UNC share has "\\" at beginning of it
* and looks like "\\server\share\<folderStructure>". * and looks like "\\server\share\<folderStructure>". So remove the
* So, remove the UNC prefix, but leave room for a "\\" * UNC namespace and add a prefix of "\\" in its place.
*/ */
to_advance += (CONST_STRLEN(unc_prefix) - CONST_STRLEN(unc_canonicalized_prefix)); remainder += CONST_STRLEN(unc_namespace_remainder);
len -= (CONST_STRLEN(unc_prefix) - CONST_STRLEN(unc_canonicalized_prefix)); remainder_len -= CONST_STRLEN(unc_namespace_remainder);
/** prefix = unc_prefix;
* Place a "\\" in the string so the result is "\\server\\share\<folderStructure>" prefix_len = CONST_STRLEN(unc_prefix);
*/
memmove(str + to_advance, unc_canonicalized_prefix, CONST_STRLEN(unc_canonicalized_prefix) * sizeof(wchar_t));
} }
if (to_advance) { if (remainder) {
memmove(str, str + to_advance, len * sizeof(wchar_t)); /*
* Sanity check that the new string isn't longer than the old one.
* (This could only happen due to programmer error introducing a
* prefix longer than the namespace it replaces.)
*/
assert(len >= remainder_len + prefix_len);
if (prefix)
memmove(str, prefix, prefix_len * sizeof(wchar_t));
memmove(str + prefix_len, remainder, remainder_len * sizeof(wchar_t));
len = remainder_len + prefix_len;
str[len] = L'\0'; str[len] = L'\0';
} }
......
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