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%2Fdatabroker%2FAbstractDOMTransactionFactory.java;h=e41df8dfa2ae62f6494e4aae3d3fdc2088861410;hb=18991f44b807ab6f06fcec76216b7f70b900b0f4;hp=2187c6e0f9298747957541b89ce5d654276e6808;hpb=2b2517144e4eb9c17d9b41e9d9ec20d0264f5e12;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java index 2187c6e0f9..e41df8dfa2 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/AbstractDOMTransactionFactory.java @@ -9,24 +9,36 @@ package org.opendaylight.controller.cluster.databroker; import com.google.common.base.Preconditions; -import com.google.common.util.concurrent.CheckedFuture; -import java.util.Collection; +import com.google.common.util.concurrent.FluentFuture; +import java.lang.invoke.MethodHandles; +import java.lang.invoke.VarHandle; import java.util.EnumMap; import java.util.Map; -import java.util.concurrent.atomic.AtomicIntegerFieldUpdater; -import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; -import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException; -import org.opendaylight.controller.md.sal.dom.api.DOMDataReadOnlyTransaction; -import org.opendaylight.controller.md.sal.dom.api.DOMDataReadWriteTransaction; -import org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreThreePhaseCommitCohort; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreTransactionFactory; +import org.opendaylight.mdsal.common.api.CommitInfo; +import org.opendaylight.mdsal.common.api.LogicalDatastoreType; +import org.opendaylight.mdsal.dom.api.DOMDataTreeReadTransaction; +import org.opendaylight.mdsal.dom.api.DOMDataTreeReadWriteTransaction; +import org.opendaylight.mdsal.dom.api.DOMDataTreeWriteTransaction; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreThreePhaseCommitCohort; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreTransactionFactory; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; public abstract class AbstractDOMTransactionFactory implements AutoCloseable { - private static final AtomicIntegerFieldUpdater UPDATER = - AtomicIntegerFieldUpdater.newUpdater(AbstractDOMTransactionFactory.class, "closed"); + private static final Logger LOG = LoggerFactory.getLogger(AbstractDOMTransactionFactory.class); + private static final VarHandle CLOSED; + + static { + try { + CLOSED = MethodHandles.lookup().findVarHandle(AbstractDOMTransactionFactory.class, "closed", boolean.class); + } catch (NoSuchFieldException | IllegalAccessException e) { + throw new ExceptionInInitializerError(e); + } + } + private final Map storeTxFactories; - private volatile int closed = 0; + + private volatile boolean closed; protected AbstractDOMTransactionFactory(final Map txFactories) { this.storeTxFactories = new EnumMap<>(txFactories); @@ -34,26 +46,28 @@ public abstract class AbstractDOMTransactionFactory submit(final DOMDataWriteTransaction transaction, - final Collection cohorts); + protected abstract FluentFuture commit(DOMDataTreeWriteTransaction transaction, + DOMStoreThreePhaseCommitCohort cohort); /** + * Creates a new read-only transaction. * - * @return + * @return the transaction instance */ - public final DOMDataReadOnlyTransaction newReadOnlyTransaction() { + public final DOMDataTreeReadTransaction newReadOnlyTransaction() { checkNotClosed(); return new DOMBrokerReadOnlyTransaction(newTransactionIdentifier(), storeTxFactories); @@ -61,10 +75,11 @@ public abstract class AbstractDOMTransactionFactory(newTransactionIdentifier(), storeTxFactories, this); + return new DOMBrokerReadWriteTransaction(newTransactionIdentifier(), storeTxFactories, this); } /** @@ -91,7 +107,7 @@ public abstract class AbstractDOMTransactionFactory getTxFactories() { + public final Map getTxFactories() { return storeTxFactories; } @@ -102,12 +118,13 @@ public abstract class AbstractDOMTransactionFactory