*/
package org.opendaylight.controller.cluster.datastore;
-import com.google.common.collect.Lists;
-import java.util.List;
import org.opendaylight.controller.cluster.datastore.identifiers.TransactionIdentifier;
-import scala.concurrent.Future;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
abstract class AbstractTransactionContext implements TransactionContext {
- protected final TransactionIdentifier identifier;
- protected final List<Future<Object>> recordedOperationFutures = Lists.newArrayList();
+ private static final Logger LOG = LoggerFactory.getLogger(AbstractTransactionContext.class);
- AbstractTransactionContext(TransactionIdentifier identifier) {
+ private long modificationCount = 0;
+
+ private final TransactionIdentifier identifier;
+
+ protected AbstractTransactionContext(TransactionIdentifier identifier) {
this.identifier = identifier;
}
- @Override
- public List<Future<Object>> getRecordedOperationFutures() {
- return recordedOperationFutures;
+ protected final TransactionIdentifier getIdentifier() {
+ return identifier;
+ }
+
+ protected void incrementModificationCount(){
+ modificationCount++;
+ }
+
+ protected void logModificationCount(){
+ LOG.debug("Total modifications on Tx {} = [ {} ]", identifier, modificationCount);
}
}
\ No newline at end of file