34f50fb01597868d838fede49046e740816c53ac
[yangtools.git] / yang / yang-data-api / src / main / java / org / opendaylight / yangtools / yang / data / api / schema / UserMapNode.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
3  *
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
7  */
8 package org.opendaylight.yangtools.yang.data.api.schema;
9
10 import java.util.Map;
11 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates;
12
13 /**
14  * {@link MapNode} which additionally preserves user-supplied ordering. This node represents a data instance of
15  * a {@code list} with {@code ordered-by user;} substatement and a {@code key} definition.
16  */
17 public interface UserMapNode extends MapNode, OrderedNodeContainer<MapEntryNode> {
18     /**
19      * {@inheritDoc}
20      *
21      * <p>
22      * The implementation is required to define a user-visible iteration order, which must match {@link #getChild(int)}.
23      */
24     @Override
25     Map<NodeIdentifierWithPredicates, MapEntryNode> asMap();
26 }