Add YangParserConfiguration
[yangtools.git] / yang / yang-parser-impl / src / main / java / org / opendaylight / yangtools / yang / parser / impl / YangParserFactoryImpl.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.impl;
9
10 import static com.google.common.base.Preconditions.checkArgument;
11 import static java.util.Objects.requireNonNull;
12
13 import com.google.common.annotations.Beta;
14 import java.util.Collection;
15 import java.util.List;
16 import javax.inject.Inject;
17 import javax.inject.Singleton;
18 import org.eclipse.jdt.annotation.NonNull;
19 import org.kohsuke.MetaInfServices;
20 import org.opendaylight.yangtools.yang.model.parser.api.YangParser;
21 import org.opendaylight.yangtools.yang.model.parser.api.YangParserConfiguration;
22 import org.opendaylight.yangtools.yang.model.parser.api.YangParserFactory;
23 import org.opendaylight.yangtools.yang.model.repo.api.StatementParserMode;
24 import org.opendaylight.yangtools.yang.parser.stmt.reactor.CrossSourceStatementReactor;
25 import org.opendaylight.yangtools.yang.xpath.api.YangXPathParserFactory;
26 import org.osgi.service.component.annotations.Activate;
27 import org.osgi.service.component.annotations.Component;
28 import org.osgi.service.component.annotations.Reference;
29
30 /**
31  * Reference {@link YangParserFactory} implementation.
32  */
33 @Beta
34 @MetaInfServices
35 @Singleton
36 @Component(immediate = true)
37 public final class YangParserFactoryImpl implements YangParserFactory {
38     private static final List<StatementParserMode> SUPPORTED_MODES = List.of(
39         StatementParserMode.DEFAULT_MODE,
40         StatementParserMode.SEMVER_MODE);
41
42     private final CrossSourceStatementReactor reactor;
43
44     private YangParserFactoryImpl(final @NonNull CrossSourceStatementReactor reactor) {
45         this.reactor = requireNonNull(reactor);
46     }
47
48     /**
49      * Construct a new {@link YangParserFactory} backed by {@link DefaultReactors#defaultReactor()}.
50      */
51     public YangParserFactoryImpl() {
52         this(DefaultReactors.defaultReactor());
53     }
54
55     @Inject
56     @Activate
57     public YangParserFactoryImpl(final @Reference YangXPathParserFactory xpathFactory) {
58         this(DefaultReactors.defaultReactorBuilder(xpathFactory).build());
59     }
60
61     /**
62      * Construct a new {@link YangParserFactory} backed by specified reactor.
63      *
64      * @param reactor Backing reactor
65      * @return A new YangParserFactory
66      */
67     public static @NonNull YangParserFactory forReactor(final @NonNull CrossSourceStatementReactor reactor) {
68         return new YangParserFactoryImpl(reactor);
69     }
70
71     @Override
72     public Collection<StatementParserMode> supportedParserModes() {
73         return SUPPORTED_MODES;
74     }
75
76     @Override
77     public @NonNull YangParser createParser(final YangParserConfiguration configuration) {
78         final StatementParserMode mode = configuration.parserMode();
79         checkArgument(SUPPORTED_MODES.contains(mode), "Unsupported parser mode %s", mode);
80         return new YangParserImpl(reactor.newBuild(mode));
81     }
82 }