]> source.dussan.org Git - jgit.git/log
jgit.git
9 years agoAdd public isStaleFileHandle() API, improve detection. 89/54489/1
Martin Fick [Tue, 25 Aug 2015 13:48:50 +0000 (07:48 -0600)]
Add public isStaleFileHandle() API, improve detection.

Add a public API to the FileUtils to determine if an IOException is a
stale NFS file handle exception.  This will make it easier to detect
such errors, and interpret them consistently throughout the codebase.
This new API is a bit more lenient in its detection than the previous
detection, and should be able to detect some errors which previously
were not identified as stale file handle exceptions because they had the
word NFS in the error message.  Adjust the packfile handling code to use
this new API for detection.

Change-Id: I21f80014546ba1afec7335890e5ae79e7f521412
Signed-off-by: Martin Fick<mfick@codeaurora.org>
9 years agoEnable annotation based NPE analysis in jgit 80/50580/7
Andrey Loskutov [Sat, 20 Jun 2015 18:01:56 +0000 (20:01 +0200)]
Enable annotation based NPE analysis in jgit

Bug: 470647
Change-Id: I14d1983bb7c208faeffee0504e0567e38d8a89f3
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoUpdate Jetty to 9.2.13.v20150730 77/54177/1
Matthias Sohn [Wed, 19 Aug 2015 22:46:58 +0000 (00:46 +0200)]
Update Jetty to 9.2.13.v20150730

Change-Id: I0c2a4cafcd1992431888c2a48592d9cb1ac04747
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoRestored obsoleted createSymLink/readSymLink in FileUtil 18/54018/1
Andrey Loskutov [Tue, 18 Aug 2015 18:01:15 +0000 (20:01 +0200)]
Restored obsoleted createSymLink/readSymLink in FileUtil

Bug: 475070
Change-Id: I425ad842dc26b55f747f192348398a3912c0ca6b
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoUse NIO2 to implement FileUtils.rename() and expose options 68/46468/5
Matthias Sohn [Wed, 22 Apr 2015 23:11:58 +0000 (01:11 +0200)]
Use NIO2 to implement FileUtils.rename() and expose options

- use NIO2's Files.move() to reimplement rename()
- provide a second method accepting CopyOptions which can be used to
  request atomic move.

Change-Id: Ibcf722978e65745218a1ccda45344ca295911659
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoMove createSymLink/readSymLink to FileUtils 36/53836/2
Andrey Loskutov [Sun, 16 Aug 2015 15:41:22 +0000 (17:41 +0200)]
Move createSymLink/readSymLink to FileUtils

Bug: 475070
Change-Id: I258f4bf291e02ef8e6f867b5d71c04ec902b6bcb
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoMerge "Change FS not to throw NPE when facing InMemory databases"
Christian Halstrick [Mon, 17 Aug 2015 07:54:23 +0000 (03:54 -0400)]
Merge "Change FS not to throw NPE when facing InMemory databases"

9 years agoExpose the set of root commits in PackStatistics 42/53842/1
Shawn Pearce [Sun, 16 Aug 2015 21:10:16 +0000 (14:10 -0700)]
Expose the set of root commits in PackStatistics

Root commits are commits with zero parents.  If a commmit has no
parents it is the first commit in the repository.  In general the root
commits should be unique for any given project, as the first commit
will be created at a different time, by a different user with its own
message.  These root commits can be used as a "fingerprint" to
identify disjoint histories.

Change-Id: Id891dbc1f17c816cea404569578bb7635ff85cdb

9 years agoChange FS not to throw NPE when facing InMemory databases 43/53843/1
Christian Halstrick [Fri, 10 Jul 2015 11:01:10 +0000 (13:01 +0200)]
Change FS not to throw NPE when facing InMemory databases

The FS class and the subclasses FS_POSIX assumed in the findHook()
method that every repository has a valid gitDir. But in tests when using
in-memory-repositories this is not true and this method was generating
NPEs. Change the method to return null if no repository directory can be
determined.

Change-Id: I38a4d36dc6452b5dacae3d0dbf562b569ca3c19b

9 years agoFix NPE in DfsGarbageCollector and further reduce memory 43/53743/2
Shawn Pearce [Fri, 14 Aug 2015 04:29:30 +0000 (21:29 -0700)]
Fix NPE in DfsGarbageCollector and further reduce memory

DfsGarbageCollector asks PackWriter for the set of objects packed
after the bitmap index is written out.  This is now null as it was
cleared to release memory. Instead use PackBitmapIndexBuilder to
build the set as it also has the objects.

Reduce memory in PackBitmapIndexBuilder by fully discarding the
ObjectToPack instances. This was the original intent of commit
4bb523475d44 ("PackWriter: shed memory while creating bitmaps")
but failed as the instances were still held live here.

Switch to BlockList instead of ObjectToPack[]. This allows the
JVM to allocate many smaller arrays instead of one contiguous
array with 5.2M reference pointers. In a tight heap the smaller
allocations are more feasible.

Reduce the initial EWAHCompressedBitmaps for the 4 type maps.  On
average a typical repository is 30% commits, 30% trees and 30% blobs.
These bitmaps are typically very dense.  PackWriter orders objects by
commit, tree, blob when writing the file so these should always be a
very dense run of 1s with some 0s before and after. So even the 1/3rd
allocation is likely too large, but the later trim() will reduce the
internal buffer anyway.

Change-Id: If0b80a31cb00894f1485ff8f53ef7ae5a759a046

9 years agoCleanup Attributes and remove obsoleted Java7BasicAttributes class 51/53451/2
Andrey Loskutov [Sun, 9 Aug 2015 22:18:48 +0000 (00:18 +0200)]
Cleanup Attributes and remove obsoleted Java7BasicAttributes class

After jgit moved to Java 7 there is no need in an extra
Java7BasicAttributes class. Also all fields of Attributes can be made
final now.

