Fixed last 2 memory leaks in rev-parse.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
diff --git a/src/revparse.c b/src/revparse.c
index ea33e3a..9719093 100644
--- a/src/revparse.c
+++ b/src/revparse.c
@@ -238,27 +238,29 @@ static git_object* dereference_object(git_object *obj)
 
 static int dereference_to_type(git_object **out, git_object *obj, git_otype target_type)
 {
+   int retcode = 1;
    git_object *obj1 = obj, *obj2 = obj;
 
-   while (1) {
+   while (retcode > 0) {
       git_otype this_type = git_object_type(obj1);
 
       if (this_type == target_type) {
          *out = obj1;
-         return 0;
-      }
-
-      /* Dereference once, if possible. */
-      obj2 = dereference_object(obj1);
-      if (!obj2) {
-         giterr_set(GITERR_REFERENCE, "Can't dereference to type");
-         return GIT_ERROR;
+         retcode = 0;
+      } else {
+         /* Dereference once, if possible. */
+         obj2 = dereference_object(obj1);
+         if (!obj2) {
+            giterr_set(GITERR_REFERENCE, "Can't dereference to type");
+            retcode = GIT_ERROR;
+         }
       }
       if (obj1 != obj) {
          git_object_free(obj1);
       }
       obj1 = obj2;
    }
+   return retcode;
 }
 
 static git_otype parse_obj_type(const char *str)
@@ -471,10 +473,8 @@ int git_revparse_single(git_object **out, git_repository *repo, const char *spec
       }
    }
 
-   if (!retcode) {
-      if (*out != cur_obj) git_object_free(cur_obj);
-      if (*out != next_obj && next_obj != cur_obj) git_object_free(next_obj);
-   }
+   if (*out != cur_obj) git_object_free(cur_obj);
+   if (*out != next_obj && next_obj != cur_obj) git_object_free(next_obj);
 
    git_buf_free(&specbuffer);
    git_buf_free(&stepbuffer);