2 * Copyright (c) 2016 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
9 package org.opendaylight.mdsal.dom.store.inmemory;
11 import com.google.common.base.Preconditions;
12 import java.util.HashMap;
13 import java.util.Iterator;
15 import org.opendaylight.mdsal.dom.api.DOMDataTreeIdentifier;
16 import org.opendaylight.mdsal.dom.spi.shard.ForeignShardModificationContext;
17 import org.opendaylight.mdsal.dom.spi.shard.ModificationContextNodeBuilder;
18 import org.opendaylight.mdsal.dom.spi.shard.WriteableSubshardBoundaryNode;
19 import org.opendaylight.yangtools.concepts.Builder;
20 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
21 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
23 public abstract class ShardDataModificationFactoryBuilder<T> extends ModificationContextNodeBuilder
24 implements Builder<T> {
25 protected final DOMDataTreeIdentifier root;
26 protected final Map<DOMDataTreeIdentifier, ForeignShardModificationContext> childShards = new HashMap<>();
28 public ShardDataModificationFactoryBuilder(final DOMDataTreeIdentifier root) {
29 this.root = Preconditions.checkNotNull(root);
32 public void addSubshard(final ForeignShardModificationContext value) {
33 WriteableSubshardBoundaryNode leafNode = WriteableSubshardBoundaryNode.from(value);
34 putNode(value.getIdentifier().getRootIdentifier(), leafNode);
37 public void addSubshard(final DOMDataTreeIdentifier prefix, final ForeignShardModificationContext value) {
38 childShards.put(prefix, value);
41 private void putNode(final YangInstanceIdentifier key, final WriteableSubshardBoundaryNode subshardNode) {
42 final Iterator<PathArgument> toBoundary = toRelative(key).getPathArguments().iterator();
43 if (toBoundary.hasNext()) {
44 ModificationContextNodeBuilder current = this;
46 final PathArgument nextArg = toBoundary.next();
47 if (!toBoundary.hasNext()) {
48 current.addBoundary(nextArg, subshardNode);
52 current = current.getInterior(nextArg);
57 private YangInstanceIdentifier toRelative(final YangInstanceIdentifier key) {
58 return key.relativeTo(root.getRootIdentifier()).get();
61 public abstract T build();