Merge branch 'rs/remote-mv-leakfix'
authorJunio C Hamano <gitster@pobox.com>
Wed, 15 Aug 2018 22:08:28 +0000 (15:08 -0700)
committerJunio C Hamano <gitster@pobox.com>
Wed, 15 Aug 2018 22:08:28 +0000 (15:08 -0700)
Leakfix.

* rs/remote-mv-leakfix:
remote: clear string_list after use in mv()

1  2 
builtin/remote.c
diff --combined builtin/remote.c
index c74ee886900176e900d80625144a8570ea127fb1,213c07b0436845857cd167449135ffff446f0ef5..07bd51f8eb348036e7e1446d513e46e2877ec6a9
@@@ -8,7 -8,6 +8,7 @@@
  #include "run-command.h"
  #include "refs.h"
  #include "refspec.h"
 +#include "object-store.h"
  #include "argv-array.h"
  
  static const char * const builtin_remote_usage[] = {
@@@ -566,7 -565,7 +566,7 @@@ static int read_remote_branches(const c
  
        strbuf_addf(&buf, "refs/remotes/%s/", rename->old_name);
        if (starts_with(refname, buf.buf)) {
-               item = string_list_append(rename->remote_branches, xstrdup(refname));
+               item = string_list_append(rename->remote_branches, refname);
                symref = resolve_ref_unsafe(refname, RESOLVE_REF_READING,
                                            NULL, &flag);
                if (symref && (flag & REF_ISSYMREF))
@@@ -612,7 -611,7 +612,7 @@@ static int mv(int argc, const char **ar
        struct remote *oldremote, *newremote;
        struct strbuf buf = STRBUF_INIT, buf2 = STRBUF_INIT, buf3 = STRBUF_INIT,
                old_remote_context = STRBUF_INIT;
-       struct string_list remote_branches = STRING_LIST_INIT_NODUP;
+       struct string_list remote_branches = STRING_LIST_INIT_DUP;
        struct rename_info rename;
        int i, refspec_updated = 0;
  
                if (create_symref(buf.buf, buf2.buf, buf3.buf))
                        die(_("creating '%s' failed"), buf.buf);
        }
+       string_list_clear(&remote_branches, 1);
        return 0;
  }