ref-filter: pass ref_format struct to atom parsers
The callback for parsing each formatting atom gets to see only the atom struct (which it's filling in) and the text to be parsed. This doesn't leave any room for it to behave differently based on context known only to the ref_format. We can solve this by passing in the surrounding ref_format to each parser. Note that this makes things slightly awkward for sort strings, which parse atoms without having a ref_format. We'll solve that by using a dummy ref_format with default parameters. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
29ef53cd36
commit
ab7ded34d6
42
ref-filter.c
42
ref-filter.c
@ -98,7 +98,7 @@ static struct used_atom {
|
|||||||
} *used_atom;
|
} *used_atom;
|
||||||
static int used_atom_cnt, need_tagged, need_symref;
|
static int used_atom_cnt, need_tagged, need_symref;
|
||||||
|
|
||||||
static void color_atom_parser(struct used_atom *atom, const char *color_value)
|
static void color_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *color_value)
|
||||||
{
|
{
|
||||||
if (!color_value)
|
if (!color_value)
|
||||||
die(_("expected format: %%(color:<color>)"));
|
die(_("expected format: %%(color:<color>)"));
|
||||||
@ -126,7 +126,7 @@ static void refname_atom_parser_internal(struct refname_atom *atom,
|
|||||||
die(_("unrecognized %%(%s) argument: %s"), name, arg);
|
die(_("unrecognized %%(%s) argument: %s"), name, arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void remote_ref_atom_parser(struct used_atom *atom, const char *arg)
|
static void remote_ref_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
struct string_list params = STRING_LIST_INIT_DUP;
|
struct string_list params = STRING_LIST_INIT_DUP;
|
||||||
int i;
|
int i;
|
||||||
@ -160,28 +160,28 @@ static void remote_ref_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
string_list_clear(¶ms, 0);
|
string_list_clear(¶ms, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void body_atom_parser(struct used_atom *atom, const char *arg)
|
static void body_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (arg)
|
if (arg)
|
||||||
die(_("%%(body) does not take arguments"));
|
die(_("%%(body) does not take arguments"));
|
||||||
atom->u.contents.option = C_BODY_DEP;
|
atom->u.contents.option = C_BODY_DEP;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void subject_atom_parser(struct used_atom *atom, const char *arg)
|
static void subject_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (arg)
|
if (arg)
|
||||||
die(_("%%(subject) does not take arguments"));
|
die(_("%%(subject) does not take arguments"));
|
||||||
atom->u.contents.option = C_SUB;
|
atom->u.contents.option = C_SUB;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void trailers_atom_parser(struct used_atom *atom, const char *arg)
|
static void trailers_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (arg)
|
if (arg)
|
||||||
die(_("%%(trailers) does not take arguments"));
|
die(_("%%(trailers) does not take arguments"));
|
||||||
atom->u.contents.option = C_TRAILERS;
|
atom->u.contents.option = C_TRAILERS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void contents_atom_parser(struct used_atom *atom, const char *arg)
|
static void contents_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (!arg)
|
if (!arg)
|
||||||
atom->u.contents.option = C_BARE;
|
atom->u.contents.option = C_BARE;
|
||||||
@ -201,7 +201,7 @@ static void contents_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
die(_("unrecognized %%(contents) argument: %s"), arg);
|
die(_("unrecognized %%(contents) argument: %s"), arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void objectname_atom_parser(struct used_atom *atom, const char *arg)
|
static void objectname_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (!arg)
|
if (!arg)
|
||||||
atom->u.objectname.option = O_FULL;
|
atom->u.objectname.option = O_FULL;
|
||||||
@ -218,7 +218,7 @@ static void objectname_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
die(_("unrecognized %%(objectname) argument: %s"), arg);
|
die(_("unrecognized %%(objectname) argument: %s"), arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void refname_atom_parser(struct used_atom *atom, const char *arg)
|
static void refname_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
refname_atom_parser_internal(&atom->u.refname, arg, atom->name);
|
refname_atom_parser_internal(&atom->u.refname, arg, atom->name);
|
||||||
}
|
}
|
||||||
@ -234,7 +234,7 @@ static align_type parse_align_position(const char *s)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void align_atom_parser(struct used_atom *atom, const char *arg)
|
static void align_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
struct align *align = &atom->u.align;
|
struct align *align = &atom->u.align;
|
||||||
struct string_list params = STRING_LIST_INIT_DUP;
|
struct string_list params = STRING_LIST_INIT_DUP;
|
||||||
@ -273,7 +273,7 @@ static void align_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
string_list_clear(¶ms, 0);
|
string_list_clear(¶ms, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void if_atom_parser(struct used_atom *atom, const char *arg)
|
static void if_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
if (!arg) {
|
if (!arg) {
|
||||||
atom->u.if_then_else.cmp_status = COMPARE_NONE;
|
atom->u.if_then_else.cmp_status = COMPARE_NONE;
|
||||||
@ -287,7 +287,7 @@ static void if_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void head_atom_parser(struct used_atom *atom, const char *arg)
|
static void head_atom_parser(const struct ref_format *format, struct used_atom *atom, const char *arg)
|
||||||
{
|
{
|
||||||
struct object_id unused;
|
struct object_id unused;
|
||||||
|
|
||||||
@ -297,7 +297,7 @@ static void head_atom_parser(struct used_atom *atom, const char *arg)
|
|||||||
static struct {
|
static struct {
|
||||||
const char *name;
|
const char *name;
|
||||||
cmp_type cmp_type;
|
cmp_type cmp_type;
|
||||||
void (*parser)(struct used_atom *atom, const char *arg);
|
void (*parser)(const struct ref_format *format, struct used_atom *atom, const char *arg);
|
||||||
} valid_atom[] = {
|
} valid_atom[] = {
|
||||||
{ "refname" , FIELD_STR, refname_atom_parser },
|
{ "refname" , FIELD_STR, refname_atom_parser },
|
||||||
{ "objecttype" },
|
{ "objecttype" },
|
||||||
@ -364,7 +364,8 @@ struct atom_value {
|
|||||||
/*
|
/*
|
||||||
* Used to parse format string and sort specifiers
|
* Used to parse format string and sort specifiers
|
||||||
*/
|
*/
|
||||||
static int parse_ref_filter_atom(const char *atom, const char *ep)
|
static int parse_ref_filter_atom(const struct ref_format *format,
|
||||||
|
const char *atom, const char *ep)
|
||||||
{
|
{
|
||||||
const char *sp;
|
const char *sp;
|
||||||
const char *arg;
|
const char *arg;
|
||||||
@ -412,7 +413,7 @@ static int parse_ref_filter_atom(const char *atom, const char *ep)
|
|||||||
arg = used_atom[at].name + (arg - atom) + 1;
|
arg = used_atom[at].name + (arg - atom) + 1;
|
||||||
memset(&used_atom[at].u, 0, sizeof(used_atom[at].u));
|
memset(&used_atom[at].u, 0, sizeof(used_atom[at].u));
|
||||||
if (valid_atom[i].parser)
|
if (valid_atom[i].parser)
|
||||||
valid_atom[i].parser(&used_atom[at], arg);
|
valid_atom[i].parser(format, &used_atom[at], arg);
|
||||||
if (*atom == '*')
|
if (*atom == '*')
|
||||||
need_tagged = 1;
|
need_tagged = 1;
|
||||||
if (!strcmp(valid_atom[i].name, "symref"))
|
if (!strcmp(valid_atom[i].name, "symref"))
|
||||||
@ -668,7 +669,7 @@ int verify_ref_format(struct ref_format *format)
|
|||||||
if (!ep)
|
if (!ep)
|
||||||
return error(_("malformed format string %s"), sp);
|
return error(_("malformed format string %s"), sp);
|
||||||
/* sp points at "%(" and ep points at the closing ")" */
|
/* sp points at "%(" and ep points at the closing ")" */
|
||||||
at = parse_ref_filter_atom(sp + 2, ep);
|
at = parse_ref_filter_atom(format, sp + 2, ep);
|
||||||
cp = ep + 1;
|
cp = ep + 1;
|
||||||
|
|
||||||
if (skip_prefix(used_atom[at].name, "color:", &color))
|
if (skip_prefix(used_atom[at].name, "color:", &color))
|
||||||
@ -2075,7 +2076,9 @@ void format_ref_array_item(struct ref_array_item *info,
|
|||||||
ep = strchr(sp, ')');
|
ep = strchr(sp, ')');
|
||||||
if (cp < sp)
|
if (cp < sp)
|
||||||
append_literal(cp, sp, &state);
|
append_literal(cp, sp, &state);
|
||||||
get_ref_atom_value(info, parse_ref_filter_atom(sp + 2, ep), &atomv);
|
get_ref_atom_value(info,
|
||||||
|
parse_ref_filter_atom(format, sp + 2, ep),
|
||||||
|
&atomv);
|
||||||
atomv->handler(atomv, &state);
|
atomv->handler(atomv, &state);
|
||||||
}
|
}
|
||||||
if (*cp) {
|
if (*cp) {
|
||||||
@ -2116,8 +2119,13 @@ void pretty_print_ref(const char *name, const unsigned char *sha1,
|
|||||||
|
|
||||||
static int parse_sorting_atom(const char *atom)
|
static int parse_sorting_atom(const char *atom)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
|
* This parses an atom using a dummy ref_format, since we don't
|
||||||
|
* actually care about the formatting details.
|
||||||
|
*/
|
||||||
|
struct ref_format dummy = REF_FORMAT_INIT;
|
||||||
const char *end = atom + strlen(atom);
|
const char *end = atom + strlen(atom);
|
||||||
return parse_ref_filter_atom(atom, end);
|
return parse_ref_filter_atom(&dummy, atom, end);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If no sorting option is given, use refname to sort as default */
|
/* If no sorting option is given, use refname to sort as default */
|
||||||
|
Loading…
Reference in New Issue
Block a user