blame: teach -L/RE/ to search from end of previous -L range
authorEric Sunshine <sunshine@sunshineco.com>
Tue, 6 Aug 2013 13:59:42 +0000 (09:59 -0400)
committerJunio C Hamano <gitster@pobox.com>
Tue, 6 Aug 2013 21:44:25 +0000 (14:44 -0700)
Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/blame.c
t/annotate-tests.sh
index 7b084d8445272e368ddfd96e5d9f74e8353b70bd..1bf8056f6b2471d290f99a6615867646531f77b4 100644 (file)
@@ -2280,6 +2280,7 @@ int cmd_blame(int argc, const char **argv, const char *prefix)
        int cmd_is_annotate = !strcmp(argv[0], "annotate");
        struct range_set ranges;
        unsigned int range_i;
+       long anchor;
 
        git_config(git_blame_config, NULL);
        init_revisions(&revs, NULL);
@@ -2475,11 +2476,12 @@ int cmd_blame(int argc, const char **argv, const char *prefix)
        if (lno && !range_list.nr)
                string_list_append(&range_list, xstrdup("1"));
 
+       anchor = 1;
        range_set_init(&ranges, range_list.nr);
        for (range_i = 0; range_i < range_list.nr; ++range_i) {
                long bottom, top;
                if (parse_range_arg(range_list.items[range_i].string,
-                                   nth_line_cb, &sb, lno, 1,
+                                   nth_line_cb, &sb, lno, anchor,
                                    &bottom, &top, sb.path))
                        usage(blame_usage);
                if (lno < top || ((lno || bottom) && lno < bottom))
@@ -2490,6 +2492,7 @@ int cmd_blame(int argc, const char **argv, const char *prefix)
                        top = lno;
                bottom--;
                range_set_append_unsafe(&ranges, bottom, top);
+               anchor = top + 1;
        }
        sort_and_merge_range_set(&ranges);
 
index 77083d9ddecaf4e26bfd0ab88dff65756d3575f0..b963d3632527db0deffcca2c635a3eb71f12e911 100644 (file)
@@ -303,6 +303,26 @@ test_expect_success 'blame -L multiple (superset/subset: unordered)' '
        check_count -L3,5 -L2,8 A 1 B 1 B1 1 B2 1 C 1 D 1 "A U Thor" 1
 '
 
+test_expect_success 'blame -L /RE/ (relative)' '
+       check_count -L3,3 -L/fox/ B1 1 B2 1 C 1 D 1 "A U Thor" 1
+'
+
+test_expect_success 'blame -L /RE/ (relative: no preceding range)' '
+       check_count -L/dog/ A 1 B 1 B1 1 B2 1 C 1 D 1 "A U Thor" 1
+'
+
+test_expect_success 'blame -L /RE/ (relative: adjacent)' '
+       check_count -L1,1 -L/dog/,+1 A 1 E 1
+'
+
+test_expect_success 'blame -L /RE/ (relative: not found)' '
+       test_must_fail $PROG -L4,4 -L/dog/ file
+'
+
+test_expect_success 'blame -L /RE/ (relative: end-of-file)' '
+       test_must_fail $PROG -L, -L/$/ file
+'
+
 test_expect_success 'setup -L :regex' '
        tr Q "\\t" >hello.c <<-\EOF &&
        int main(int argc, const char *argv[])