/* * Copyright (c) 2013 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.yangtools.yang.model.api; import java.util.Collection; import java.util.Set; import org.opendaylight.yangtools.yang.common.QName; /** * Node which can contains other nodes. */ public interface DataNodeContainer { /** * Returns set of all newly defined types within this DataNodeContainer. * * @return typedef statements in lexicographical order */ Set> getTypeDefinitions(); /** * Returns set of all child nodes defined within this DataNodeContainer. * Although the return type is a collection, each node is guaranteed to * be present at most once. * * @return child nodes in lexicographical order */ Collection getChildNodes(); /** * Returns set of all groupings defined within this DataNodeContainer. * * @return grouping statements in lexicographical order */ Set getGroupings(); /** * @param name * QName of seeked child * @return child node of this DataNodeContainer if child with given name is * present, null otherwise */ DataSchemaNode getDataChildByName(QName name); /** * @param name * name of seeked child as String * @return child node of this DataNodeContainer if child with given name is * present, null otherwise * * @deprecated This method disregards the namespace and thus leads to unpredictable results * when multiple children exist with the same localname, but with different namespaces. */ @Deprecated DataSchemaNode getDataChildByName(String name); /** * @return Set of all uses nodes defined within this DataNodeContainer */ Set getUses(); }