summaryrefslogtreecommitdiffstats
path: root/pathspec.c
diff options
context:
space:
mode:
authorJeff King <peff@peff.net>2023-06-01 19:38:14 +0200
committerJunio C Hamano <gitster@pobox.com>2023-06-03 03:34:25 +0200
commit8e32caaa783a3a6b1d94834ee6e2d21ac36ff39f (patch)
tree9db5c7c6043c22b58da2bb43c59c3e307ff630bc /pathspec.c
parentGit 2.40.1 (diff)
downloadgit-8e32caaa783a3a6b1d94834ee6e2d21ac36ff39f.tar.xz
git-8e32caaa783a3a6b1d94834ee6e2d21ac36ff39f.zip
pathspec: factor out magic-to-name function
When we have unsupported magic in a pathspec (because a command or code path does not support particular items), we list the unsupported ones in an error message. Let's factor out the code here that converts the bits back into their human-readable names, so that it can be used from other callers, which may want to provide more flexible error messages. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'pathspec.c')
-rw-r--r--pathspec.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/pathspec.c b/pathspec.c
index ab70fcbe61..f6fbb643ff 100644
--- a/pathspec.c
+++ b/pathspec.c
@@ -525,24 +525,29 @@ static int pathspec_item_cmp(const void *a_, const void *b_)
return strcmp(a->match, b->match);
}
-static void NORETURN unsupported_magic(const char *pattern,
- unsigned magic)
+void pathspec_magic_names(unsigned magic, struct strbuf *out)
{
- struct strbuf sb = STRBUF_INIT;
int i;
for (i = 0; i < ARRAY_SIZE(pathspec_magic); i++) {
const struct pathspec_magic *m = pathspec_magic + i;
if (!(magic & m->bit))
continue;
- if (sb.len)
- strbuf_addstr(&sb, ", ");
+ if (out->len)
+ strbuf_addstr(out, ", ");
if (m->mnemonic)
- strbuf_addf(&sb, _("'%s' (mnemonic: '%c')"),
+ strbuf_addf(out, _("'%s' (mnemonic: '%c')"),
m->name, m->mnemonic);
else
- strbuf_addf(&sb, "'%s'", m->name);
+ strbuf_addf(out, "'%s'", m->name);
}
+}
+
+static void NORETURN unsupported_magic(const char *pattern,
+ unsigned magic)
+{
+ struct strbuf sb = STRBUF_INIT;
+ pathspec_magic_names(magic, &sb);
/*
* We may want to substitute "this command" with a command
* name. E.g. when "git add -p" or "git add -i" dies when running