X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=yang%2Fyang-model-util%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyangtools%2Fyang%2Fmodel%2Frepo%2Futil%2FSchemaSourceTransformer.java;h=bb7da5593c8997fcae63b6f1cc7856a5e5643312;hb=da8e25edb78d9eb08303f365d41d2ae369fdce61;hp=b691317bf2a162899fb900ac7882fcc2fc354ce8;hpb=c7a0084b595bebb306475b8256e9334f3613d532;p=yangtools.git diff --git a/yang/yang-model-util/src/main/java/org/opendaylight/yangtools/yang/model/repo/util/SchemaSourceTransformer.java b/yang/yang-model-util/src/main/java/org/opendaylight/yangtools/yang/model/repo/util/SchemaSourceTransformer.java index b691317bf2..bb7da5593c 100644 --- a/yang/yang-model-util/src/main/java/org/opendaylight/yangtools/yang/model/repo/util/SchemaSourceTransformer.java +++ b/yang/yang-model-util/src/main/java/org/opendaylight/yangtools/yang/model/repo/util/SchemaSourceTransformer.java @@ -7,16 +7,16 @@ */ package org.opendaylight.yangtools.yang.model.repo.util; -import com.google.common.base.Preconditions; +import static java.util.Objects.requireNonNull; + import com.google.common.util.concurrent.AsyncFunction; -import com.google.common.util.concurrent.CheckedFuture; import com.google.common.util.concurrent.Futures; +import com.google.common.util.concurrent.ListenableFuture; +import com.google.common.util.concurrent.MoreExecutors; import java.util.HashMap; import java.util.Map; -import org.opendaylight.yangtools.util.concurrent.ExceptionMapper; -import org.opendaylight.yangtools.util.concurrent.ReflectiveExceptionMapper; +import javax.annotation.Nonnull; import org.opendaylight.yangtools.yang.model.repo.api.SchemaRepository; -import org.opendaylight.yangtools.yang.model.repo.api.SchemaSourceException; import org.opendaylight.yangtools.yang.model.repo.api.SchemaSourceRepresentation; import org.opendaylight.yangtools.yang.model.repo.api.SourceIdentifier; import org.opendaylight.yangtools.yang.model.repo.spi.PotentialSchemaSource; @@ -25,13 +25,14 @@ import org.opendaylight.yangtools.yang.model.repo.spi.SchemaSourceProvider; import org.opendaylight.yangtools.yang.model.repo.spi.SchemaSourceRegistration; import org.opendaylight.yangtools.yang.model.repo.spi.SchemaSourceRegistry; -public class SchemaSourceTransformer implements SchemaSourceListener, SchemaSourceProvider { - private static final ExceptionMapper MAPPER = ReflectiveExceptionMapper.create("Source transformation", SchemaSourceException.class); +public class SchemaSourceTransformer + implements SchemaSourceListener, SchemaSourceProvider { @FunctionalInterface - public interface Transformation extends AsyncFunction { + public interface Transformation + extends AsyncFunction { @Override - CheckedFuture apply(final S input) throws Exception; + ListenableFuture apply(@Nonnull S input) throws Exception; } private final Map, RefcountedRegistration> sources = new HashMap<>(); @@ -43,17 +44,17 @@ public class SchemaSourceTransformer srcClass, final SchemaSourceRegistry consumer, final Class dstClass, final AsyncFunction function) { - this.provider = Preconditions.checkNotNull(provider); - this.consumer = Preconditions.checkNotNull(consumer); - this.function = Preconditions.checkNotNull(function); - this.srcClass = Preconditions.checkNotNull(srcClass); - this.dstClass = Preconditions.checkNotNull(dstClass); + this.provider = requireNonNull(provider); + this.consumer = requireNonNull(consumer); + this.function = requireNonNull(function); + this.srcClass = requireNonNull(srcClass); + this.dstClass = requireNonNull(dstClass); } @Override - public CheckedFuture getSource(final SourceIdentifier sourceIdentifier) { - final CheckedFuture f = provider.getSchemaSource(sourceIdentifier, srcClass); - return Futures.makeChecked(Futures.transform(f, function), MAPPER); + public ListenableFuture getSource(final SourceIdentifier sourceIdentifier) { + return Futures.transformAsync(provider.getSchemaSource(sourceIdentifier, srcClass), function, + MoreExecutors.directExecutor()); } @Override