Change-Id: I0be6daf7758189b0eecc4e26294bd278ed8bf7a0
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoMerge "Remove "experimental" from the description of the pack bitmap index"
Shawn Pearce [Thu, 13 Aug 2015 19:07:37 +0000 (15:07 -0400)]
Merge "Remove "experimental" from the description of the pack bitmap index"

9 years agoPackWriter: shed memory while creating bitmaps 78/53678/2
Shawn Pearce [Thu, 13 Aug 2015 05:58:26 +0000 (22:58 -0700)]
PackWriter: shed memory while creating bitmaps

Once bitmap creation begins the internal maps required for packing are
no longer necessary.  On a repository with 5.2M objects this can save
more than 438 MiB of memory by allowing the ObjectToPack instances to
get garbage collected away.

Downside is the PackWriter cannot be used for any further opertions
except to write the bitmap index.  This is an acceptable trade-off as
in practice nobody uses the PackWriter after the bitmaps are built.

Change-Id: Ibfaf84b22fa0590896a398ff659a91fcf03d7128

9 years agoMerge "Do not retain commit body during bitmap generation"
Shawn Pearce [Thu, 13 Aug 2015 16:09:03 +0000 (12:09 -0400)]
Merge "Do not retain commit body during bitmap generation"

9 years agoMerge "Bitmap builder: actually compress EWAH bitmaps in memory"
Shawn Pearce [Thu, 13 Aug 2015 16:08:29 +0000 (12:08 -0400)]
Merge "Bitmap builder: actually compress EWAH bitmaps in memory"

9 years agoBitmap builder: actually compress EWAH bitmaps in memory 79/53679/1
Shawn Pearce [Thu, 13 Aug 2015 06:18:24 +0000 (23:18 -0700)]
Bitmap builder: actually compress EWAH bitmaps in memory

For construction performance each new EWAHBitmap is allocated at the
roughly worst-case size the bitmap would need if all of the words must
be literal and no run length compression is available.  In practice
this is far larger than is required, wasting heap memory while the
bitmaps are computed.

Trim down each bitmap to its minimum required size. This copies the
internal array to a new smaller array, allowing the GC to reclaim the
prior larger array for reuse.

A single bitmap of 5.2M bits is only 79 KiB of memory without this
trim call but 15,000 such bitmaps is 1.1 GiB. Trimming can help fit
a larger number of bitmaps during processing.

Change-Id: I2bd19a786189db5b01c4c96f209b83de50e10c3b

9 years agoDo not retain commit body during bitmap generation 77/53677/1
Shawn Pearce [Thu, 13 Aug 2015 05:10:35 +0000 (22:10 -0700)]
Do not retain commit body during bitmap generation

The bitmap preparer only needs commit graph topology; it does not use
the message body.  Allow the RevWalk to free the body after the commit
has been parsed to save memory.

Change-Id: I97d4a440c9fc313873fd224bd05b9d9e3dc575db

9 years agoConsider original file mode while checking parent ignore rules 47/52547/4
Andrey Loskutov [Fri, 24 Jul 2015 21:26:43 +0000 (23:26 +0200)]
Consider original file mode while checking parent ignore rules

The WorkingTreeIterator.isEntryIgnored() should use originally requested
file mode while descending to the file tree root and checking ignore
rules. Original code asking isEntryIgnored() on a file was using
directory mode instead if the .gitignore was not located in the same
directory.

Bug: 473506
Change-Id: I9f16ba714c3ea9e6585e9c11623270dbdf4fb1df
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoChanged default log4j log level from "WARNING" to "WARN" 32/53532/1
Andrey Loskutov [Tue, 11 Aug 2015 07:58:57 +0000 (09:58 +0200)]
Changed default log4j log level from "WARNING" to "WARN"

Bug: 474674
Change-Id: I8be8934cf6cb3ee60567b59f8e836475efb780ac
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoClone should create Git instances which are able to close repository 94/53094/2
Andrey Loskutov [Mon, 3 Aug 2015 18:58:46 +0000 (20:58 +0200)]
Clone should create Git instances which are able to close repository

Bug: 474093
Change-Id: I13be133dac7834d1d2b51eb9948a716b8719d057
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoMerge "Clone should close repository after errors in fetch or checkout"
Christian Halstrick [Tue, 4 Aug 2015 11:34:20 +0000 (07:34 -0400)]
Merge "Clone should close repository after errors in fetch or checkout"

9 years agocontainsGitModulesFile() should not crash on bare repository 05/53005/3
Andrey Loskutov [Sat, 1 Aug 2015 15:03:11 +0000 (17:03 +0200)]
containsGitModulesFile() should not crash on bare repository

Change-Id: Iba7e4674b3d33c730613a6ac703977f48b015853
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoClone should close repository after errors in fetch or checkout 27/53027/1
Andrey Loskutov [Sun, 2 Aug 2015 21:46:09 +0000 (23:46 +0200)]
Clone should close repository after errors in fetch or checkout

Bug: 474093
Change-Id: Ia0a1478260b94a71a947aa8c04ee0c836d390aec
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoFixed javadoc: the getBranch() and getFullBranch() can return null 15/51015/5
Andrey Loskutov [Sun, 28 Jun 2015 18:34:57 +0000 (20:34 +0200)]
Fixed javadoc: the getBranch() and getFullBranch() can return null

Change-Id: I284a1b5f8220f68496f992b0e97e6934e03ae616
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoPushCertificate: Omit null pushee from text representation 37/52737/1
Dave Borowitz [Tue, 28 Jul 2015 17:53:07 +0000 (10:53 -0700)]
PushCertificate: Omit null pushee from text representation

Change-Id: Ie9546f2e0e9ee62e0a3c919572153b6076355195

9 years agoFix non-externalized string warning in Main.execute() 30/52530/1
Matthias Sohn [Fri, 24 Jul 2015 20:56:52 +0000 (22:56 +0200)]
Fix non-externalized string warning in Main.execute()

Change-Id: Ib0404daaf485aa6c8dc6ba0b169b46fb800325e4
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoHonor also https_proxy environment variable 86/52486/3
Christian Halstrick [Fri, 24 Jul 2015 12:05:37 +0000 (14:05 +0200)]
Honor also https_proxy environment variable

