2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2024 Ericsson
4 * Modifications Copyright (C) 2024 OpenInfra Foundation Europe
5 * ================================================================================
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
18 * SPDX-License-Identifier: Apache-2.0
19 * ============LICENSE_END=========================================================
21 package org.oran.smo.yangtools.parser.data.dom;
23 import java.util.Objects;
25 import org.oran.smo.yangtools.parser.util.NamespaceModuleIdentifier;
28 * Encodes an annotation value.
30 * @author Mark Hollmann
32 public class YangDataDomNodeAnnotationValue extends NamespaceModuleIdentifier {
34 private final Object value;
36 public YangDataDomNodeAnnotationValue(final String namespace, final String moduleName, final String annotationName,
38 super(namespace, moduleName, Objects.requireNonNull(annotationName));
43 * May be null if the data input was JSON and resolution has not been done yet.
45 public String getNamespace() {
46 return super.getNamespace();
50 * May be null if the data input was XML and resolution has not been done yet.
52 public String getModuleName() {
53 return super.getModuleName();
56 public String getName() {
57 return super.getIdentifier();
61 * Returns the value of the annotation. The encoding of the value is handled in the same way
62 * how it is done for the data DOM node (i.e. it distinguishes between XML and JSON source).
63 * May return null (annotation has no argument).
65 public Object getValue() {