Merge LeafListStatementSupport
[yangtools.git] / yang / yang-parser-rfc7950 / src / main / java / org / opendaylight / yangtools / yang / parser / rfc7950 / reactor / RFC7950Reactors.java
1 /*
2  * Copyright (c) 2017 Pantheon Technologies, s.r.o. 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.parser.rfc7950.reactor;
9
10 import static org.opendaylight.yangtools.yang.common.YangVersion.VERSION_1;
11 import static org.opendaylight.yangtools.yang.common.YangVersion.VERSION_1_1;
12
13 import com.google.common.annotations.Beta;
14 import com.google.common.collect.ImmutableSet;
15 import com.google.common.collect.Sets;
16 import org.eclipse.jdt.annotation.NonNull;
17 import org.opendaylight.yangtools.yang.common.YangVersion;
18 import org.opendaylight.yangtools.yang.parser.openconfig.stmt.OpenConfigVersionSupport;
19 import org.opendaylight.yangtools.yang.parser.rfc7950.namespace.ModuleQNameToPrefix;
20 import org.opendaylight.yangtools.yang.parser.rfc7950.namespace.YangNamespaceContextNamespace;
21 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.XPathSupport;
22 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.action.ActionStatementSupport;
23 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.anydata.AnydataStatementSupport;
24 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.anyxml.AnyxmlStatementSupport;
25 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.argument.ArgumentStatementSupport;
26 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.augment.AugmentImplicitHandlingNamespace;
27 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.augment.AugmentStatementRFC6020Support;
28 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.augment.AugmentStatementRFC7950Support;
29 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.base.BaseStatementSupport;
30 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.belongs_to.BelongsToStatementSupport;
31 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.bit.BitStatementSupport;
32 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.case_.CaseStatementSupport;
33 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.choice.ChoiceStatementSupport;
34 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.config.ConfigStatementSupport;
35 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.contact.ContactStatementSupport;
36 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.container.ContainerStatementSupport;
37 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.default_.DefaultStatementSupport;
38 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.description.DescriptionStatementSupport;
39 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.deviate.DeviateStatementRFC6020Support;
40 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.deviate.DeviateStatementRFC7950Support;
41 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.deviation.DeviationStatementSupport;
42 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.enum_.EnumStatementSupport;
43 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.error_app_tag.ErrorAppTagStatementSupport;
44 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.error_message.ErrorMessageStatementSupport;
45 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.extension.ExtensionStatementSupport;
46 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.feature.FeatureStatementSupport;
47 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.fraction_digits.FractionDigitsStatementSupport;
48 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.grouping.GroupingStatementSupport;
49 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.identity.IdentityStatementSupport;
50 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.if_feature.IfFeatureStatementRFC6020Support;
51 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.if_feature.IfFeatureStatementRFC7950Support;
52 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.import_.ImportStatementRFC6020Support;
53 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.import_.ImportStatementRFC7950Support;
54 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.include.IncludeStatementSupport;
55 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.input.InputStatementSupport;
56 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.key.KeyStatementSupport;
57 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.leaf.LeafStatementSupport;
58 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.leaf_list.LeafListStatementSupport;
59 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.length.LengthStatementSupport;
60 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.list.ConfigListWarningNamespace;
61 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.list.ListStatementRFC6020Support;
62 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.list.ListStatementRFC7950Support;
63 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.mandatory.MandatoryStatementSupport;
64 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.max_elements.MaxElementsStatementSupport;
65 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.min_elements.MinElementsStatementSupport;
66 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.modifier.ModifierStatementSupport;
67 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.module.ModuleStatementSupport;
68 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.must.MustStatementSupport;
69 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.namespace.NamespaceStatementSupport;
70 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.notification.NotificationStatementRFC6020Support;
71 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.notification.NotificationStatementRFC7950Support;
72 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.ordered_by.OrderedByStatementSupport;
73 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.organization.OrganizationStatementSupport;
74 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.output.OutputStatementSupport;
75 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.path.PathStatementSupport;
76 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.pattern.PatternStatementRFC6020Support;
77 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.pattern.PatternStatementRFC7950Support;
78 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.position.PositionStatementSupport;
79 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.prefix.PrefixStatementSupport;
80 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.presence.PresenceStatementSupport;
81 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.range.RangeStatementSupport;
82 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.reference.ReferenceStatementSupport;
83 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.refine.RefineStatementSupport;
84 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.require_instance.RequireInstanceStatementSupport;
85 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.revision.RevisionStatementSupport;
86 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.revision_date.RevisionDateStatementSupport;
87 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.rpc.RpcStatementSupport;
88 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.status.StatusStatementSupport;
89 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.submodule.SubmoduleStatementRFC6020Support;
90 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.submodule.SubmoduleStatementRFC7950Support;
91 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.type.BaseTypeNamespace;
92 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.type.TypeStatementRFC6020Support;
93 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.type.TypeStatementRFC7950Support;
94 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.typedef.TypedefStatementSupport;
95 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.unique.UniqueStatementSupport;
96 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.units.UnitsStatementSupport;
97 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.uses.SourceGroupingNamespace;
98 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.uses.UsesStatementSupport;
99 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.value.ValueStatementSupport;
100 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.when.WhenStatementSupport;
101 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.yang_version.YangVersionStatementSupport;
102 import org.opendaylight.yangtools.yang.parser.rfc7950.stmt.yin_element.YinElementStatementSupport;
103 import org.opendaylight.yangtools.yang.parser.spi.ExtensionNamespace;
104 import org.opendaylight.yangtools.yang.parser.spi.FeatureNamespace;
105 import org.opendaylight.yangtools.yang.parser.spi.GroupingNamespace;
106 import org.opendaylight.yangtools.yang.parser.spi.IdentityNamespace;
107 import org.opendaylight.yangtools.yang.parser.spi.ModuleNamespace;
108 import org.opendaylight.yangtools.yang.parser.spi.NamespaceToModule;
109 import org.opendaylight.yangtools.yang.parser.spi.PreLinkageModuleNamespace;
110 import org.opendaylight.yangtools.yang.parser.spi.SchemaTreeNamespace;
111 import org.opendaylight.yangtools.yang.parser.spi.SubmoduleNamespace;
112 import org.opendaylight.yangtools.yang.parser.spi.TypeNamespace;
113 import org.opendaylight.yangtools.yang.parser.spi.meta.ModelProcessingPhase;
114 import org.opendaylight.yangtools.yang.parser.spi.meta.SemanticVersionModuleNamespace;
115 import org.opendaylight.yangtools.yang.parser.spi.meta.SemanticVersionNamespace;
116 import org.opendaylight.yangtools.yang.parser.spi.meta.StatementDefinitionNamespace;
117 import org.opendaylight.yangtools.yang.parser.spi.meta.StatementSupportBundle;
118 import org.opendaylight.yangtools.yang.parser.spi.source.BelongsToModuleContext;
119 import org.opendaylight.yangtools.yang.parser.spi.source.BelongsToPrefixToModuleCtx;
120 import org.opendaylight.yangtools.yang.parser.spi.source.BelongsToPrefixToModuleName;
121 import org.opendaylight.yangtools.yang.parser.spi.source.ImpPrefixToNamespace;
122 import org.opendaylight.yangtools.yang.parser.spi.source.ImportPrefixToModuleCtx;
123 import org.opendaylight.yangtools.yang.parser.spi.source.ImportPrefixToSemVerSourceIdentifier;
124 import org.opendaylight.yangtools.yang.parser.spi.source.ImportedModuleContext;
125 import org.opendaylight.yangtools.yang.parser.spi.source.IncludedModuleContext;
126 import org.opendaylight.yangtools.yang.parser.spi.source.IncludedSubmoduleNameToModuleCtx;
127 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleCtxToModuleQName;
128 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleCtxToSourceIdentifier;
129 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleNameToModuleQName;
130 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleNameToNamespace;
131 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleNamespaceForBelongsTo;
132 import org.opendaylight.yangtools.yang.parser.spi.source.ModuleQNameToModuleName;
133 import org.opendaylight.yangtools.yang.parser.spi.source.ModulesDeviatedByModules;
134 import org.opendaylight.yangtools.yang.parser.spi.source.PrefixToModule;
135 import org.opendaylight.yangtools.yang.parser.spi.source.QNameToStatementDefinition;
136 import org.opendaylight.yangtools.yang.parser.spi.source.SupportedFeaturesNamespace;
137 import org.opendaylight.yangtools.yang.parser.spi.validation.ValidationBundlesNamespace;
138 import org.opendaylight.yangtools.yang.parser.spi.validation.ValidationBundlesNamespace.ValidationBundleType;
139 import org.opendaylight.yangtools.yang.parser.stmt.reactor.CrossSourceStatementReactor;
140 import org.opendaylight.yangtools.yang.xpath.api.YangXPathParserFactory;
141
142 /**
143  * Utility class holding entrypoints for assembling RFC6020/RFC7950 statement {@link CrossSourceStatementReactor}s.
144  *
145  * @author Robert Varga
146  */
147 @Beta
148 public final class RFC7950Reactors {
149     private static final ImmutableSet<YangVersion> SUPPORTED_VERSIONS = Sets.immutableEnumSet(VERSION_1, VERSION_1_1);
150
151     private static final StatementSupportBundle INIT_BUNDLE = StatementSupportBundle.builder(SUPPORTED_VERSIONS)
152             .addSupport(ValidationBundlesNamespace.BEHAVIOUR)
153             .addSupport(SupportedFeaturesNamespace.BEHAVIOUR)
154             .addSupport(ModulesDeviatedByModules.BEHAVIOUR)
155             .build();
156
157     private static final StatementSupportBundle PRE_LINKAGE_BUNDLE = StatementSupportBundle.derivedFrom(INIT_BUNDLE)
158             .addVersionSpecificSupport(VERSION_1, ModuleStatementSupport.rfc6020Instance())
159             .addVersionSpecificSupport(VERSION_1_1, ModuleStatementSupport.rfc7950Instance())
160             .addVersionSpecificSupport(VERSION_1, SubmoduleStatementRFC6020Support.getInstance())
161             .addVersionSpecificSupport(VERSION_1_1, SubmoduleStatementRFC7950Support.getInstance())
162             .addSupport(NamespaceStatementSupport.getInstance())
163             .addVersionSpecificSupport(VERSION_1, ImportStatementRFC6020Support.getInstance())
164             .addVersionSpecificSupport(VERSION_1_1, ImportStatementRFC7950Support.getInstance())
165             .addVersionSpecificSupport(VERSION_1, IncludeStatementSupport.rfc6020Instance())
166             .addVersionSpecificSupport(VERSION_1_1, IncludeStatementSupport.rfc7950Instance())
167             .addSupport(BelongsToStatementSupport.getInstance())
168             .addSupport(PrefixStatementSupport.getInstance())
169             .addSupport(YangVersionStatementSupport.getInstance())
170             .addSupport(RevisionStatementSupport.getInstance())
171             .addSupport(RevisionDateStatementSupport.getInstance())
172             .addSupport(ModuleNameToNamespace.BEHAVIOUR)
173             .addSupport(PreLinkageModuleNamespace.BEHAVIOUR)
174             .addSupport(ImpPrefixToNamespace.BEHAVIOUR)
175             .addSupport(ModuleCtxToModuleQName.BEHAVIOUR)
176             .build();
177
178     private static final StatementSupportBundle LINKAGE_BUNDLE = StatementSupportBundle
179             .derivedFrom(PRE_LINKAGE_BUNDLE)
180             .addSupport(DescriptionStatementSupport.getInstance())
181             .addSupport(ReferenceStatementSupport.getInstance())
182             .addSupport(ContactStatementSupport.getInstance())
183             .addSupport(OrganizationStatementSupport.getInstance())
184             .addSupport(ModuleNamespace.BEHAVIOUR)
185             .addSupport(ModuleNamespaceForBelongsTo.BEHAVIOUR)
186             .addSupport(SubmoduleNamespace.BEHAVIOUR)
187             .addSupport(NamespaceToModule.BEHAVIOUR)
188             .addSupport(ModuleNameToModuleQName.BEHAVIOUR)
189             .addSupport(ModuleCtxToSourceIdentifier.BEHAVIOUR)
190             .addSupport(ModuleQNameToModuleName.BEHAVIOUR)
191             .addSupport(PrefixToModule.BEHAVIOUR)
192             .addSupport(ImportedModuleContext.BEHAVIOUR)
193             .addSupport(IncludedModuleContext.BEHAVIOUR)
194             .addSupport(IncludedSubmoduleNameToModuleCtx.BEHAVIOUR)
195             .addSupport(ImportPrefixToModuleCtx.BEHAVIOUR)
196             .addSupport(BelongsToPrefixToModuleCtx.BEHAVIOUR)
197             .addSupport(ModuleQNameToPrefix.BEHAVIOUR)
198             .addSupport(BelongsToModuleContext.BEHAVIOUR)
199             .addSupport(QNameToStatementDefinition.BEHAVIOUR)
200             .addSupport(BelongsToPrefixToModuleName.BEHAVIOUR)
201             .build();
202
203     private static final StatementSupportBundle STMT_DEF_BUNDLE = StatementSupportBundle
204             .derivedFrom(LINKAGE_BUNDLE)
205             .addSupport(YinElementStatementSupport.getInstance())
206             .addSupport(ArgumentStatementSupport.getInstance())
207             .addSupport(ExtensionStatementSupport.getInstance())
208             .addSupport(SchemaTreeNamespace.getInstance())
209             .addSupport(ExtensionNamespace.BEHAVIOUR)
210             .addSupport(TypedefStatementSupport.getInstance())
211             .addSupport(TypeNamespace.BEHAVIOUR)
212             .addVersionSpecificSupport(VERSION_1, IdentityStatementSupport.rfc6020Instance())
213             .addVersionSpecificSupport(VERSION_1_1, IdentityStatementSupport.rfc7950Instance())
214             .addSupport(IdentityNamespace.BEHAVIOUR)
215             .addSupport(DefaultStatementSupport.getInstance())
216             .addSupport(StatusStatementSupport.getInstance())
217             .addSupport(BaseTypeNamespace.BEHAVIOUR)
218             .addVersionSpecificSupport(VERSION_1, TypeStatementRFC6020Support.getInstance())
219             .addVersionSpecificSupport(VERSION_1_1, TypeStatementRFC7950Support.getInstance())
220             .addSupport(UnitsStatementSupport.getInstance())
221             .addSupport(RequireInstanceStatementSupport.getInstance())
222             .addVersionSpecificSupport(VERSION_1, BitStatementSupport.rfc6020Instance())
223             .addVersionSpecificSupport(VERSION_1_1, BitStatementSupport.rfc7950Instance())
224             .addSupport(PathStatementSupport.strictInstance())
225             .addVersionSpecificSupport(VERSION_1, EnumStatementSupport.rfc6020Instance())
226             .addVersionSpecificSupport(VERSION_1_1, EnumStatementSupport.rfc7950Instance())
227             .addSupport(LengthStatementSupport.getInstance())
228             .addVersionSpecificSupport(VERSION_1, PatternStatementRFC6020Support.getInstance())
229             .addVersionSpecificSupport(VERSION_1_1, PatternStatementRFC7950Support.getInstance())
230             .addVersionSpecificSupport(VERSION_1_1, ModifierStatementSupport.getInstance())
231             .addSupport(RangeStatementSupport.getInstance())
232             .addSupport(KeyStatementSupport.getInstance())
233             .addVersionSpecificSupport(VERSION_1, ContainerStatementSupport.rfc6020Instance())
234             .addVersionSpecificSupport(VERSION_1_1, ContainerStatementSupport.rfc7950Instance())
235             .addVersionSpecificSupport(VERSION_1, GroupingStatementSupport.rfc6020Instance())
236             .addVersionSpecificSupport(VERSION_1_1, GroupingStatementSupport.rfc7950Instance())
237             .addVersionSpecificSupport(VERSION_1, ListStatementRFC6020Support.getInstance())
238             .addVersionSpecificSupport(VERSION_1_1, ListStatementRFC7950Support.getInstance())
239             .addSupport(ConfigListWarningNamespace.BEHAVIOUR)
240             .addSupport(UniqueStatementSupport.getInstance())
241             .addVersionSpecificSupport(VERSION_1_1, ActionStatementSupport.getInstance())
242             .addVersionSpecificSupport(VERSION_1, RpcStatementSupport.rfc6020Instance())
243             .addVersionSpecificSupport(VERSION_1_1, RpcStatementSupport.rfc7950Instance())
244             .addVersionSpecificSupport(VERSION_1, InputStatementSupport.rfc6020Instance())
245             .addVersionSpecificSupport(VERSION_1_1, InputStatementSupport.rfc7950Instance())
246             .addVersionSpecificSupport(VERSION_1, OutputStatementSupport.rfc6020Instance())
247             .addVersionSpecificSupport(VERSION_1_1, OutputStatementSupport.rfc7950Instance())
248             .addVersionSpecificSupport(VERSION_1, NotificationStatementRFC6020Support.getInstance())
249             .addVersionSpecificSupport(VERSION_1_1, NotificationStatementRFC7950Support.getInstance())
250             .addSupport(FractionDigitsStatementSupport.getInstance())
251             .addSupport(BaseStatementSupport.getInstance())
252             .addSupport(StatementDefinitionNamespace.BEHAVIOUR)
253             .build();
254
255
256     private RFC7950Reactors() {
257         // Hidden on purpose
258     }
259
260     /**
261      * Returns a pre-built {@link CrossSourceStatementReactor} supporting RFC6020 and RFC7950, along with OpenConfig
262      * semantic version extension. This is useful for parsing near-vanilla YANG models while providing complete
263      * support for semantic versions.
264      *
265      * @return A shared reactor instance.
266      */
267     public static @NonNull CrossSourceStatementReactor defaultReactor() {
268         return ServiceLoaderState.DefaultReactor.INSTANCE;
269     }
270
271     /**
272      * Returns a partially-configured {@link CustomCrossSourceStatementReactorBuilder}, with RFC6020/RFC7950
273      * and OpenConfig semantic version support enabled.
274      *
275      * @return A new {@link CustomCrossSourceStatementReactorBuilder}.
276      */
277     public static @NonNull CustomCrossSourceStatementReactorBuilder defaultReactorBuilder() {
278         return addExtensions(vanillaReactorBuilder());
279     }
280
281     public static @NonNull CustomCrossSourceStatementReactorBuilder defaultReactorBuilder(
282             final YangXPathParserFactory xpathFactory) {
283         return addExtensions(vanillaReactorBuilder(xpathFactory));
284     }
285
286     private static @NonNull CustomCrossSourceStatementReactorBuilder addExtensions(
287             final @NonNull CustomCrossSourceStatementReactorBuilder builder) {
288         return builder
289                 // Semantic version support
290                 .addStatementSupport(ModelProcessingPhase.SOURCE_LINKAGE, OpenConfigVersionSupport.getInstance())
291                 .addNamespaceSupport(ModelProcessingPhase.SOURCE_LINKAGE, SemanticVersionNamespace.BEHAVIOUR)
292                 .addNamespaceSupport(ModelProcessingPhase.SOURCE_LINKAGE, SemanticVersionModuleNamespace.BEHAVIOUR)
293                 .addNamespaceSupport(ModelProcessingPhase.SOURCE_LINKAGE,
294                     ImportPrefixToSemVerSourceIdentifier.BEHAVIOUR);
295     }
296
297     /**
298      * Returns a pre-built {@link CrossSourceStatementReactor} supporting both RFC6020 and RFC7950. This is useful
299      * for parsing vanilla YANG models without any semantic support for extensions. Notably missing is the semantic
300      * version extension, hence attempts to use semantic version mode will cause failures.
301      *
302      * @return A shared reactor instance.
303      */
304     public static @NonNull CrossSourceStatementReactor vanillaReactor() {
305         return ServiceLoaderState.VanillaReactor.INSTANCE;
306     }
307
308     /**
309      * Returns a partially-configured {@link CustomCrossSourceStatementReactorBuilder}, with vanilla RFC6020/RFC7950
310      * support enabled.
311      *
312      * @return A new {@link CustomCrossSourceStatementReactorBuilder}.
313      */
314     public static @NonNull CustomCrossSourceStatementReactorBuilder vanillaReactorBuilder() {
315         return vanillaReactorBuilder(ServiceLoaderState.XPath.INSTANCE);
316     }
317
318     public static @NonNull CustomCrossSourceStatementReactorBuilder vanillaReactorBuilder(
319             final @NonNull YangXPathParserFactory xpathFactory) {
320         return vanillaReactorBuilder(new XPathSupport(xpathFactory));
321     }
322
323     private static @NonNull CustomCrossSourceStatementReactorBuilder vanillaReactorBuilder(
324             final @NonNull XPathSupport xpathSupport) {
325         final StatementSupportBundle fullDeclarationBundle = fullDeclarationBundle(xpathSupport);
326         return new CustomCrossSourceStatementReactorBuilder(SUPPORTED_VERSIONS)
327                 .addAllSupports(ModelProcessingPhase.INIT, INIT_BUNDLE)
328                 .addAllSupports(ModelProcessingPhase.SOURCE_PRE_LINKAGE, PRE_LINKAGE_BUNDLE)
329                 .addAllSupports(ModelProcessingPhase.SOURCE_LINKAGE, LINKAGE_BUNDLE)
330                 .addAllSupports(ModelProcessingPhase.STATEMENT_DEFINITION, STMT_DEF_BUNDLE)
331                 .addAllSupports(ModelProcessingPhase.FULL_DECLARATION, fullDeclarationBundle)
332                 .addAllSupports(ModelProcessingPhase.EFFECTIVE_MODEL, fullDeclarationBundle)
333                 .addValidationBundle(ValidationBundleType.SUPPORTED_REFINE_SUBSTATEMENTS,
334                     YangValidationBundles.SUPPORTED_REFINE_SUBSTATEMENTS)
335                 .addValidationBundle(ValidationBundleType.SUPPORTED_AUGMENT_TARGETS,
336                     YangValidationBundles.SUPPORTED_AUGMENT_TARGETS)
337
338                 // FIXME: 7.0.0: we do not seem to need this validation bundle
339                 .addValidationBundle(ValidationBundleType.SUPPORTED_CASE_SHORTHANDS,
340                     YangValidationBundles.SUPPORTED_CASE_SHORTHANDS)
341
342                 .addValidationBundle(ValidationBundleType.SUPPORTED_DATA_NODES,
343                     YangValidationBundles.SUPPORTED_DATA_NODES);
344     }
345
346     private static @NonNull StatementSupportBundle fullDeclarationBundle(final XPathSupport xpathSupport) {
347         return StatementSupportBundle
348             .derivedFrom(STMT_DEF_BUNDLE)
349             .addSupport(LeafStatementSupport.getInstance())
350             .addSupport(ConfigStatementSupport.getInstance())
351             .addSupport(DeviationStatementSupport.getInstance())
352             .addVersionSpecificSupport(VERSION_1, DeviateStatementRFC6020Support.getInstance())
353             .addVersionSpecificSupport(VERSION_1_1, DeviateStatementRFC7950Support.getInstance())
354             .addVersionSpecificSupport(VERSION_1, ChoiceStatementSupport.rfc6020Instance())
355             .addVersionSpecificSupport(VERSION_1_1, ChoiceStatementSupport.rfc7950Instance())
356             .addVersionSpecificSupport(VERSION_1, CaseStatementSupport.rfc6020Instance())
357             .addVersionSpecificSupport(VERSION_1_1, CaseStatementSupport.rfc7950Instance())
358             .addSupport(MustStatementSupport.createInstance(xpathSupport))
359             .addSupport(MandatoryStatementSupport.getInstance())
360             .addSupport(AnyxmlStatementSupport.getInstance())
361             .addVersionSpecificSupport(VERSION_1_1, AnydataStatementSupport.getInstance())
362             .addSupport(FeatureNamespace.BEHAVIOUR)
363             .addVersionSpecificSupport(VERSION_1, IfFeatureStatementRFC6020Support.getInstance())
364             .addVersionSpecificSupport(VERSION_1_1, IfFeatureStatementRFC7950Support.getInstance())
365             .addSupport(GroupingNamespace.BEHAVIOUR)
366             .addSupport(SourceGroupingNamespace.BEHAVIOUR)
367             .addSupport(UsesStatementSupport.getInstance())
368             .addSupport(ErrorMessageStatementSupport.getInstance())
369             .addSupport(ErrorAppTagStatementSupport.getInstance())
370             .addVersionSpecificSupport(VERSION_1, LeafListStatementSupport.rfc6020Instance())
371             .addVersionSpecificSupport(VERSION_1_1, LeafListStatementSupport.rfc7950Instance())
372             .addSupport(PresenceStatementSupport.getInstance())
373             .addSupport(MaxElementsStatementSupport.getInstance())
374             .addSupport(MinElementsStatementSupport.getInstance())
375             .addSupport(OrderedByStatementSupport.getInstance())
376             .addSupport(WhenStatementSupport.createInstance(xpathSupport))
377             .addSupport(AugmentImplicitHandlingNamespace.BEHAVIOUR)
378             .addVersionSpecificSupport(VERSION_1, AugmentStatementRFC6020Support.getInstance())
379             .addVersionSpecificSupport(VERSION_1_1, AugmentStatementRFC7950Support.getInstance())
380             .addVersionSpecificSupport(VERSION_1, RefineStatementSupport.rfc6020Instance())
381             .addVersionSpecificSupport(VERSION_1_1, RefineStatementSupport.rfc7950Instance())
382             .addSupport(FeatureStatementSupport.getInstance())
383             .addSupport(PositionStatementSupport.getInstance())
384             .addSupport(ValueStatementSupport.getInstance())
385             .addSupport(YangNamespaceContextNamespace.BEHAVIOUR)
386             .build();
387     }
388 }