In addition to honor the http_proxy variable for setting a proxy for
http JGit should also honor the https_proxy variable to set a similar
proxy for https traffic

Bug: 473365
Change-Id: I1002cb575e26cd842bf81ad751ec7c267b585ce2
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoFix ResolveMerger when files should be replaced by folders 13/52213/3
Christian Halstrick [Sun, 19 Jul 2015 11:31:41 +0000 (13:31 +0200)]
Fix ResolveMerger when files should be replaced by folders

When during Merge for a certain path OURS & BASE contains a file and
THEIRS contains a folder there was a bug in JGit leading to unnecessary
conflicts. This commit fixes it and adds a test for this situation.

Bug: 472693
Change-Id: I71fac5a6a2ef926c01adc266c6f9b3275e870129
Also-by: Clemens Buchacher <drizzd@aon.at>
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoMerge "Fix typos in javadoc of ObjectId.equals()"
Matthias Sohn [Tue, 21 Jul 2015 22:37:51 +0000 (18:37 -0400)]
Merge "Fix typos in javadoc of ObjectId.equals()"

9 years agoDon't keep empty ignore rules in the ignore node list 19/52019/2
Andrey Loskutov [Wed, 15 Jul 2015 22:23:37 +0000 (00:23 +0200)]
Don't keep empty ignore rules in the ignore node list

Change-Id: Icd893dfaba06561bbe5cc60ebf866ec5d8301c22
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoAllow leading/trailing spaces in ignore rules 03/52003/3
Andrey Loskutov [Wed, 15 Jul 2015 19:07:35 +0000 (21:07 +0200)]
Allow leading/trailing spaces in ignore rules

According to [1] leading spaces are allowed in ignore rules and trailing
spaces are allowed too if they are escaped via backslash.

[1] https://www.kernel.org/pub/software/scm/git/docs/gitignore.html

Bug: 472762
Change-Id: I5e3ae5599cb9e5d80072f38c82c20cbc9475a18a
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoDon't crash while parsing ignore patterns 40/51940/3
Andrey Loskutov [Tue, 14 Jul 2015 22:01:14 +0000 (00:01 +0200)]
Don't crash while parsing ignore patterns

Catch unexpected PatternSyntaxException and convert it to
InvalidPatternException. Log such errors, do not silently ignore them.

Bug: 463581
Change-Id: Id0936d9816769ec0cfae1898beda0f7a3c146e67
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoAllow leading literal '#' and '!' in ignore rules if they are escaped 90/51890/4
Andrey Loskutov [Mon, 13 Jul 2015 22:05:49 +0000 (00:05 +0200)]
Allow leading literal '#' and '!' in ignore rules if they are escaped

According to [1] backslash can escape leading special characters '#' and
'!' in ignore rules, so that they are treated literally.

[1] https://www.kernel.org/pub/software/scm/git/docs/gitignore.html

Bug: 463581
Change-Id: I4c02927413a9c63ea5dbf2954877080d902ec1b2
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoDon't trim trailing space if it is escaped with backslash 89/51889/4
Andrey Loskutov [Mon, 13 Jul 2015 21:58:04 +0000 (23:58 +0200)]
Don't trim trailing space if it is escaped with backslash

According to [1] backslash can escape trailing space in ignore rules.

[1] https://www.kernel.org/pub/software/scm/git/docs/gitignore.html

Bug: 463581
Change-Id: I9cf13f8775cb49f0b6d61cfd3ca3fd6d665fccd8
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoConsider only escaping backslash for regular expressions in ignore rules 88/51888/4
Andrey Loskutov [Mon, 13 Jul 2015 21:54:57 +0000 (23:54 +0200)]
Consider only escaping backslash for regular expressions in ignore rules

While checking if we should consider an ignore rule without '[]'
brackets as a regular expression, check if the backslash escapes one of
the glob special characters '?', '*', '[', '\\'. If not, backslash is
not a part of a regex and should be treated literally.

Bug: 463581
Change-Id: I85208c7f85246fbf6c5029ce3c8b7bb8f4dbd947
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoRemove "experimental" from the description of the pack bitmap index 57/52257/1
Terry Parker [Mon, 20 Jul 2015 18:28:11 +0000 (11:28 -0700)]
Remove "experimental" from the description of the pack bitmap index

Change-Id: I940701093eb6c6d26e147b79de77997b0df481a0
Signed-off-by: Terry Parker <tparker@google.com>
9 years agoFix typos in javadoc of ObjectId.equals() 75/52175/2
Matthias Sohn [Fri, 17 Jul 2015 14:13:57 +0000 (16:13 +0200)]
Fix typos in javadoc of ObjectId.equals()

Change-Id: Ic2503a2c3c616934d923937fdf8ceb4ae57b7028
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoDFS: Remove now-redundant getOneRef 16/52116/1
Jonathan Nieder [Thu, 16 Jul 2015 21:50:42 +0000 (14:50 -0700)]
DFS: Remove now-redundant getOneRef

Instead of reimplementing exactRef in a separate, private method,
use it directly.

Change-Id: I0fc06fc46eef0e36e571a6ef622f38dc2aa59038

9 years agoDFS: Override exactRef() with optimal version 15/52115/1
Shawn Pearce [Thu, 16 Jul 2015 21:31:50 +0000 (14:31 -0700)]
DFS: Override exactRef() with optimal version

This avoids scanning a directory to find all names and
then weeding down to the requested name.

Change-Id: I36ce31febad6e881182bc3a278c7ed35cc04cbda

9 years agoPushCertificate: Add toTextWithSignature() method 23/52023/2
Dave Borowitz [Thu, 16 Jul 2015 01:07:06 +0000 (18:07 -0700)]
PushCertificate: Add toTextWithSignature() method

Change-Id: Ic0129373cc0c0321ffa43dc11a658d4f891ec2c2

