X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-dom-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fdom%2Fbroker%2Fimpl%2FHashMapDataStore.xtend;h=9600881e505abdeb8c4d5022d4f1c91c94907e80;hb=13a76258537f64367e3036925a0331522a571705;hp=7d57819cbf0ac3a1775c4eedc026719740a8fce7;hpb=13efd0b8e167e8aadd531b5ec0e72572a72bc249;p=controller.git diff --git a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/impl/HashMapDataStore.xtend b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/impl/HashMapDataStore.xtend index 7d57819cbf..9600881e50 100644 --- a/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/impl/HashMapDataStore.xtend +++ b/opendaylight/md-sal/sal-dom-broker/src/main/java/org/opendaylight/controller/sal/dom/broker/impl/HashMapDataStore.xtend @@ -1,7 +1,12 @@ +/* + * 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.impl -import org.opendaylight.controller.md.sal.common.api.data.DataReader -import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandler import org.opendaylight.controller.md.sal.common.api.data.DataModification import org.opendaylight.controller.md.sal.common.api.data.DataCommitHandler.DataCommitTransaction import org.opendaylight.yangtools.yang.common.RpcResult @@ -11,23 +16,41 @@ import org.opendaylight.controller.sal.common.util.Rpcs import java.util.Collections import org.opendaylight.yangtools.yang.data.api.InstanceIdentifier import org.opendaylight.yangtools.yang.data.api.CompositeNode -import static extension org.opendaylight.controller.sal.dom.broker.impl.DataUtils.*; +import org.opendaylight.controller.sal.core.api.data.DataStore +import java.util.HashSet + +class HashMapDataStore implements DataStore, AutoCloseable { -class HashMapDataStore // -implements // -DataReader, DataCommitHandler { val Map configuration = new ConcurrentHashMap(); val Map operational = new ConcurrentHashMap(); + + + + override containsConfigurationPath(InstanceIdentifier path) { + throw new UnsupportedOperationException("TODO: auto-generated method stub") + + } + + override containsOperationalPath(InstanceIdentifier path) { + throw new UnsupportedOperationException("TODO: auto-generated method stub") + } + + override getStoredConfigurationPaths() { + configuration.keySet + } + + override getStoredOperationalPaths() { + operational.keySet + } override readConfigurationData(InstanceIdentifier path) { - configuration.read(path); + configuration.get(path); } override readOperationalData(InstanceIdentifier path) { - operational.read(path); + operational.get(path); } - @@ -41,18 +64,36 @@ DataReader, DataCommitHandler finish(HashMapDataStoreTransaction transaction) { val modification = transaction.modification; - configuration.putAll(modification.updatedConfigurationData); - operational.putAll(modification.updatedOperationalData); - for (removal : modification.removedConfigurationData) { - configuration.remove(removal); + remove(configuration,removal); } for (removal : modification.removedOperationalData) { - operational.remove(removal); + remove(operational,removal); } + configuration.putAll(modification.updatedConfigurationData); + operational.putAll(modification.updatedOperationalData); + return Rpcs.getRpcResult(true, null, Collections.emptySet); } + + def remove(Map map, InstanceIdentifier identifier) { + val affected = new HashSet(); + for(path : map.keySet) { + if(identifier.contains(path)) { + affected.add(path); + } + } + for(pathToRemove : affected) { + map.remove(pathToRemove); + } + + } + + override close() { + // NOOP + } + } class HashMapDataStoreTransaction implements //