X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FStandaloneFrontendHistory.java;h=7fd53c7b7cb66f72805e6b3939a57a36be78a4c3;hb=f41c5e6e6f6e10b36b1e4b1992877e38e718c8fb;hp=1f2eb72560aef600a2deb9520600f8f845600fd3;hpb=5fd8e6506248cc34da72281a1662612f6c2b2f9a;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/StandaloneFrontendHistory.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/StandaloneFrontendHistory.java index 1f2eb72560..7fd53c7b7c 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/StandaloneFrontendHistory.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/StandaloneFrontendHistory.java @@ -8,6 +8,12 @@ package org.opendaylight.controller.cluster.datastore; import com.google.common.base.Preconditions; +import com.google.common.collect.ImmutableMap; +import com.google.common.collect.RangeSet; +import com.google.common.collect.TreeRangeSet; +import com.google.common.primitives.UnsignedLong; +import java.util.HashMap; +import java.util.Map; import org.opendaylight.controller.cluster.access.concepts.ClientIdentifier; import org.opendaylight.controller.cluster.access.concepts.LocalHistoryIdentifier; import org.opendaylight.controller.cluster.access.concepts.RequestException; @@ -24,26 +30,52 @@ final class StandaloneFrontendHistory extends AbstractFrontendHistory { private final LocalHistoryIdentifier identifier; private final ShardDataTree tree; - StandaloneFrontendHistory(final String persistenceId, final ClientIdentifier clientId, final ShardDataTree tree) { - super(persistenceId); + private StandaloneFrontendHistory(final String persistenceId, final ClientIdentifier clientId, + final ShardDataTree tree, final Map closedTransactions, + final RangeSet purgedTransactions) { + super(persistenceId, tree, closedTransactions, purgedTransactions); this.identifier = new LocalHistoryIdentifier(clientId, 0); this.tree = Preconditions.checkNotNull(tree); } + static StandaloneFrontendHistory create(final String persistenceId, final ClientIdentifier clientId, + final ShardDataTree tree) { + return new StandaloneFrontendHistory(persistenceId, clientId, tree, ImmutableMap.of(), + TreeRangeSet.create()); + } + + static StandaloneFrontendHistory recreate(final String persistenceId, final ClientIdentifier clientId, + final ShardDataTree tree, final Map closedTransactions, + final RangeSet purgedTransactions) { + return new StandaloneFrontendHistory(persistenceId, clientId, tree, new HashMap<>(closedTransactions), + purgedTransactions); + } + @Override public LocalHistoryIdentifier getIdentifier() { return identifier; } + @Override + FrontendTransaction createOpenSnapshot(final TransactionIdentifier id) throws RequestException { + return FrontendReadOnlyTransaction.create(this, tree.newReadOnlyTransaction(id)); + } + @Override FrontendTransaction createOpenTransaction(final TransactionIdentifier id) throws RequestException { - return FrontendTransaction.createOpen(this, tree.newReadWriteTransaction(id)); + return FrontendReadWriteTransaction.createOpen(this, tree.newReadWriteTransaction(id)); } @Override FrontendTransaction createReadyTransaction(final TransactionIdentifier id, final DataTreeModification mod) throws RequestException { - return FrontendTransaction.createReady(this, id, mod); + return FrontendReadWriteTransaction.createReady(this, id, mod); + } + + @Override + ShardDataTreeCohort createFailedCohort(final TransactionIdentifier id, final DataTreeModification mod, + final Exception failure) { + return tree.createFailedCohort(id, mod, failure); } @Override