9 years agoPushCertificateParser: Add fromString method 22/52022/1
Dave Borowitz [Thu, 16 Jul 2015 01:04:10 +0000 (18:04 -0700)]
PushCertificateParser: Add fromString method

Change-Id: I74c3f65a9ff297f708d996a4c138456a31a466b8

9 years agoBaseReceivePack: Add method to override the push cert 21/52021/1
Dave Borowitz [Thu, 16 Jul 2015 00:58:26 +0000 (17:58 -0700)]
BaseReceivePack: Add method to override the push cert

Change-Id: Id912f45c933c78a85b245fa7b6edebbeb40b009c

9 years agoBaseReceivePack: Don't throw from getPushCertificate() 20/52020/1
Dave Borowitz [Thu, 16 Jul 2015 00:55:17 +0000 (17:55 -0700)]
BaseReceivePack: Don't throw from getPushCertificate()

Rather than lazily parsing the push in this method, parse it at the
end of recvCommands(), which already contains the necessary try/catch
for handling this error. This allows later callers to avoid having to
handle this condition superfluously.

Change-Id: I5dcaf1a44bf4e321adc281e3381e7e17ac89db06

9 years agoPushCertificateStore: Return boolean from batch save methods 16/52016/2
Dave Borowitz [Wed, 15 Jul 2015 17:18:01 +0000 (10:18 -0700)]
PushCertificateStore: Return boolean from batch save methods

Change-Id: I9730cb4f60c60ee6d5a7a156a0b6a53f79309ec3

9 years agoAllow saving push certs on a subset of refs 74/51874/4
Dave Borowitz [Mon, 13 Jul 2015 19:03:42 +0000 (12:03 -0700)]
Allow saving push certs on a subset of refs

Consider a BatchRefUpdate produced by Gerrit Code Review, where the
original command pushed over the wire might refer to
"refs/for/master", but that command is ignored and replaced with some
additional commands like creating "refs/changes/34/1234/1". We do not
want to store the cert in "refs/for/master@{cert}", since that may
lead someone looking to the ref to the incorrect conclusion that that
ref exists.

Add a separate put method that takes a collection of commands, and
only stores certs on those refs that have a matching command in the
cert.

Change-Id: I4661bfe2ead28a2883b33a4e3dfe579b3157d68a

9 years agoUpdate org.apache.httpcomponents 94/51894/1
Matthias Sohn [Mon, 13 Jul 2015 23:55:58 +0000 (01:55 +0200)]
Update org.apache.httpcomponents

- update org.apache.httpcomponents.httpcore to 4.3.3
- update org.apache.httpcomponents.httpclient to 4.3.6, 4.3.5 and later
  are reported to fix vulnerability CVE-2014-3577

CQ: 9220
CQ: 9221
Bug: 470523
Change-Id: I39b80b250c6c1daede6a23e9f177fb2988ac37bb
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoAccess static member LocalDiskRepositoryTestCase.CONTENT directly 60/51860/2
Matthias Sohn [Mon, 13 Jul 2015 15:06:54 +0000 (17:06 +0200)]
Access static member LocalDiskRepositoryTestCase.CONTENT directly

37a1e4be moved this constant causing the following error message in
Eclipse: "The static field LocalDiskRepositoryTestCase.CONTENT should be
accessed directly".

Change-Id: I4ceb57a30f2e5a8f7e55109ef260a244ed5e7044
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoPushCertificateStore: Add method to save in batch 66/51866/2
Dave Borowitz [Sat, 11 Jul 2015 00:12:54 +0000 (17:12 -0700)]
PushCertificateStore: Add method to save in batch

Change-Id: I8bfaee1a52d368ffe2cd7e8af1754a5261569078

9 years agoFixed @since tags on new API 01/51801/1
Andrey Loskutov [Sun, 12 Jul 2015 16:44:08 +0000 (18:44 +0200)]
Fixed @since tags on new API

Change-Id: I77bc2ec486ffe4c8b864663d103d8cf39c3f35e1
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
9 years agoStore push certificates in refs/meta/push-certs 28/51128/13
Dave Borowitz [Tue, 30 Jun 2015 01:05:11 +0000 (18:05 -0700)]
Store push certificates in refs/meta/push-certs

Inspired by a proposal from gitolite[1], where we store a file in
a tree for each ref name, and the contents of the file is the latest
push cert to affect that ref.

The main modification from that proposal (other than lacking the
out-of-git batching) is to append "@{cert}" to filenames, which allows
storing certificates for both refs/foo and refs/foo/bar. Those
refnames cannot coexist at the same time in a repository, but we do
not want to discard the push certificate responsible for deleting the
ref, which we would have to do if refs/foo in the push cert tree
changed from a tree to a blob.

The "@{cert}" syntax is at least somewhat consistent with
gitrevisions(7) wherein @{...} describe operators on ref names.

As we cannot (currently) atomically update the push cert ref with the
refs that were updated, this operation is inherently racy. Kick the can
down the road by pushing this burden on callers.

[1] https://github.com/sitaramc/gitolite/blob/cf062b8bb6b21a52f7c5002d33fbc950762c1aa7/contrib/hooks/repo-specific/save-push-signatures

Change-Id: Id3eb32416f969fba4b5e4d9c4b47053c564b0ccd

9 years agoAdd setTargetBranch in RepoCommand. 96/51696/3
Yuxuan 'fishy' Wang [Fri, 10 Jul 2015 05:12:28 +0000 (22:12 -0700)]
Add setTargetBranch in RepoCommand.

This will allow us to write the super project in a branch other than
master.

Change-Id: I578ed9ecbc6423416239e31ad644531dae9fb5c3
Signed-off-by: Yuxuan 'fishy' Wang <fishywang@google.com>
9 years agoMove `RepositoryTestCase.indexState` to parent class 15/51615/2
Chris Price [Tue, 7 Jul 2015 12:06:50 +0000 (13:06 +0100)]
Move `RepositoryTestCase.indexState` to parent class

