+++ /dev/null
-/*
- * Copyright (c) 2020 PANTHEON.tech, s.r.o. and others. All rights reserved.
- *
- * This program and the accompanying materials are made available under the
- * terms of the Eclipse Public License v1.0 which accompanies this distribution,
- * and is available at http://www.eclipse.org/legal/epl-v10.html
- */
-package org.opendaylight.yangtools.yang.parser.impl;
-
-import com.google.common.annotations.Beta;
-import java.util.Collection;
-import org.opendaylight.yangtools.yang.model.parser.api.YangParser;
-import org.opendaylight.yangtools.yang.model.parser.api.YangParserFactory;
-import org.opendaylight.yangtools.yang.model.repo.api.StatementParserMode;
-import org.opendaylight.yangtools.yang.xpath.api.YangXPathParserFactory;
-import org.osgi.service.component.annotations.Activate;
-import org.osgi.service.component.annotations.Component;
-import org.osgi.service.component.annotations.Deactivate;
-import org.osgi.service.component.annotations.Reference;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@Beta
-@Component(immediate = true)
-// FIXME: merge this with YangParserFactoryImpl once we have OSGi R7, which we really want because field injection is
-// a static analysis pain. It also results in not-obvious classes like this one.
-public final class OSGiYangParserFactory implements YangParserFactory {
- private static final Logger LOG = LoggerFactory.getLogger(OSGiYangParserFactory.class);
-
- @Reference
- YangXPathParserFactory xpathFactory = null;
-
- private YangParserFactory delegate = null;
-
- @Activate
- void activate() {
- delegate = new YangParserFactoryImpl(xpathFactory);
- LOG.info("YANG Parser activated");
- }
-
- @Deactivate
- void deactivate() {
- LOG.info("YANG Parser deactivated");
- delegate = null;
- }
-
- @Override
- public Collection<StatementParserMode> supportedParserModes() {
- return delegate.supportedParserModes();
- }
-
- @Override
- public YangParser createParser(final StatementParserMode parserMode) {
- return delegate.createParser(parserMode);
- }
-}
import org.opendaylight.yangtools.yang.model.repo.api.StatementParserMode;
import org.opendaylight.yangtools.yang.parser.stmt.reactor.CrossSourceStatementReactor;
import org.opendaylight.yangtools.yang.xpath.api.YangXPathParserFactory;
+import org.osgi.service.component.annotations.Activate;
+import org.osgi.service.component.annotations.Component;
+import org.osgi.service.component.annotations.Reference;
/**
* Reference {@link YangParserFactory} implementation.
- *
- * @author Robert Varga
*/
@Beta
@MetaInfServices
@Singleton
+@Component(immediate = true)
public final class YangParserFactoryImpl implements YangParserFactory {
private static final ImmutableList<StatementParserMode> SUPPORTED_MODES = ImmutableList.of(
StatementParserMode.DEFAULT_MODE, StatementParserMode.SEMVER_MODE);
-
private final CrossSourceStatementReactor reactor;
+ private YangParserFactoryImpl(final @NonNull CrossSourceStatementReactor reactor) {
+ this.reactor = requireNonNull(reactor);
+ }
+
/**
* Construct a new {@link YangParserFactory} backed by {@link DefaultReactors#defaultReactor()}.
*/
}
@Inject
- public YangParserFactoryImpl(final YangXPathParserFactory xpathFactory) {
+ @Activate
+ public YangParserFactoryImpl(final @Reference YangXPathParserFactory xpathFactory) {
this(DefaultReactors.defaultReactorBuilder(xpathFactory).build());
}
* Construct a new {@link YangParserFactory} backed by specified reactor.
*
* @param reactor Backing reactor
+ * @return A new YangParserFactory
*/
- public YangParserFactoryImpl(final @NonNull CrossSourceStatementReactor reactor) {
- this.reactor = requireNonNull(reactor);
+ public static @NonNull YangParserFactory forReactor(final @NonNull CrossSourceStatementReactor reactor) {
+ return new YangParserFactoryImpl(reactor);
}
@Override