Skip to content

Commit

Permalink
range-diff/format-patch: refactor check for commit range
Browse files Browse the repository at this point in the history
Currently, when called with exactly two arguments, `git range-diff`
tests for a literal `..` in each of the two. Likewise, the argument
provided via `--range-diff` to `git format-patch` is checked in the same
manner.

However, `<commit>^!` is a perfectly valid commit range, equivalent to
`<commit>^..<commit>` according to the `SPECIFYING RANGES` section of
gitrevisions[7].

In preparation for allowing more sophisticated ways to specify commit
ranges, let's refactor the check into its own function.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
  • Loading branch information
dscho committed Jan 27, 2021
1 parent 71ca53e commit b98fa94
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 5 deletions.
2 changes: 1 addition & 1 deletion builtin/log.c
Original file line number Diff line number Diff line change
Expand Up @@ -1680,7 +1680,7 @@ static void infer_range_diff_ranges(struct strbuf *r1,
struct commit *head)
{
const char *head_oid = oid_to_hex(&head->object.oid);
int prev_is_range = !!strstr(prev, "..");
int prev_is_range = is_range_diff_range(prev);

if (prev_is_range)
strbuf_addstr(r1, prev);
Expand Down
9 changes: 5 additions & 4 deletions builtin/range-diff.c
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#include "parse-options.h"
#include "range-diff.h"
#include "config.h"
#include "revision.h"

static const char * const builtin_range_diff_usage[] = {
N_("git range-diff [<options>] <old-base>..<old-tip> <new-base>..<new-tip>"),
Expand Down Expand Up @@ -46,12 +47,12 @@ int cmd_range_diff(int argc, const char **argv, const char *prefix)
diffopt.use_color = 1;

if (argc == 2) {
if (!strstr(argv[0], ".."))
die(_("no .. in range: '%s'"), argv[0]);
if (!is_range_diff_range(argv[0]))
die(_("not a commit range: '%s'"), argv[0]);
strbuf_addstr(&range1, argv[0]);

if (!strstr(argv[1], ".."))
die(_("no .. in range: '%s'"), argv[1]);
if (!is_range_diff_range(argv[1]))
die(_("not a commit range: '%s'"), argv[1]);
strbuf_addstr(&range2, argv[1]);
} else if (argc == 3) {
strbuf_addf(&range1, "%s..%s", argv[0], argv[1]);
Expand Down
5 changes: 5 additions & 0 deletions range-diff.c
Original file line number Diff line number Diff line change
Expand Up @@ -564,3 +564,8 @@ int show_range_diff(const char *range1, const char *range2,

return res;
}

int is_range_diff_range(const char *arg)
{
return !!strstr(arg, "..");
}
8 changes: 8 additions & 0 deletions range-diff.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,12 @@ int show_range_diff(const char *range1, const char *range2,
const struct diff_options *diffopt,
const struct strvec *other_arg);

/*
* Determine whether the given argument is usable as a range argument of `git
* range-diff`, e.g. A..B. Note that this only validates the format but does
* _not_ parse it, i.e. it does _not_ look up the specified commits in the
* local repository.
*/
int is_range_diff_range(const char *arg);

#endif

0 comments on commit b98fa94

Please sign in to comment.