Author: mreutegg
Date: Wed Jul 13 15:57:28 2016
New Revision: 1752448

URL: http://svn.apache.org/viewvc?rev=1752448&view=rev
Log:
OAK-4556: Track branch on newBranchCommit()

Modified:
    
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/Commit.java
    
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
    
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/MergeCommit.java
    
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/UnsavedModifications.java
    
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java

Modified: 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/Commit.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/Commit.java?rev=1752448&r1=1752447&r2=1752448&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/Commit.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/Commit.java
 Wed Jul 13 15:57:28 2016
@@ -59,7 +59,6 @@ public class Commit {
     private static final Logger LOG = LoggerFactory.getLogger(Commit.class);
 
     protected final DocumentNodeStore nodeStore;
-    private final DocumentNodeStoreBranch branch;
     private final RevisionVector baseRevision;
     private final Revision revision;
     private final HashMap<String, UpdateOp> operations = new 
LinkedHashMap<String, UpdateOp>();
@@ -85,18 +84,13 @@ public class Commit {
      * @param revision the revision for this commit.
      * @param baseRevision the base revision for this commit or {@code null} if
      *                     there is none.
-     * @param branch the branch associated with this commit or {@code null} if
-     *               there is none.
-     *                              
      */
     Commit(@Nonnull DocumentNodeStore nodeStore,
            @Nonnull Revision revision,
-           @Nullable RevisionVector baseRevision,
-           @Nullable DocumentNodeStoreBranch branch) {
+           @Nullable RevisionVector baseRevision) {
         this.nodeStore = checkNotNull(nodeStore);
         this.revision = checkNotNull(revision);
         this.baseRevision = baseRevision;
-        this.branch = branch;
     }
 
     UpdateOp getUpdateOperationForNode(String path) {
@@ -179,28 +173,13 @@ public class Commit {
         boolean isBranch = baseRev != null && baseRev.isBranch();
         Revision rev = getRevision();
         if (isBranch && !nodeStore.isDisableBranches()) {
-            rev = rev.asBranchRevision();
-            // remember branch commit
-            Branch b = nodeStore.getBranches().getBranch(baseRev);
-            if (b == null) {
-                // baseRev is marker for new branch
-                b = nodeStore.getBranches().create(
-                        baseRev.asTrunkRevision(), rev, branch);
-                LOG.debug("Branch created with base revision {} and " +
-                        "modifications on {}", baseRevision, 
operations.keySet());
-                if (LOG.isTraceEnabled()) {
-                    LOG.trace("Branch created", new Exception());
-                }
-            } else {
-                b.addCommit(rev);
-            }
             try {
                 // prepare commit
                 prepare(baseRev);
                 success = true;
             } finally {
                 if (!success) {
-                    b.removeCommit(rev);
+                    b.removeCommit(rev.asBranchRevision());
                     if (!b.hasCommits()) {
                         nodeStore.getBranches().remove(b);
                     }

Modified: 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java?rev=1752448&r1=1752447&r2=1752448&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
 Wed Jul 13 15:57:28 2016
@@ -501,7 +501,7 @@ public final class DocumentNodeStore
         if (rootDoc == null) {
             // root node is missing: repository is not initialized
             Revision commitRev = newRevision();
-            Commit commit = new Commit(this, commitRev, null, null);
+            Commit commit = new Commit(this, commitRev, null);
             RevisionVector head = new RevisionVector(commitRev);
             DocumentNodeState n = new DocumentNodeState(this, "/", head);
             commit.addNode(n);
@@ -771,6 +771,11 @@ public final class DocumentNodeStore
             } finally {
                 backgroundOperationLock.readLock().unlock();
             }
+        } else {
+            Branch b = branches.getBranch(c.getBaseRevision());
+            if (b != null) {
+                b.removeCommit(c.getRevision().asBranchRevision());
+            }
         }
     }
 
@@ -2219,7 +2224,7 @@ public final class DocumentNodeStore
         Commit c;
         try {
             checkOpen();
-            c = new Commit(this, commitQueue.createRevision(), base, null);
+            c = new Commit(this, commitQueue.createRevision(), base);
             success = true;
         } finally {
             if (!success) {
@@ -2236,7 +2241,23 @@ public final class DocumentNodeStore
                 "base must be a branch revision: " + base);
 
         checkOpen();
-        return new Commit(this, newRevision(), base, branch);
+        Commit c = new Commit(this, newRevision(), base);
+        if (!isDisableBranches()) {
+            Revision rev = c.getRevision().asBranchRevision();
+            // remember branch commit
+            Branch b = getBranches().getBranch(base);
+            if (b == null) {
+                // baseRev is marker for new branch
+                getBranches().create(base.asTrunkRevision(), rev, branch);
+                LOG.debug("Branch created with base revision {}", base);
+                if (LOG.isTraceEnabled()) {
+                    LOG.trace("Branch created", new Exception());
+                }
+            } else {
+                b.addCommit(rev);
+            }
+        }
+        return c;
     }
 
     /**

Modified: 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/MergeCommit.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/MergeCommit.java?rev=1752448&r1=1752447&r2=1752448&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/MergeCommit.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/MergeCommit.java
 Wed Jul 13 15:57:28 2016
@@ -35,7 +35,7 @@ class MergeCommit extends Commit {
     MergeCommit(DocumentNodeStore nodeStore,
                 RevisionVector baseRevision,
                 SortedSet<Revision> revisions) {
-        super(nodeStore, revisions.last(), baseRevision, null);
+        super(nodeStore, revisions.last(), baseRevision);
         this.mergeRevs = revisions;
     }
 

Modified: 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/UnsavedModifications.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/UnsavedModifications.java?rev=1752448&r1=1752447&r2=1752448&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/UnsavedModifications.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/main/java/org/apache/jackrabbit/oak/plugins/document/UnsavedModifications.java
 Wed Jul 13 15:57:28 2016
@@ -179,7 +179,7 @@ class UnsavedModifications {
             int size = pathList.size();
             if (updateOp == null) {
                 // create UpdateOp
-                Commit commit = new Commit(store, r, null, null);
+                Commit commit = new Commit(store, r, null);
                 updateOp = commit.getUpdateOperationForNode(p);
                 NodeDocument.setLastRev(updateOp, r);
                 lastRev = r;

Modified: 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java?rev=1752448&r1=1752447&r2=1752448&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-core/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
 Wed Jul 13 15:57:28 2016
@@ -265,7 +265,7 @@ public class DocumentNodeStoreTest {
             public void run() {
                 try {
                     Revision r = store.newRevision();
-                    Commit c = new Commit(store, r, head, null);
+                    Commit c = new Commit(store, r, head);
                     c.addNode(new DocumentNodeState(store, 
"/newConflictingNode", new RevisionVector(r)));
                     c.addNode(new DocumentNodeState(store, "/deletedNode", new 
RevisionVector(r)));
                     c.updateProperty("/updateNode", "foo", "baz");
@@ -283,7 +283,7 @@ public class DocumentNodeStoreTest {
         created.acquireUninterruptibly();
         // commit will succeed and add collision marker to writer commit
         Revision r = store.newRevision();
-        Commit c = new Commit(store, r, head, null);
+        Commit c = new Commit(store, r, head);
         c.addNode(new DocumentNodeState(store, "/newConflictingNode", new 
RevisionVector(r)));
         c.addNode(new DocumentNodeState(store, "/newNonConflictingNode", new 
RevisionVector(r)));
         c.apply();


Reply via email to