diff options
author | Adam Spiers <git@adamspiers.org> | 2013-01-06 17:58:05 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-01-06 23:26:37 +0100 |
commit | 270be8160493eb25ee43eb7db8dda2504343dc65 (patch) | |
tree | 93d5642a17e8d182a1c9a22c02c62e3219416ae0 /dir.c | |
parent | dir.c: keep track of where patterns came from (diff) | |
download | git-270be8160493eb25ee43eb7db8dda2504343dc65.tar.xz git-270be8160493eb25ee43eb7db8dda2504343dc65.zip |
dir.c: provide clear_directory() for reclaiming dir_struct memory
By the end of a directory traversal, a dir_struct instance will
typically contains pointers to various data structures on the heap.
clear_directory() provides a convenient way to reclaim that memory.
Signed-off-by: Adam Spiers <git@adamspiers.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'dir.c')
-rw-r--r-- | dir.c | 30 |
1 files changed, 30 insertions, 0 deletions
@@ -1557,3 +1557,33 @@ void free_pathspec(struct pathspec *pathspec) free(pathspec->items); pathspec->items = NULL; } + +/* + * Frees memory within dir which was allocated for exclude lists and + * the exclude_stack. Does not free dir itself. + */ +void clear_directory(struct dir_struct *dir) +{ + int i, j; + struct exclude_list_group *group; + struct exclude_list *el; + struct exclude_stack *stk; + + for (i = EXC_CMDL; i <= EXC_FILE; i++) { + group = &dir->exclude_list_group[i]; + for (j = 0; j < group->nr; j++) { + el = &group->el[j]; + if (i == EXC_DIRS) + free((char *)el->src); + clear_exclude_list(el); + } + free(group->el); + } + + stk = dir->exclude_stack; + while (stk) { + struct exclude_stack *prev = stk->prev; + free(stk); + stk = prev; + } +} |