diff options
author | Ivan Frade <ifrade@google.com> | 2023-09-28 15:06:40 -0700 |
---|---|---|
committer | Ivan Frade <ifrade@google.com> | 2023-09-28 15:06:40 -0700 |
commit | 42917767f9bfe42218e0069d1eed259460c3972e (patch) | |
tree | 864f34af0f8c506b8377a5ab227dbebb2d044016 /org.eclipse.jgit/src/org/eclipse/jgit/transport | |
parent | e8955fb506f121f7800eabb02432e19fe66c7761 (diff) | |
download | jgit-42917767f9bfe42218e0069d1eed259460c3972e.tar.gz jgit-42917767f9bfe42218e0069d1eed259460c3972e.zip |
UploadPack: Delay freeing refs in sendPack()
Change [1] set refs to null at the beggining of sendPack claiming they
are not needed anymore, but they are still used few lines below to
hoist referenced objects to the front of the pack. With refs nullified,
the hoist doesn't happened. This hasn't caused any problem so far,
probably because it is just an optimization and the objects are in the
pack anyway.
Move the nullification after the hoisting to keep the optimization and
save the memory.
[1] https://git.eclipse.org/r/c/jgit/jgit/+/161341
Change-Id: I8455249d8482f616af362d3912b718064d473b49
Diffstat (limited to 'org.eclipse.jgit/src/org/eclipse/jgit/transport')
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/transport/UploadPack.java | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/UploadPack.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/UploadPack.java index 5220057f4f..33aa585569 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/UploadPack.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/UploadPack.java @@ -2364,11 +2364,6 @@ public class UploadPack implements Closeable { } msgOut.flush(); - // Advertised objects and refs are not used from here on and can be - // cleared. - advertised = null; - refs = null; - PackConfig cfg = packConfig; if (cfg == null) cfg = new PackConfig(db); @@ -2410,6 +2405,11 @@ public class UploadPack implements Closeable { pw.setTagTargets(tagTargets); } + // Advertised objects and refs are not used from here on and can be + // cleared. + advertised = null; + refs = null; + RevWalk rw = walk; if (req.getDepth() > 0 || req.getDeepenSince() != 0 || !deepenNots.isEmpty()) { int walkDepth = req.getDepth() == 0 ? Integer.MAX_VALUE |