The test helper method `indexState` in `RepositoryTestCase` is
very useful for writing tests, even in cases where we need to
do things like create more than one repository for a test and
thus we don't want to use the built-in `db` member variable that
exists in `RepositoryTestCase`.  Since the method is static,
we can move it up to the parent class `LocalDiskRepositoryTestCase`,
where it can be used by tests that aren't a great fit for inheriting
directly from `RepositoryTestCase`.

Bug: 436200
Change-Id: I2b6de75c001d2d77ddb607488af246548784a67f
Signed-off-by: Chris Price <chris@puppetlabs.com>
9 years agoChange `indexState` to static method 14/51614/2
Chris Price [Tue, 7 Jul 2015 11:43:56 +0000 (12:43 +0100)]
Change `indexState` to static method

The `indexState` method is no longer referring to any
member variables from the class, so it can be made static.

Bug: 436200
Change-Id: I013316de5c373417ea758ca6e17da29209fead53
Signed-off-by: Chris Price <chris@puppetlabs.com>
9 years agoMerge "Use local variable in RepositoryTestCase.indexState"
Christian Halstrick [Thu, 9 Jul 2015 22:27:38 +0000 (18:27 -0400)]
Merge "Use local variable in RepositoryTestCase.indexState"

9 years agoPushCertificateParser: Move reader parsing to instance method 30/51630/3
Dave Borowitz [Thu, 9 Jul 2015 01:42:28 +0000 (18:42 -0700)]
PushCertificateParser: Move reader parsing to instance method

Change-Id: I8ab5fb97303e25b28187375b6f9ff28f918bdd43

9 years agoPushCertificateParser: Make constructor public 29/51629/3
Dave Borowitz [Thu, 9 Jul 2015 01:41:32 +0000 (18:41 -0700)]
PushCertificateParser: Make constructor public

Primarily to aid in writing end-to-end tests, which must be written
outside this package as we don't currently have a Bouncy Castle
dependency.

Change-Id: Ia24179773140d9ecc616b3a6b2e630c85d800157

9 years agoReport PackProtocolExceptions to client during receive-pack 09/51209/6
Dave Borowitz [Wed, 1 Jul 2015 18:24:25 +0000 (11:24 -0700)]
Report PackProtocolExceptions to client during receive-pack

We have done this since forever with the "wanted old new ref" error,
so let's do it for other such errors thrown in the same block as well.

Change-Id: Ib3b1c7f05e31a5b3e40e85eb07b16736920a033b

9 years agoPushCertificate: implement hashCode/equals/toString 04/51204/7
Dave Borowitz [Wed, 1 Jul 2015 16:42:35 +0000 (09:42 -0700)]
PushCertificate: implement hashCode/equals/toString

Change-Id: Ib588a3f47492cee5e5e6274a3b088678919a0fa0

9 years agoPushCertificateParser: Make pushee optional 08/51208/9
Dave Borowitz [Wed, 1 Jul 2015 18:44:09 +0000 (11:44 -0700)]
PushCertificateParser: Make pushee optional

When pushing to an HTTP server using the C git client, I observed a
certificate lacking a pushee field. Handle this gracefully in the
parser.

Change-Id: I7f3c5fa78f2e35172a93180036e679687415cac4

9 years agoPushCertificateParser: Change error string for invalid field 07/51207/8
Dave Borowitz [Wed, 1 Jul 2015 18:29:09 +0000 (11:29 -0700)]
PushCertificateParser: Change error string for invalid field

The old one didn't take an argument; the new one includes the field
name.

Change-Id: I175dc75dcdd05ba6fdec315c04c79550cfdc2342

9 years agoPushCertificateParser: Add method for parsing from a stream 27/51127/11
Dave Borowitz [Tue, 30 Jun 2015 00:26:57 +0000 (17:26 -0700)]
PushCertificateParser: Add method for parsing from a stream

We intend to store received push certificates somewhere, like a
particular ref in the repository in question. For reading data back
out, it will be useful to read push certificates (without pkt-line
framing) in a streaming fashion.

Change-Id: I70de313b1ae463407b69505caee63e8f4e057ed4

9 years agoIO: Add a method for reading lines 26/51126/8
Dave Borowitz [Tue, 30 Jun 2015 00:26:39 +0000 (17:26 -0700)]
IO: Add a method for reading lines

Change-Id: Ib7be76aa7ac889354ad4782e2b64d4221a0e25b9

9 years agoBaseReceivePack: Treat all LFs as optional 36/51436/3
Dave Borowitz [Mon, 6 Jul 2015 19:19:42 +0000 (15:19 -0400)]
BaseReceivePack: Treat all LFs as optional

Discussion on the git mailing list has concluded[1] that the intended
behavior for all (non-sideband) portions of the receive-pack protocol
is for trailing LFs in pkt-lines to be optional. Go back to using
PacketLineIn#readString() everywhere.

For push certificates specifically, we agreed that the payload signed
by the client is always concatenated with LFs even though the client
MAY omit LFs when framing the certificate for the wire. This is still
reflected in the implementation of PushCertificate#toText().

[1] http://thread.gmane.org/gmane.comp.version-control.git/273175/focus=273412

Change-Id: I817231c4d4defececb8722142fea18ff42e06e44

9 years agoBaseReceivePack: More validation during parseCommand 73/51073/5
Dave Borowitz [Mon, 29 Jun 2015 23:00:53 +0000 (16:00 -0700)]
BaseReceivePack: More validation during parseCommand

Change-Id: I25f3a5582a45dd0ec8f78f5daf74c2203797a184

9 years agoUse local variable in RepositoryTestCase.indexState 75/51475/1
Chris Price [Tue, 7 Jul 2015 11:30:06 +0000 (12:30 +0100)]
Use local variable in RepositoryTestCase.indexState

There is a signature of the test helper method `indexState`,
in `RepositoryTestCase`, that accepts a `Repository` object
as an argument.  However, there was one line of code where
this variable was not being used, and the method was instead
referring to a member variable `db`.  I believe this was
probably just an oversight in a previous refactor, and
that the correct behavior is to use the variable from
the argument list.  This change also has the benefit
of making it possible to convert this method to a static
method, since it no longer relies on any state from the class.

