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
8 package org.opendaylight.yangtools.yang.data.util;
10 import java.io.IOException;
11 import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeStreamAttributeWriter;
12 import org.opendaylight.yangtools.yang.data.api.schema.stream.NormalizedNodeStreamWriter;
13 import org.opendaylight.yangtools.yang.model.api.YangModeledAnyXmlSchemaNode;
16 * Utility class used for tracking parser state as needed by a StAX-like parser.
17 * This class is to be used only by respective XML and JSON parsers in yang-data-codec-xml and yang-data-codec-gson.
20 * Represents a YANG-modeled-anyxml node.
22 public final class YangModeledAnyXmlNodeDataWithSchema extends CompositeNodeDataWithSchema {
24 public YangModeledAnyXmlNodeDataWithSchema(final YangModeledAnyXmlSchemaNode yangModeledAnyXml) {
25 super(yangModeledAnyXml);
29 public void write(final NormalizedNodeStreamWriter writer) throws IOException {
30 writer.nextDataSchemaNode(getSchema());
32 if (writer instanceof NormalizedNodeStreamAttributeWriter && getAttributes() != null) {
33 ((NormalizedNodeStreamAttributeWriter) writer).startYangModeledAnyXmlNode(provideNodeIdentifier(),
34 childSizeHint(), getAttributes());
36 writer.startYangModeledAnyXmlNode(provideNodeIdentifier(), childSizeHint());