/* * * 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.cluster.datastore.node.utils; import com.google.common.base.Preconditions; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild; import org.opendaylight.yangtools.yang.data.api.schema.DataContainerNode; import org.opendaylight.yangtools.yang.data.api.schema.MixinNode; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNodeContainer; /** * NormalizedNodeNavigator walks a {@link NormalizedNodeVisitor} through the NormalizedNode * * {@link NormalizedNode } is a tree like structure that provides a generic structure for a yang data model * * For examples of visitors * @see NormalizedNodePrinter * * */ public class NormalizedNodeNavigator { private final org.opendaylight.controller.cluster.datastore.node.utils.NormalizedNodeVisitor visitor; public NormalizedNodeNavigator( org.opendaylight.controller.cluster.datastore.node.utils.NormalizedNodeVisitor visitor){ Preconditions.checkNotNull(visitor, "visitor should not be null"); this.visitor = visitor; } public void navigate(String parentPath, NormalizedNode normalizedNode){ if(parentPath == null){ parentPath = ""; } navigateNormalizedNode(0, parentPath, normalizedNode); } private void navigateDataContainerNode(int level, final String parentPath, final DataContainerNode dataContainerNode){ visitor.visitNode(level, parentPath ,dataContainerNode); String newParentPath = parentPath + "/" + dataContainerNode.getIdentifier().toString(); final Iterable> value = dataContainerNode.getValue(); for(NormalizedNode node : value){ if(node instanceof MixinNode && node instanceof NormalizedNodeContainer){ navigateNormalizedNodeContainerMixin(level, newParentPath, (NormalizedNodeContainer) node); } else { navigateNormalizedNode(level, newParentPath, node); } } } private void navigateNormalizedNodeContainerMixin(int level, final String parentPath, NormalizedNodeContainer node) { visitor.visitNode(level, parentPath, node); String newParentPath = parentPath + "/" + node.getIdentifier().toString(); final Iterable> value = node.getValue(); for(NormalizedNode normalizedNode : value){ if(normalizedNode instanceof MixinNode && normalizedNode instanceof NormalizedNodeContainer){ navigateNormalizedNodeContainerMixin(level + 1, newParentPath, (NormalizedNodeContainer) normalizedNode); } else { navigateNormalizedNode(level, newParentPath, normalizedNode); } } } private void navigateNormalizedNode(int level, String parentPath, NormalizedNode normalizedNode){ if(normalizedNode instanceof DataContainerNode){ final DataContainerNode dataContainerNode = (DataContainerNode) normalizedNode; navigateDataContainerNode(level + 1, parentPath, dataContainerNode); } else { visitor.visitNode(level+1, parentPath, normalizedNode); } } }