X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fdom%2Fbroker%2FDataBrokerImpl.java;h=27e351c28a05707a782be3b3e708b01d5cde60e6;hb=17d82f582a6bc13c78be3b19954ff8c021180e93;hp=d95fdcc53dbc68019704b876c7a2ea7bdb34051e;hpb=f8e25f0e3d6196b5d3625c94a52ed5a6ab3fe5a7;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/DataBrokerImpl.java b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/DataBrokerImpl.java index d95fdcc53d..27e351c28a 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/DataBrokerImpl.java +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/DataBrokerImpl.java @@ -1,5 +1,14 @@ +/* + * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0 which accompanies this distribution, + * and is available at http://www.eclipse.org/legal/epl-v10.html + */ package org.opendaylight.controller.sal.dom.broker; +import java.util.concurrent.atomic.AtomicLong; + import org.opendaylight.controller.md.sal.common.api.data.DataReader; import org.opendaylight.controller.md.sal.common.impl.service.AbstractDataBroker; import org.opendaylight.controller.sal.common.DataStoreIdentifier; @@ -9,58 +18,72 @@ import org.opendaylight.controller.sal.core.api.data.DataValidator; import org.opendaylight.controller.sal.dom.broker.impl.DataReaderRouter; import org.opendaylight.yangtools.concepts.Registration; import org.opendaylight.yangtools.yang.data.api.CompositeNode; -import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier; +import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; + +import com.google.common.util.concurrent.MoreExecutors; + +public class DataBrokerImpl extends AbstractDataBroker implements + DataProviderService, AutoCloseable { -public class DataBrokerImpl extends AbstractDataBroker implements - DataProviderService { + private AtomicLong nextTransaction = new AtomicLong(); + private final AtomicLong createdTransactionsCount = new AtomicLong(); public DataBrokerImpl() { setDataReadRouter(new DataReaderRouter()); + setExecutor(MoreExecutors.sameThreadExecutor()); + } + + public AtomicLong getCreatedTransactionsCount() { + return createdTransactionsCount; } @Override public DataTransactionImpl beginTransaction() { - return new DataTransactionImpl(this); + String transactionId = "DOM-" + nextTransaction.getAndIncrement(); + createdTransactionsCount.getAndIncrement(); + return new DataTransactionImpl(transactionId,this); } @Override - public Registration> registerConfigurationReader( - InstanceIdentifier path, DataReader reader) { + public Registration registerConfigurationReader( + YangInstanceIdentifier path, DataReader reader) { return getDataReadRouter().registerConfigurationReader(path, reader); } @Override - public Registration> registerOperationalReader( - InstanceIdentifier path, DataReader reader) { + public Registration registerOperationalReader( + YangInstanceIdentifier path, DataReader reader) { return getDataReadRouter().registerOperationalReader(path, reader); } @Deprecated @Override public void addValidator(DataStoreIdentifier store, DataValidator validator) { - // TODO Auto-generated method stub + throw new UnsupportedOperationException("Deprecated"); } @Deprecated @Override public void removeValidator(DataStoreIdentifier store, DataValidator validator) { - // TODO Auto-generated method stub - + throw new UnsupportedOperationException("Deprecated"); } @Deprecated @Override public void addRefresher(DataStoreIdentifier store, DataRefresher refresher) { - // TODO Auto-generated method stub - + throw new UnsupportedOperationException("Deprecated"); } @Deprecated @Override public void removeRefresher(DataStoreIdentifier store, DataRefresher refresher) { - // TODO Auto-generated method stub + throw new UnsupportedOperationException("Deprecated"); + } + + @Override + public void close() throws Exception { } -} \ No newline at end of file +}