2 * Copyright (c) 2017 Red Hat, 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.mdsal.trace.impl;
10 import static java.util.Objects.requireNonNull;
12 import org.opendaylight.mdsal.dom.api.DOMDataTreeReadTransaction;
13 import org.opendaylight.mdsal.dom.api.DOMDataTreeReadWriteTransaction;
14 import org.opendaylight.mdsal.dom.api.DOMDataTreeWriteTransaction;
15 import org.opendaylight.mdsal.dom.api.DOMTransactionChain;
17 class TracingTransactionChain extends AbstractCloseTracked<TracingTransactionChain> implements DOMTransactionChain {
19 private final DOMTransactionChain delegate;
20 private final TracingBroker tracingBroker;
21 private final CloseTrackedRegistry<TracingReadOnlyTransaction> readOnlyTransactionsRegistry;
22 private final CloseTrackedRegistry<TracingWriteTransaction> writeTransactionsRegistry;
23 private final CloseTrackedRegistry<TracingReadWriteTransaction> readWriteTransactionsRegistry;
25 TracingTransactionChain(DOMTransactionChain delegate, TracingBroker tracingBroker,
26 CloseTrackedRegistry<TracingTransactionChain> transactionChainsRegistry) {
27 super(transactionChainsRegistry);
28 this.delegate = requireNonNull(delegate);
29 this.tracingBroker = requireNonNull(tracingBroker);
31 final boolean isDebug = transactionChainsRegistry.isDebugContextEnabled();
32 String anchor = "TransactionChain@" + Integer.toHexString(hashCode());
33 this.readOnlyTransactionsRegistry = new CloseTrackedRegistry<>(anchor, "newReadOnlyTransaction()", isDebug);
34 this.writeTransactionsRegistry = new CloseTrackedRegistry<>(anchor, "newWriteOnlyTransaction()", isDebug);
35 this.readWriteTransactionsRegistry = new CloseTrackedRegistry<>(anchor, "newReadWriteTransaction()", isDebug);
39 @SuppressWarnings("resource")
40 public DOMDataTreeReadTransaction newReadOnlyTransaction() {
41 final DOMDataTreeReadTransaction tx = delegate.newReadOnlyTransaction();
42 return new TracingReadOnlyTransaction(tx, readOnlyTransactionsRegistry);
46 public DOMDataTreeReadWriteTransaction newReadWriteTransaction() {
47 return new TracingReadWriteTransaction(delegate.newReadWriteTransaction(), tracingBroker,
48 readWriteTransactionsRegistry);
52 public DOMDataTreeWriteTransaction newWriteOnlyTransaction() {
53 final DOMDataTreeWriteTransaction tx = delegate.newWriteOnlyTransaction();
54 return new TracingWriteTransaction(tx, tracingBroker, writeTransactionsRegistry);
60 super.removeFromTrackedRegistry();
63 public CloseTrackedRegistry<TracingReadOnlyTransaction> getReadOnlyTransactionsRegistry() {
64 return readOnlyTransactionsRegistry;
67 public CloseTrackedRegistry<TracingReadWriteTransaction> getReadWriteTransactionsRegistry() {
68 return readWriteTransactionsRegistry;
71 public CloseTrackedRegistry<TracingWriteTransaction> getWriteTransactionsRegistry() {
72 return writeTransactionsRegistry;
75 // https://jira.opendaylight.org/browse/CONTROLLER-1792
78 public final boolean equals(Object object) {
79 return object == this || delegate.equals(object);
83 public final int hashCode() {
84 return delegate.hashCode();
88 public final String toString() {
89 return getClass().getName() + "; delegate=" + delegate;