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