Bug: 436200
Change-Id: Iac95b046dc5bd0b3756642e241c3637f1fad3609
Signed-off-by: Chris Price <chris@puppetlabs.com>
9 years agoFix non-escaped quotes in JGitText.properties 66/51366/3
Matthias Sohn [Fri, 3 Jul 2015 23:08:59 +0000 (01:08 +0200)]
Fix non-escaped quotes in JGitText.properties

In most texts we use "cannot" hence instead of escaping the apostroph in
"can't" use "cannot".

Bug: 471796
Change-Id: Icda5b4db38076789d06498428909306aef3cb68b
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoThrow InvalidObjectIdException from ObjectId.fromString("tooshort") 44/51144/3
Jonathan Nieder [Tue, 30 Jun 2015 21:42:39 +0000 (14:42 -0700)]
Throw InvalidObjectIdException from ObjectId.fromString("tooshort")

ObjectId.fromString already throws InvalidObjectIdException for most
malformed object ids, but for this kind it previously threw
IllegalArgumentException.  Since InvalidObjectIdException is a child of
IllegalArgumentException, callers that catch IllegalArgumentException
will continue to work.

Change-Id: I24e1422d51607c86a1cb816a495703279e461f01
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoAvoid double-colon in InvalidObjectIdException description 43/51143/2
Jonathan Nieder [Tue, 30 Jun 2015 21:34:02 +0000 (14:34 -0700)]
Avoid double-colon in InvalidObjectIdException description

The invalidId message in JGitText and the asAscii bad id both contain a
colon, so the resulting message would say

Invalid id: : a78987c98798ufa

Fix it by keeping the colon in the translated message and not adding
another colon programmatically.

Noticed by code inspection.

Change-Id: I13972eebde27a4128828e6c64517666f0ba6288b
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoCompare API against 4.0.0.201506090130-r 09/50809/1
Matthias Sohn [Wed, 24 Jun 2015 13:14:54 +0000 (15:14 +0200)]
Compare API against 4.0.0.201506090130-r

Change-Id: I7cb7e89875b5238a54411b8c43c298d4cbe9f7ac
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoMerge branch 'stable-4.0' 95/50795/1
Matthias Sohn [Wed, 24 Jun 2015 12:46:51 +0000 (14:46 +0200)]
Merge branch 'stable-4.0'

Change-Id: I5c965206ad10bababe366a51ab7c33a8836a7868
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoPrepare 4.0.2-SNAPSHOT builds 84/50784/1
Matthias Sohn [Wed, 24 Jun 2015 11:51:21 +0000 (13:51 +0200)]
Prepare 4.0.2-SNAPSHOT builds

Change-Id: I645cacfdde21aa28aa2e17c10dec0576b170ed0e
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoJGit v4.0.1.201506240215-r 61/50761/1 v4.0.1.201506240215-r
Matthias Sohn [Wed, 24 Jun 2015 06:17:29 +0000 (08:17 +0200)]
JGit v4.0.1.201506240215-r

Change-Id: Ib7713b657e7812b0debd72bb4eece0daa187e80d
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoAPI to remove repositories from RepositoryCache 38/50238/3
Tobias Oberlies [Tue, 16 Jun 2015 08:14:44 +0000 (10:14 +0200)]
API to remove repositories from RepositoryCache

Add methods that allow to unregister repositories from the
RepositoryCache individually.

Bug: 470234
Change-Id: Ib918a634d829c9898072ae7bdeb22b099a32b1c9
Signed-off-by: Tobias Oberlies <tobias.oberlies@sap.com>
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoAdd a grace period for packfiles during GC 30/50230/2
Christian Halstrick [Fri, 12 Jun 2015 23:38:29 +0000 (01:38 +0200)]
Add a grace period for packfiles during GC

For loose objects an expiration date can be set which will save too
young objects from being deleted. Add the same for packfiles. Packfiles
which are too young are not deleted.

Bug: 468024
Change-Id: I3956411d19b47aaadc215dab360d57fa6c24635e
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoSignedPushConfig: Allow setting a custom nonce generator impl 61/50461/1
Dave Borowitz [Thu, 18 Jun 2015 17:07:37 +0000 (13:07 -0400)]
SignedPushConfig: Allow setting a custom nonce generator impl

Change-Id: Ic0156a7d65d99881ef27801fcce7754594c436f0

9 years agoPackCertificateParser: return null if nothing was received 51/50451/2
Dave Borowitz [Thu, 18 Jun 2015 14:55:16 +0000 (10:55 -0400)]
PackCertificateParser: return null if nothing was received

Add test for this case in both the enabled and disabled cases.

Change-Id: If9d12192a2dc9f9dd1eac9844b5a7b0edadc0b34

9 years agoInclude push certificates in RefUpdate 47/50447/2
Dave Borowitz [Thu, 18 Jun 2015 14:14:48 +0000 (10:14 -0400)]
Include push certificates in RefUpdate

This may be used by e.g. a custom reflog implementation to record
this information along with the ref update.

Change-Id: I44adbfad704b76f9c1beced6e1ce82eaf71410d2

9 years agoRemove redundant @since tags in new signed push classes 46/50446/1
Dave Borowitz [Thu, 18 Jun 2015 14:18:38 +0000 (10:18 -0400)]
Remove redundant @since tags in new signed push classes

Change-Id: I9f57318a59f668906b80f67230d36ba6439fc7b4

9 years agoAdd a separate type for the identity in a push certificate 94/50394/4
Dave Borowitz [Wed, 17 Jun 2015 17:12:22 +0000 (13:12 -0400)]
Add a separate type for the identity in a push certificate

These differ subtly from a PersonIdent, because they can contain
anything that is a valid User ID passed to gpg --local-user. Upstream
git push --signed will just take the configuration value from
user.signingkey and pass that verbatim in both --local-user and the
pusher field of the certificate. This does not necessarily contain an
email address, which means the parsing implementation ends up being
substantially different from RawParseUtils.parsePersonIdent.
Nonetheless, we try hard to match PersonIdent behavior in
questionable cases.

