aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2017-06-02 15:05:58 +0900
committerJunio C Hamano <gitster@pobox.com>2017-06-02 15:05:58 +0900
commit7d26aa32309a2a5979c4ae4b85b25b20e8aae0d4 (patch)
treed04eae1e3b22448ecac24085db96419c53ddca77
parent0339965c70d68fd3831c9a5306443c869de3f6a8 (diff)
parentd9244ecf4f109030e61b8fd52a799789133e2199 (diff)
downloadgit-7d26aa32309a2a5979c4ae4b85b25b20e8aae0d4.tar.gz
git-7d26aa32309a2a5979c4ae4b85b25b20e8aae0d4.tar.xz
Merge branch 'js/bs-is-a-dir-sep-on-windows'
"foo\bar\baz" in "git fetch foo\bar\baz", even though there is no slashes in it, cannot be a nickname for a remote on Windows, as that is likely to be a pathname on a local filesystem. * js/bs-is-a-dir-sep-on-windows: Windows: do not treat a path with backslashes as a remote's nick name mingw.h: permit arguments with side effects for is_dir_sep
-rw-r--r--compat/mingw.h6
-rw-r--r--remote.c7
2 files changed, 11 insertions, 2 deletions
diff --git a/compat/mingw.h b/compat/mingw.h
index 335016955..e03aecfe2 100644
--- a/compat/mingw.h
+++ b/compat/mingw.h
@@ -398,7 +398,11 @@ HANDLE winansi_get_osfhandle(int fd);
(isalpha(*(path)) && (path)[1] == ':' ? 2 : 0)
int mingw_skip_dos_drive_prefix(char **path);
#define skip_dos_drive_prefix mingw_skip_dos_drive_prefix
-#define is_dir_sep(c) ((c) == '/' || (c) == '\\')
+static inline int mingw_is_dir_sep(int c)
+{
+ return c == '/' || c == '\\';
+}
+#define is_dir_sep mingw_is_dir_sep
static inline char *mingw_find_last_dir_sep(const char *path)
{
char *ret = NULL;
diff --git a/remote.c b/remote.c
index fdc52d802..e43b1460f 100644
--- a/remote.c
+++ b/remote.c
@@ -649,7 +649,12 @@ static int valid_remote_nick(const char *name)
{
if (!name[0] || is_dot_or_dotdot(name))
return 0;
- return !strchr(name, '/'); /* no slash */
+
+ /* remote nicknames cannot contain slashes */
+ while (*name)
+ if (is_dir_sep(*name++))
+ return 0;
+ return 1;
}
const char *remote_for_branch(struct branch *branch, int *explicit)