builtin/mv: don't use memory after free
commitd954828d45efbd4b53576e86066657e87391318d
authorJohn Keeping <john@keeping.me.uk>
Sun, 16 Feb 2014 16:06:05 +0000 (16 16:06 +0000)
committerJunio C Hamano <gitster@pobox.com>
Tue, 18 Feb 2014 23:51:56 +0000 (18 15:51 -0800)
treee9863eead8a070c6a3c60932f28463b7d9506bfe
parenta68a67dea399f15305b059aa36c007cfdde2890e
builtin/mv: don't use memory after free

If 'src' already ends with a slash, then add_slash() will just return
it, meaning that 'free(src_with_slash)' is actually 'free(src)'.  Since
we use 'src' later, this will result in use-after-free.

In fact, this cannot happen because 'src' comes from
internal_copy_pathspec() without the KEEP_TRAILING_SLASH flag, so any
trailing '/' will have been stripped; but static analysis tools are not
clever enough to realise this and so warn that 'src' could be used after
having been free'd.  Fix this by checking that 'src_w_slash' is indeed
newly allocated memory.

Signed-off-by: John Keeping <john@keeping.me.uk>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/mv.c