Change-Id: I37714ce7372ccf554b24ddbff56aa61f0b19cbae

9 years agoPushCertificateParser: include begin/end lines in signature 96/50296/6
Dave Borowitz [Mon, 15 Jun 2015 20:50:22 +0000 (16:50 -0400)]
PushCertificateParser: include begin/end lines in signature

The signature is intended to be passed to a verification library such
as Bouncy Castle, which expects these lines to be present in order to
parse the signature.

Change-Id: I22097bead2746da5fc53419f79761cafd5c31c3b

9 years agoPushCertificateParser: throw PackProtocolException in more cases 95/50295/6
Dave Borowitz [Mon, 15 Jun 2015 19:48:22 +0000 (15:48 -0400)]
PushCertificateParser: throw PackProtocolException in more cases

This is the subclass of IOException already thrown by
BaseReceivePack#recvCommands when encountering an invalid value on
the wire. That's what PushCertificateParser is doing too, so use the
same subclass.

Change-Id: I1d323909ffe70757ea56e511556080695b1a0c11

9 years agoExtract a class for signed push configuration 94/50294/6
Dave Borowitz [Mon, 15 Jun 2015 19:25:14 +0000 (15:25 -0400)]
Extract a class for signed push configuration

The default behavior is to read a repository's signed push
configuration from that repo's config file, but this is not very
flexible when it comes to managing groups of repositories (e.g. with
Gerrit). Allow callers to override the configuration using a POJO.

Change-Id: Ib8f33e75daa0b2fbd000a2c4558c01c014ab1ce5

9 years agoBaseReceivePack: fix reading cert lines in command loop 93/50293/4
Dave Borowitz [Mon, 15 Jun 2015 18:54:13 +0000 (14:54 -0400)]
BaseReceivePack: fix reading cert lines in command loop

Add a missing continues to prevent falling through to the command
parsing section. The first continue happens when the command list is
empty, so change the condition to see whether we have read the first
line, rather than any commands.

Fix comparison to BEGIN_SIGNATURE to use raw line with newline.

Change-Id: If3d92f5ceade8ba7605847a4b2bc55ff17d119ac

9 years agoSilence API warnings introduced by a85e817d 95/50395/1
Matthias Sohn [Wed, 17 Jun 2015 21:08:45 +0000 (23:08 +0200)]
Silence API warnings introduced by a85e817d

a85e817d is a slightly breaking API change to classes that were
technically public and technically released in 4.0. However, it is
highly unlikely that people were actually depending on public behavior,
since there were no public methods to create PushCertificates with
anything other than null field values, or a PushCertificateParser that
did anything other than infinite loop or throw exceptions when reading.

Change-Id: I1d0ba9ea0a347e8ff5a0f4af169d9bb18c5838d2
Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
9 years agoUpdate comments about PackStatistics 91/50291/1
Terry Parker [Tue, 16 Jun 2015 17:05:29 +0000 (10:05 -0700)]
Update comments about PackStatistics

Change-Id: I4862932dc38b58cc98400ed584cc506013846065
Signed-off-by: Terry Parker <tparker@google.com>
9 years agoAdd the set of shallow commits to PackStatistics 21/50221/2
Terry Parker [Mon, 15 Jun 2015 21:45:12 +0000 (14:45 -0700)]
Add the set of shallow commits to PackStatistics

Change-Id: I976102e054369b045340d4b9209984b5243e3750
Signed-off-by: Terry Parker <tparker@google.com>
9 years agoAdd tests for HMACSHA1NonceGenerator 83/50183/2
Dave Borowitz [Mon, 15 Jun 2015 14:14:59 +0000 (10:14 -0400)]
Add tests for HMACSHA1NonceGenerator

Correct documentation of NonceStatus.OK/SLOP to match the implemented
behavior.

Change-Id: Id5ec1945eab76db6d2e4b592cb25907ea3d835cd

9 years agoMerge "Introduce PostUploadHook to replace UploadPackLogger"
Shawn Pearce [Fri, 12 Jun 2015 21:21:38 +0000 (17:21 -0400)]
Merge "Introduce PostUploadHook to replace UploadPackLogger"

9 years agoIntroduce PostUploadHook to replace UploadPackLogger 30/50130/5
Terry Parker [Fri, 12 Jun 2015 19:00:36 +0000 (12:00 -0700)]
Introduce PostUploadHook to replace UploadPackLogger

UploadPackLogger is incorrectly named--it can be used to trigger any
post upload action, such as GC/compaction. This change introduces
PostUploadHook/PostUploadHookChain to replace
UploadPackLogger/UploadPackLoggerChain and deprecates the latter.

It also introduces PackStatistics as a replacement for
PackWriter.Statistics, since the latter is not public API.
It changes PackWriter to use PackStatistics and reimplements
PackWriter.Statistics to delegate to PackStatistics.

Change-Id: Ic51df1613e471f568ffee25ae67e118425b38986
Signed-off-by: Terry Parker <tparker@google.com>
9 years agoTreat CloneCommand.setBranch(null) as setBranch("HEAD") 78/49978/2
Jonathan Nieder [Wed, 10 Jun 2015 22:43:48 +0000 (15:43 -0700)]
Treat CloneCommand.setBranch(null) as setBranch("HEAD")

This method is documented to take a branch name (not a possibly null
string).  The only way a caller could have set null without either
re-setting to a sane value afterward or producing NullPointerException
was to also call setNoCheckout(true), in which case there would have
been no reason to set the branch in the first place.

Make setBranch(null) request the default behavior (remote's default
branch) instead, imitating C git's clone --no-branch.

Change-Id: I960e7046b8d5b5bc75c7f3688f3a075d3a951b00
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoTreat CloneCommand.setRemote(null) as setRemote("origin") 77/49977/2
Jonathan Nieder [Wed, 10 Jun 2015 22:43:27 +0000 (15:43 -0700)]
Treat CloneCommand.setRemote(null) as setRemote("origin")

