<!DOCTYPE html>
<html lang='en'>
<head>
<title>jgit.git - JGit, the Java implementation of git: https://github.com/eclipse-jgit/jgit</title>
<meta name='generator' content='cgit v1.2.3'/>
<meta name='robots' content='index, nofollow'/>
<link rel='stylesheet' type='text/css' href='/cgit.css'/>
<link rel='shortcut icon' href='/favicon.ico'/>
<link rel='alternate' title='Atom feed' href='https://source.dussan.org/jgit.git/atom/?h=master' type='application/atom+xml'/>
</head>
<body>
<div id='cgit'><table id='header'>
<tr>
<td class='logo' rowspan='2'><a href='/'><img src='/cgit.png' alt='cgit logo'/></a></td>
<td class='main'><a href='/'>index</a> : <a href='/jgit.git/'>jgit.git</a></td><td class='form'><form method='get'>
<input type='hidden' name='id2' value='13f866c5c7709c5439de516bd889fe6c1da57d1e'/><select name='h' onchange='this.form.submit();'>
<option value='master' selected='selected'>master</option>
<option value='master%private'>master%private</option>
<option value='next'>next</option>
<option value='servlet-4'>servlet-4</option>
<option value='stable-0.10'>stable-0.10</option>
<option value='stable-0.11'>stable-0.11</option>
<option value='stable-0.12'>stable-0.12</option>
<option value='stable-0.7'>stable-0.7</option>
<option value='stable-0.8'>stable-0.8</option>
<option value='stable-0.9'>stable-0.9</option>
<option value='stable-1.0'>stable-1.0</option>
<option value='stable-1.1'>stable-1.1</option>
<option value='stable-1.2'>stable-1.2</option>
<option value='stable-1.3'>stable-1.3</option>
<option value='stable-2.0'>stable-2.0</option>
<option value='stable-2.1'>stable-2.1</option>
<option value='stable-2.2'>stable-2.2</option>
<option value='stable-2.3'>stable-2.3</option>
<option value='stable-3.0'>stable-3.0</option>
<option value='stable-3.1'>stable-3.1</option>
<option value='stable-3.2'>stable-3.2</option>
<option value='stable-3.3'>stable-3.3</option>
<option value='stable-3.4'>stable-3.4</option>
<option value='stable-3.5'>stable-3.5</option>
<option value='stable-3.6'>stable-3.6</option>
<option value='stable-3.7'>stable-3.7</option>
<option value='stable-4.0'>stable-4.0</option>
<option value='stable-4.1'>stable-4.1</option>
<option value='stable-4.10'>stable-4.10</option>
<option value='stable-4.11'>stable-4.11</option>
<option value='stable-4.2'>stable-4.2</option>
<option value='stable-4.3'>stable-4.3</option>
<option value='stable-4.4'>stable-4.4</option>
<option value='stable-4.5'>stable-4.5</option>
<option value='stable-4.6'>stable-4.6</option>
<option value='stable-4.7'>stable-4.7</option>
<option value='stable-4.8'>stable-4.8</option>
<option value='stable-4.9'>stable-4.9</option>
<option value='stable-5.0'>stable-5.0</option>
<option value='stable-5.1'>stable-5.1</option>
<option value='stable-5.10'>stable-5.10</option>
<option value='stable-5.11'>stable-5.11</option>
<option value='stable-5.12'>stable-5.12</option>
<option value='stable-5.13'>stable-5.13</option>
<option value='stable-5.2'>stable-5.2</option>
<option value='stable-5.3'>stable-5.3</option>
<option value='stable-5.4'>stable-5.4</option>
<option value='stable-5.5'>stable-5.5</option>
<option value='stable-5.6'>stable-5.6</option>
<option value='stable-5.7'>stable-5.7</option>
<option value='stable-5.8'>stable-5.8</option>
<option value='stable-5.9'>stable-5.9</option>
<option value='stable-6.0'>stable-6.0</option>
<option value='stable-6.1'>stable-6.1</option>
<option value='stable-6.10'>stable-6.10</option>
<option value='stable-6.2'>stable-6.2</option>
<option value='stable-6.3'>stable-6.3</option>
<option value='stable-6.4'>stable-6.4</option>
<option value='stable-6.5'>stable-6.5</option>
<option value='stable-6.6'>stable-6.6</option>
<option value='stable-6.7'>stable-6.7</option>
<option value='stable-6.8'>stable-6.8</option>
<option value='stable-6.9'>stable-6.9</option>
<option value='stable-7.0'>stable-7.0</option>
<option value='stable-7.1'>stable-7.1</option>
<option value='stable-7.2'>stable-7.2</option>
<option value='stable-7.3'>stable-7.3</option>
<option value='stable-7.4'>stable-7.4</option>
</select> <input type='submit' value='switch'/></form></td></tr>
<tr><td class='sub'>JGit, the Java implementation of git: https://github.com/eclipse-jgit/jgit</td><td class='sub right'>www-data</td></tr></table>
<table class='tabs'><tr><td>
<a href='/jgit.git/about/'>about</a><a href='/jgit.git/'>summary</a><a href='/jgit.git/refs/'>refs</a><a href='/jgit.git/log/'>log</a><a href='/jgit.git/tree/'>tree</a><a href='/jgit.git/commit/'>commit</a><a class='active' href='/jgit.git/diff/?id2=13f866c5c7709c5439de516bd889fe6c1da57d1e'>diff</a><a href='/jgit.git/stats/'>stats</a></td><td class='form'><form class='right' method='get' action='/jgit.git/log/'>
<input type='hidden' name='id2' value='13f866c5c7709c5439de516bd889fe6c1da57d1e'/><select name='qt'>
<option value='grep'>log msg</option>
<option value='author'>author</option>
<option value='committer'>committer</option>
<option value='range'>range</option>
</select>
<input class='txt' type='search' size='10' name='q' value=''/>
<input type='submit' value='search'/>
</form>
</td></tr></table>
<div class='content'><div class='cgit-panel'><b>diff options</b><form method='get'><input type='hidden' name='id2' value='13f866c5c7709c5439de516bd889fe6c1da57d1e'/><table><tr><td colspan='2'/></tr><tr><td class='label'>context:</td><td class='ctrl'><select name='context' onchange='this.form.submit();'><option value='1'>1</option><option value='2'>2</option><option value='3' selected='selected'>3</option><option value='4'>4</option><option value='5'>5</option><option value='6'>6</option><option value='7'>7</option><option value='8'>8</option><option value='9'>9</option><option value='10'>10</option><option value='15'>15</option><option value='20'>20</option><option value='25'>25</option><option value='30'>30</option><option value='35'>35</option><option value='40'>40</option></select></td></tr><tr><td class='label'>space:</td><td class='ctrl'><select<style>pre { line-height: 125%; }
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #888888 } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { color: #008800; font-weight: bold } /* Keyword */
.highlight .ch { color: #888888 } /* Comment.Hashbang */
.highlight .cm { color: #888888 } /* Comment.Multiline */
.highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */
.highlight .cpf { color: #888888 } /* Comment.PreprocFile */
.highlight .c1 { color: #888888 } /* Comment.Single */
.highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #333333 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #666666 } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: #008800 } /* Keyword.Pseudo */
.highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */
.highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */
.highlight .na { color: #336699 } /* Name.Attribute */
.highlight .nb { color: #003388 } /* Name.Builtin */
.highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */
.highlight .no { color: #003366; font-weight: bold } /* Name.Constant */
.highlight .nd { color: #555555 } /* Name.Decorator */
.highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */
.highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */
.highlight .nl { color: #336699; font-style: italic } /* Name.Label */
.highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */
.highlight .py { color: #336699; font-weight: bold } /* Name.Property */
.highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */
.highlight .nv { color: #336699 } /* Name.Variable */
.highlight .ow { color: #008800 } /* Operator.Word */
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
.highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */
.highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */
.highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */
.highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */
.highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */
.highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */
.highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */
.highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */
.highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */
.highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */
.highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */
.highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */
.highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */
.highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */
.highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */
.highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */
.highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */
.highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */
.highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */
.highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */
.highlight .vc { color: #336699 } /* Name.Variable.Class */
.highlight .vg { color: #dd7700 } /* Name.Variable.Global */
.highlight .vi { color: #3333bb } /* Name.Variable.Instance */
.highlight .vm { color: #336699 } /* Name.Variable.Magic */
.highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */</style><div class="highlight"><pre><span></span><span class="kn">import</span><span class="w"> </span><span class="nn">org.aspectj.lang.annotation.*</span><span class="p">;</span>

<span class="nd">@Aspect</span>
<span class="kd">public</span><span class="w"> </span><span class="kd">class</span> <span class="nc">Code</span><span class="w"> </span><span class="p">{</span>
<span class="w">  </span><span class="nd">@Before</span><span class="p">(</span><span class="s">&quot;if(37!=42)&quot;</span><span class="p">)</span>
<span class="w">  </span><span class="kd">public</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="nf">runme</span><span class="p">()</span><span class="w"> </span><span class="p">{}</span>
<span class="p">}</span>
</pre></div>
</code></pre></td></tr></table>
</div> <!-- class=content -->
<div class='footer'>generated by <a href='https://git.zx2c4.com/cgit/about/'>cgit v1.2.3</a> (<a href='https://git-scm.com/'>git 2.39.1</a>) at 2025-08-02 19:01:31 +0000</div>
</div> <!-- id=cgit -->
</body>
</html>
bjectId);</div><div class='add'>+			if (ldr == null &amp;&amp; restoreFromSelfOrAlternate(objectId, null)) {</div><div class='add'>+				ldr = openObjectWithoutRestoring(curs, objectId);</div><div class='add'>+			}</div><div class='ctx'> 		}</div><div class='ctx'> 		return ldr;</div><div class='ctx'> 	}</div><div class='hunk'>@@ -419,11 +428,16 @@ public class ObjectDirectory extends FileObjectDatabase {</div><div class='ctx'> 		return loose.open(curs, id);</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='add'>+	@SuppressWarnings("boxing")</div><div class='ctx'> 	@Override</div><div class='ctx'> 	long getObjectSize(WindowCursor curs, AnyObjectId id) throws IOException {</div><div class='del'>-		long sz = getObjectSizeWithoutRestoring(curs, id);</div><div class='del'>-		if (0 &gt; sz &amp;&amp; restoreFromSelfOrAlternate(id, null)) {</div><div class='add'>+		Long sz = getFromLocalObjectToPack(curs, id,</div><div class='add'>+				(p, c, l) -&gt; p.getObjectSize(c, l));</div><div class='add'>+		if (sz == null) {</div><div class='ctx'> 			sz = getObjectSizeWithoutRestoring(curs, id);</div><div class='add'>+			if (sz &lt; 0 &amp;&amp; restoreFromSelfOrAlternate(id, null)) {</div><div class='add'>+				sz = getObjectSizeWithoutRestoring(curs, id);</div><div class='add'>+			}</div><div class='ctx'> 		}</div><div class='ctx'> 		return sz;</div><div class='ctx'> 	}</div><div class='hunk'>@@ -480,6 +494,24 @@ public class ObjectDirectory extends FileObjectDatabase {</div><div class='ctx'> 		return -1;</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='add'>+	private &lt;R&gt; R getFromLocalObjectToPack(WindowCursor curs,</div><div class='add'>+			AnyObjectId objectId,</div><div class='add'>+			TriFunctionThrowsException&lt;Pack, WindowCursor, LocalObjectToPack, R, IOException&gt; func) {</div><div class='add'>+		if (objectId instanceof LocalObjectToPack) {</div><div class='add'>+			LocalObjectToPack lotp = (LocalObjectToPack) objectId;</div><div class='add'>+			Pack pack = lotp.pack;</div><div class='add'>+			if (pack != null) {</div><div class='add'>+				try {</div><div class='add'>+					return func.apply(pack, curs, lotp);</div><div class='add'>+				} catch (IOException e) {</div><div class='add'>+					// lotp potentially repacked, continue as if lotp not</div><div class='add'>+					// provided</div><div class='add'>+				}</div><div class='add'>+			}</div><div class='add'>+		}</div><div class='add'>+		return null;</div><div class='add'>+	}</div><div class='add'>+</div><div class='ctx'> 	@Override</div><div class='ctx'> 	void selectObjectRepresentation(PackWriter packer, ObjectToPack otp,</div><div class='ctx'> 			WindowCursor curs) throws IOException {</div><div class='head'>diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java<br/>index f2f54947af..8988b41b55 100644<br/>--- a/<a href='/jgit.git/tree/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java?id=13f866c5c7709c5439de516bd889fe6c1da57d1e'>org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java</a><br/>+++ b/<a href='/jgit.git/tree/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java?id=ada3a20f06ec5f253011918ffe22364a01e32365'>org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java</a></div><div class='hunk'>@@ -124,15 +124,16 @@ public class Pack implements Iterable&lt;PackIndex.MutableEntry&gt; {</div><div class='ctx'> </div><div class='ctx'> 	private byte[] packChecksum;</div><div class='ctx'> </div><div class='del'>-	private Optionally&lt;PackIndex&gt; loadedIdx = Optionally.empty();</div><div class='add'>+	private volatile Optionally&lt;PackIndex&gt; loadedIdx = Optionally.empty();</div><div class='ctx'> </div><div class='del'>-	private Optionally&lt;PackReverseIndex&gt; reverseIdx = Optionally.empty();</div><div class='add'>+	private volatile Optionally&lt;PackReverseIndex&gt; reverseIdx = Optionally.empty();</div><div class='ctx'> </div><div class='ctx'> 	private volatile PackObjectSizeIndex loadedObjSizeIdx;</div><div class='ctx'> </div><div class='ctx'> 	private volatile boolean attemptLoadObjSizeIdx;</div><div class='ctx'> </div><div class='del'>-	private Optionally&lt;PackBitmapIndex&gt; bitmapIdx = Optionally.empty();</div><div class='add'>+	private volatile Optionally&lt;PackBitmapIndex&gt; bitmapIdx = Optionally.empty();</div><div class='add'>+</div><div class='ctx'> </div><div class='ctx'> 	/**</div><div class='ctx'> 	 * Objects we have tried to read, and discovered to be corrupt.</div><div class='hunk'>@@ -168,7 +169,15 @@ public class Pack implements Iterable&lt;PackIndex.MutableEntry&gt; {</div><div class='ctx'> 		length = Long.MAX_VALUE;</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='del'>-	private synchronized PackIndex idx() throws IOException {</div><div class='add'>+	private PackIndex idx() throws IOException {</div><div class='add'>+		Optional&lt;PackIndex&gt; optional = loadedIdx.getOptional();</div><div class='add'>+		if (optional.isPresent()) {</div><div class='add'>+			return optional.get();</div><div class='add'>+		}</div><div class='add'>+		return memoizeIdxIfNeeded();</div><div class='add'>+	}</div><div class='add'>+</div><div class='add'>+	private synchronized PackIndex memoizeIdxIfNeeded() throws IOException {</div><div class='ctx'> 		Optional&lt;PackIndex&gt; optional = loadedIdx.getOptional();</div><div class='ctx'> 		if (optional.isPresent()) {</div><div class='ctx'> 			return optional.get();</div><div class='hunk'>@@ -420,9 +429,9 @@ public class Pack implements Iterable&lt;PackIndex.MutableEntry&gt; {</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='ctx'> 	private synchronized void closeIndices() {</div><div class='del'>-		loadedIdx.clear();</div><div class='del'>-		reverseIdx.clear();</div><div class='del'>-		bitmapIdx.clear();</div><div class='add'>+		loadedIdx = Optionally.empty();</div><div class='add'>+		reverseIdx = Optionally.empty();</div><div class='add'>+		bitmapIdx = Optionally.empty();</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='ctx'> 	/**</div><div class='hunk'>@@ -1290,7 +1299,15 @@ public class Pack implements Iterable&lt;PackIndex.MutableEntry&gt; {</div><div class='ctx'> 		return getReverseIdx().findNextOffset(startOffset, maxOffset);</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='del'>-	synchronized PackBitmapIndex getBitmapIndex() throws IOException {</div><div class='add'>+	PackBitmapIndex getBitmapIndex() throws IOException {</div><div class='add'>+		Optional&lt;PackBitmapIndex&gt; optional = bitmapIdx.getOptional();</div><div class='add'>+		if (optional.isPresent()) {</div><div class='add'>+			return optional.get();</div><div class='add'>+		}</div><div class='add'>+		return memoizeBitmapIndexIfNeeded();</div><div class='add'>+	}</div><div class='add'>+</div><div class='add'>+	private synchronized PackBitmapIndex memoizeBitmapIndexIfNeeded() throws IOException {</div><div class='ctx'> 		if (invalid || bitmapIdxFile == null) {</div><div class='ctx'> 			return null;</div><div class='ctx'> 		}</div><div class='hunk'>@@ -1325,7 +1342,15 @@ public class Pack implements Iterable&lt;PackIndex.MutableEntry&gt; {</div><div class='ctx'> 		this.bitmapIdxFile = bitmapIndexFile;</div><div class='ctx'> 	}</div><div class='ctx'> </div><div class='del'>-	private synchronized PackReverseIndex getReverseIdx() throws IOException {</div><div class='add'>+	private PackReverseIndex getReverseIdx() throws IOException {</div><div class='add'>+		Optional&lt;PackReverseIndex&gt; optional = reverseIdx.getOptional();</div><div class='add'>+		if (optional.isPresent()) {</div><div class='add'>+			return optional.get();</div><div class='add'>+		}</div><div class='add'>+		return memoizeReverseIdxIfNeeded();</div><div class='add'>+	}</div><div class='add'>+</div><div class='add'>+	private synchronized PackReverseIndex memoizeReverseIdxIfNeeded() throws IOException {</div><div class='ctx'> 		if (invalid) {</div><div class='ctx'> 			throw new PackInvalidException(packFile, invalidatingCause);</div><div class='ctx'> 		}</div></td></tr></table></div> <!-- class=content -->
<div class='footer'>generated by <a href='https://git.zx2c4.com/cgit/about/'>cgit v1.2.3</a> (<a href='https://git-scm.com/'>git 2.39.1</a>) at 2025-08-02 19:01:30 +0000</div>
</div> <!-- id=cgit -->
</body>
</html>
