xdiff/histogram: remove tail recursion
authorStefan Beller <sbeller@google.com>
Thu, 19 Jul 2018 22:19:42 +0000 (15:19 -0700)
committerJunio C Hamano <gitster@pobox.com>
Mon, 23 Jul 2018 17:12:16 +0000 (10:12 -0700)
When running the same reproduction script as the previous patch,
it turns out the stack is too small, which can be easily avoided.

Signed-off-by: Stefan Beller <sbeller@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
xdiff/xhistogram.c
index fc2d3cd95d96dd2c2a6e2893a25151db50f6c91e..ec85f5992bd2c5148382eaba73b6c4c51c74dbf2 100644 (file)
@@ -318,7 +318,9 @@ static int histogram_diff(xpparam_t const *xpp, xdfenv_t *env,
 {
        struct region lcs;
        int lcs_found;
-       int result = -1;
+       int result;
+redo:
+       result = -1;
 
        if (count1 <= 0 && count2 <= 0)
                return 0;
@@ -355,11 +357,17 @@ static int histogram_diff(xpparam_t const *xpp, xdfenv_t *env,
                                                line2, lcs.begin2 - line2);
                        if (result)
                                goto out;
-                       result = histogram_diff(xpp, env,
-                                               lcs.end1 + 1, LINE_END(1) - lcs.end1,
-                                               lcs.end2 + 1, LINE_END(2) - lcs.end2);
-                       if (result)
-                               goto out;
+                       /*
+                        * result = histogram_diff(xpp, env,
+                        *            lcs.end1 + 1, LINE_END(1) - lcs.end1,
+                        *            lcs.end2 + 1, LINE_END(2) - lcs.end2);
+                        * but let's optimize tail recursion ourself:
+                       */
+                       count1 = LINE_END(1) - lcs.end1;
+                       line1 = lcs.end1 + 1;
+                       count2 = LINE_END(2) - lcs.end2;
+                       line2 = lcs.end2 + 1;
+                       goto redo;
                }
        }
 out: