2 * Copyright (c) 2017 Brocade Communications 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.mdsal.binding.dom.adapter;
10 import com.google.common.util.concurrent.FluentFuture;
11 import java.util.Optional;
12 import org.eclipse.jdt.annotation.NonNull;
13 import org.opendaylight.mdsal.binding.api.QueryReadWriteTransaction;
14 import org.opendaylight.mdsal.binding.api.query.QueryExpression;
15 import org.opendaylight.mdsal.binding.api.query.QueryResult;
16 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
17 import org.opendaylight.mdsal.dom.api.DOMDataTreeReadWriteTransaction;
18 import org.opendaylight.yangtools.yang.binding.DataObject;
19 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
21 class BindingDOMReadWriteTransactionAdapter extends BindingDOMWriteTransactionAdapter<DOMDataTreeReadWriteTransaction>
22 implements QueryReadWriteTransaction {
23 BindingDOMReadWriteTransactionAdapter(final AdapterContext adapterContext,
24 final DOMDataTreeReadWriteTransaction delegateTx) {
25 super(adapterContext, delegateTx);
29 public final <T extends DataObject> FluentFuture<Optional<T>> read(final LogicalDatastoreType store,
30 final InstanceIdentifier<T> path) {
31 return doRead(getDelegate(), store, path);
35 public final FluentFuture<Boolean> exists(final LogicalDatastoreType store, final InstanceIdentifier<?> path) {
36 return doExists(getDelegate(), store, path);
40 public final <T extends @NonNull DataObject> FluentFuture<QueryResult<T>> execute(final LogicalDatastoreType store,
41 final QueryExpression<T> query) {
42 return doExecute(getDelegate(), store, query);