diff options
-rw-r--r-- | src/path.c | 25 | ||||
-rw-r--r-- | tests-clar/core/path.c | 9 |
2 files changed, 34 insertions, 0 deletions
diff --git a/src/path.c b/src/path.c index 569101c40..dd6bb70ad 100644 --- a/src/path.c +++ b/src/path.c @@ -19,6 +19,22 @@ #define LOOKS_LIKE_DRIVE_PREFIX(S) (git__isalpha((S)[0]) && (S)[1] == ':') +static bool looks_like_network_computer_name(const char *path, int pos) +{ + if (pos < 3) + return false; + + if (path[0] != '/' || path[1] != '/') + return false; + + while (pos-- > 2) { + if (path[pos] == '/') + return false; + } + + return true; +} + /* * Based on the Android implementation, BSD licensed. * Check http://android.git.kernel.org/ @@ -111,6 +127,15 @@ int git_path_dirname_r(git_buf *buffer, const char *path) len = 3; goto Exit; } + + /* Similarly checks if we're dealing with a network computer name + '//computername/.git' will return '//computername/' */ + + if (looks_like_network_computer_name(path, len)) { + len++; + goto Exit; + } + #endif Exit: diff --git a/tests-clar/core/path.c b/tests-clar/core/path.c index 864393b70..894e81f3d 100644 --- a/tests-clar/core/path.c +++ b/tests-clar/core/path.c @@ -87,6 +87,15 @@ void test_core_path__00_dirname(void) check_dirname(".git/", "."); check_dirname(REP16("/abc"), REP15("/abc")); + +#ifdef GIT_WIN32 + check_dirname("C:/path/", "C:/"); + check_dirname("C:/path", "C:/"); + check_dirname("//computername/path/", "//computername/"); + check_dirname("//computername/path", "//computername/"); + check_dirname("//computername/sub/path/", "//computername/sub"); + check_dirname("//computername/sub/path", "//computername/sub"); +#endif } /* get the base name of a path */ |