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