2 * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.cluster.datastore;
10 import com.google.common.base.MoreObjects;
11 import com.google.common.base.Preconditions;
12 import javax.annotation.concurrent.NotThreadSafe;
13 import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier;
14 import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeSnapshot;
17 * Abstract base for transactions running on SharrdDataTree.
19 * @param <T> Backing transaction type.
22 abstract class AbstractShardDataTreeTransaction<T extends DataTreeSnapshot> {
23 private final T snapshot;
24 private final TransactionIdentifier id;
25 private boolean closed;
27 protected AbstractShardDataTreeTransaction(final TransactionIdentifier id, final T snapshot) {
28 this.snapshot = Preconditions.checkNotNull(snapshot);
29 this.id = Preconditions.checkNotNull(id);
32 final TransactionIdentifier getId() {
36 final T getSnapshot() {
40 final boolean isClosed() {
45 * Close this transaction and mark it as closed, allowing idempotent invocations.
47 * @return True if the transaction got closed by this method invocation.
49 protected final boolean close() {
59 public final String toString() {
60 return MoreObjects.toStringHelper(this).add("id", id).add("closed", closed).add("snapshot", snapshot).toString();
63 abstract void abort();