There is only one instance of grep_source_init(GREP_SOURCE_FILE), and in
that case the path and identifier arguments are equal - not just as
strings, but the same pointer is passed. So we can save some time and
memory by reusing the gs->path = xstrdup_or_null(path) we have already
done as gs->identifier, and changing grep_source_clear accordingly
to avoid a double free.

Signed-off-by: Rasmus Villemoes <r...@rasmusvillemoes.dk>
---
 grep.c | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)

diff --git a/grep.c b/grep.c
index 3d7cd0e96..b1532b1b6 100644
--- a/grep.c
+++ b/grep.c
@@ -1972,7 +1972,8 @@ void grep_source_init(struct grep_source *gs, enum 
grep_source_type type,
 
        switch (type) {
        case GREP_SOURCE_FILE:
-               gs->identifier = xstrdup(identifier);
+               gs->identifier = identifier == path ?
+                       gs->path : xstrdup(identifier);
                break;
        case GREP_SOURCE_OID:
                gs->identifier = oiddup(identifier);
@@ -1986,7 +1987,10 @@ void grep_source_init(struct grep_source *gs, enum 
grep_source_type type,
 void grep_source_clear(struct grep_source *gs)
 {
        FREE_AND_NULL(gs->name);
-       FREE_AND_NULL(gs->path);
+       if (gs->path == gs->identifier)
+               gs->path = NULL;
+       else
+               FREE_AND_NULL(gs->path);
        FREE_AND_NULL(gs->identifier);
        grep_source_clear_data(gs);
 }
-- 
2.15.1

Reply via email to