diffcore-break: free filespec data as we go
authorJeff King <peff@peff.net>
Mon, 16 Nov 2009 15:56:25 +0000 (10:56 -0500)
committerJunio C Hamano <gitster@pobox.com>
Mon, 16 Nov 2009 21:21:11 +0000 (13:21 -0800)
As we look at each changed file and consider breaking it, we
load the blob data and make a decision about whether to
break, which is independent of any other blobs that might
have changed. However, we keep the data in memory while we
consider breaking all of the other files. Which means that
both versions of every file you are diffing are in memory at
the same time.

This patch instead frees the blob data as we finish with
each file pair, leading to much lower memory usage.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
diffcore-break.c

index d7097bb576cef8900e8e0218ba82e1cc7a87a567..15562e45560726475bc395d3a89a212d6e2a1aba 100644 (file)
@@ -204,12 +204,16 @@ void diffcore_break(int break_score)
                                dp->score = score;
                                dp->broken_pair = 1;
 
+                               diff_free_filespec_data(p->one);
+                               diff_free_filespec_data(p->two);
                                free(p); /* not diff_free_filepair(), we are
                                          * reusing one and two here.
                                          */
                                continue;
                        }
                }
+               diff_free_filespec_data(p->one);
+               diff_free_filespec_data(p->two);
                diff_q(&outq, p);
        }
        free(q->queue);