summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Aniszczyk <caniszczyk@gmail.com>2011-01-26 12:17:47 -0500
committerCode Review <codereview-daemon@eclipse.org>2011-01-26 12:17:47 -0500
commit9b8ac0151ea1c74ccb04883aa280f4800b53ea64 (patch)
tree477d08521bf39a89d226dff63e3e354cf3787792
parent257315d80e1645435371f926adcad48c6e11a1ba (diff)
parent85f69c286b6c3225dcff05aba42910daefb28da0 (diff)
downloadjgit-9b8ac0151ea1c74ccb04883aa280f4800b53ea64.tar.gz
jgit-9b8ac0151ea1c74ccb04883aa280f4800b53ea64.zip
Merge "MergeCommand should create missing branches"
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/api/MergeCommand.java27
1 files changed, 25 insertions, 2 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/api/MergeCommand.java b/org.eclipse.jgit/src/org/eclipse/jgit/api/MergeCommand.java
index 42e1a51ac9..29ce00e448 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/api/MergeCommand.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/api/MergeCommand.java
@@ -131,7 +131,6 @@ public class MergeCommand extends GitCommand<MergeResult> {
// Check for FAST_FORWARD, ALREADY_UP_TO_DATE
revWalk = new RevWalk(repo);
- RevCommit headCommit = revWalk.lookupCommit(head.getObjectId());
// we know for now there is only one commit
Ref ref = commits.get(0);
@@ -144,6 +143,30 @@ public class MergeCommand extends GitCommand<MergeResult> {
objectId = ref.getObjectId();
RevCommit srcCommit = revWalk.lookupCommit(objectId);
+
+ ObjectId headId = head.getObjectId();
+ if (headId == null) {
+ revWalk.parseHeaders(srcCommit);
+ DirCacheCheckout dco = new DirCacheCheckout(repo,
+ repo.lockDirCache(), srcCommit.getTree());
+ dco.setFailOnConflict(true);
+ dco.checkout();
+ RefUpdate refUpdate = repo
+ .updateRef(head.getTarget().getName());
+ refUpdate.setNewObjectId(objectId);
+ refUpdate.setExpectedOldObjectId(null);
+ refUpdate.setRefLogMessage("initial pull", false);
+ if (refUpdate.update() != Result.NEW)
+ throw new NoHeadException(
+ JGitText.get().commitOnRepoWithoutHEADCurrentlyNotSupported);
+ setCallable(false);
+ return new MergeResult(srcCommit, srcCommit, new ObjectId[] {
+ null, srcCommit }, MergeStatus.FAST_FORWARD,
+ mergeStrategy, null, null);
+ }
+
+ RevCommit headCommit = revWalk.lookupCommit(headId);
+
if (revWalk.isMergedInto(srcCommit, headCommit)) {
setCallable(false);
return new MergeResult(headCommit, srcCommit, new ObjectId[] {
@@ -159,7 +182,7 @@ public class MergeCommand extends GitCommand<MergeResult> {
dco.setFailOnConflict(true);
dco.checkout();
- updateHead(refLogMessage, srcCommit, head.getObjectId());
+ updateHead(refLogMessage, srcCommit, headId);
setCallable(false);
return new MergeResult(srcCommit, srcCommit, new ObjectId[] {
headCommit, srcCommit }, MergeStatus.FAST_FORWARD,