diff options
author | Brandon Casey <casey@nrlssc.navy.mil> | 2008-08-22 02:16:30 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-08-22 09:15:37 +0200 |
commit | 2cb1f36d5098060a4bac182da16ceed3197a57c2 (patch) | |
tree | f307204f169aec5535a89c246f79f7df537190c0 /remote.h | |
parent | filter-branch: Grok special characters in tag names (diff) | |
download | git-2cb1f36d5098060a4bac182da16ceed3197a57c2.tar.xz git-2cb1f36d5098060a4bac182da16ceed3197a57c2.zip |
remote.c: add a function for deleting a refspec array and use it (twice)
A number of call sites allocate memory for a refspec array, populate
its members with heap memory, and then free only the refspec pointer
while leaking the memory allocated for the member elements. Provide
a function for freeing the elements of a refspec array and the array
itself.
Caution to callers: code paths must be checked to ensure that the
refspec members "src" and "dst" can be passed to free.
Signed-off-by: Brandon Casey <casey@nrlssc.navy.mil>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote.h')
-rw-r--r-- | remote.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -78,6 +78,7 @@ void ref_remove_duplicates(struct ref *ref_map); int valid_fetch_refspec(const char *refspec); struct refspec *parse_fetch_refspec(int nr_refspec, const char **refspec); struct refspec *parse_push_refspec(int nr_refspec, const char **refspec); +void free_refspecs(struct refspec *refspec, int nr_refspec); int match_refs(struct ref *src, struct ref *dst, struct ref ***dst_tail, int nr_refspec, const char **refspec, int all); |