A non-bare clone command with null remote produces a
NullPointerException when trying to produce a refspec to fetch against.

In a bare repository, a null remote name is accepted by mistake,
producing a configuration with items like 'remote.url' instead of
'remote.<remote>.url'.  This was never meant to work.

Instead, let's make setRemote(null) undo any previous setRemote calls
and re-set the remote name to DEFAULT_REMOTE, imitating C git clone's
--no-origin option.

While we're here, add some tests for setRemote working normally.

Change-Id: I76f502da5e677df501d3ef387e7f61f42a7ca238
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoDocument CloneCommand.setURI(null) 76/49976/2
Jonathan Nieder [Wed, 10 Jun 2015 22:11:39 +0000 (15:11 -0700)]
Document CloneCommand.setURI(null)

call() throws InvalidRemoteException if uri == null, so there should
never be reason to leave the URI set to null.  Document this.

Change-Id: I7f2cdbe8042d99cf8a3c1a8c4c2dcb58c5b8c305
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoHandle null in ProgressMonitor setters 80/49980/2
Jonathan Nieder [Wed, 10 Jun 2015 20:59:48 +0000 (13:59 -0700)]
Handle null in ProgressMonitor setters

These commands' monitor fields can never be null unless someone passes
null to setProgressMonitor.  Anyone passing null probably meant to
disable the ProgressMonitor, so do that (by falling back to
NullProgressMonitor.INSTANCE) instead of saving a null and eventually
producing NullPointerException.

Change-Id: I63ad93ea8ad669fd333a5fd40880e7583ba24827
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoDocument CloneCommand.setDirectory(null) and setGitDir(null) more clearly 79/49979/2
Jonathan Nieder [Wed, 10 Jun 2015 22:52:34 +0000 (15:52 -0700)]
Document CloneCommand.setDirectory(null) and setGitDir(null) more clearly

Change-Id: I74757ca68eaa941833846a7c8d983b4e996fa207
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoRequire all projects to have a name 81/49981/3
Jonathan Nieder [Wed, 10 Jun 2015 23:35:43 +0000 (16:35 -0700)]
Require all projects to have a name

A project's name attribute is required according to repo's
doc/manifest-format.txt:

    <!ELEMENT project (annotation*,
                       project*)>
    <!ATTLIST project name        CDATA #REQUIRED>

Enforcing this in code makes reading easier (in particular making it
clearer that getName() and getPath() can never return null).

Change-Id: I8c7014dd6042183d7fecb2202af5acdc384aa8e4
Signed-off-by: Jonathan Nieder <jrn@google.com>
9 years agoMerge topic 'push-cert-2'
Dave Borowitz [Thu, 11 Jun 2015 17:07:42 +0000 (13:07 -0400)]
Merge topic 'push-cert-2'

* changes:
  Rewrite push certificate parsing
  Allow trailing newlines in receive-pack

9 years agoRewrite push certificate parsing 66/49966/7
Dave Borowitz [Wed, 10 Jun 2015 00:23:03 +0000 (17:23 -0700)]
Rewrite push certificate parsing

- Consistently return structured data, such as actual ReceiveCommands,
  which is more useful for callers that are doing things other than
  verifying the signature, e.g. recording the set of commands.
- Store the certificate version field, as this is required to be part
  of the signed payload.
- Add a toText() method to recreate the actual payload for signature
  verification. This requires keeping track of the un-chomped command
  strings from the original protocol stream.
- Separate the parser from the certificate itself, so the actual
  PushCertificate object can be immutable. Make a fair attempt at deep
  immutability, but this is not possible with the current mutable
  ReceiveCommand structure.
- Use more detailed error messages that don't involve NON-NLS strings.
- Document null return values more thoroughly. Instead of having the
  undocumented behavior of throwing NPE from certain methods if they
  are not first guarded by enabled(), eliminate enabled() and return
  null from those methods.
- Add tests for parsing a push cert from a section of pkt-line stream
  using a real live stream captured with Wireshark (which, it should
  be noted, uncovered several simply incorrect statements in C git's
  Documentation/technical/pack-protocol.txt).

This is a slightly breaking API change to classes that were
technically public and technically released in 4.0. However, it is
highly unlikely that people were actually depending on public
behavior, since there were no public methods to create
PushCertificates with anything other than null field values, or a
PushCertificateParser that did anything other than infinite loop or
throw exceptions when reading.

Change-Id: I5382193347a8eb1811032d9b32af9651871372d0

9 years agoMerge "submodule test: Use config.unset instead of setting to null"
Christian Halstrick [Thu, 11 Jun 2015 11:44:33 +0000 (07:44 -0400)]
Merge "submodule test: Use config.unset instead of setting to null"

9 years agoMerge "Add new submodule layout to SubmoduleAddCommand"
Christian Halstrick [Thu, 11 Jun 2015 09:13:21 +0000 (05:13 -0400)]
Merge "Add new submodule layout to SubmoduleAddCommand"

9 years agoAllow trailing newlines in receive-pack 65/49965/5
Dave Borowitz [Wed, 10 Jun 2015 19:47:04 +0000 (12:47 -0700)]
Allow trailing newlines in receive-pack

C git's receive-pack.c strips trailing newlines in command lists when
present[1], although send-pack.c does not send them, at least in the
case of command lists[2]. Change JGit to match this behavior.
Add tests.

This also fixes parsing of commands in the push cert, which, unlike
commands sent in the non-push case, always have trailing newlines.

[1] https://github.com/git/git/blob/7974889a053574e449b55ca543a486e38e74864f/builtin/receive-pack.c#L1380
where packet_read_line chomps newlines:
https://github.com/git/git/blob/7974889a053574e449b55ca543a486e38e74864f/pkt-line.c#L202

[2] https://github.com/git/git/blob/7974889a053574e449b55ca543a486e38e74864f/send-pack.c#L470

Change-Id: I4bca6342a7482a53c9a5815a94b3c181a479d04b