summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorTerry Parker <tparker@google.com>2018-06-26 16:44:01 -0700
committerTerry Parker <tparker@google.com>2018-06-26 20:13:47 -0700
commit115a740e2fa65d3ab70f150691b045ecfdb146bb (patch)
treea305a363901e9d79437353fa74a120aa4aa32577 /tools
parente8e4fe7af674baf13acd074f7207d7e6758d0ec6 (diff)
downloadjgit-115a740e2fa65d3ab70f150691b045ecfdb146bb.tar.gz
jgit-115a740e2fa65d3ab70f150691b045ecfdb146bb.zip
Correctly handle initialization of shallow commits
In a new RevWalk, if the first object parsed is one of the shallow commits, the following happens: 1) RevCommit.parseCanonical() is called on a new "r1" RevCommit. 2) RevCommit.parseCanonical() immediately calls RevWalk.initializeShallowCommits(). 3) RevWalk.initializeShallowCommits() calls lookupCommit(id), creating and adding a new "r2" version of this same object and marking its parents empty. 4) RevCommit.parseCanonical() initializes the "r1" RevCommit's fields, including the parents. 5) RevCommit.parseCanonical()'s caller uses the "r1" commit that has parents, losing the fact that it is a shallow commit. This change passes the current RevCommit as an argument to RevWalk.initializeShallowCommits() so that method can set its parents empty rather than creating the duplicate "r2" commit. Change-Id: I67b79aa2927dd71ac7b0d8f8917f423dcaf08c8a Signed-off-by: Terry Parker <tparker@google.com>
Diffstat (limited to 'tools')
0 files changed, 0 insertions, 0 deletions