/** * Copyright (c) 2016-present, RxJava Contributors. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License is * distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See * the License for the specific language governing permissions and limitations under the License. */ package io.reactivex.internal.fuseable; import io.reactivex.Flowable; /** * Interface indicating a operator implementation can be macro-fused back to Flowable in case * the operator goes from Flowable to some other reactive type and then the sequence calls * for toFlowable again: * <pre> * Single<Integer> single = Flowable.range(1, 10).reduce((a, b) -> a + b); * Flowable<Integer> flowable = single.toFlowable(); * </pre> * * The {@code Single.toFlowable()} will check for this interface and call the {@link #fuseToFlowable()} * to return a Flowable which could be the Flowable-specific implementation of reduce(BiFunction). * <p> * This causes a slight overhead in assembly time (1 instanceof check, 1 operator allocation and 1 dropped * operator) but does not incur the conversion overhead at runtime. * * @param <T> the value type */ public interface FuseToFlowable<T> { /** * Returns a (direct) Flowable for the operator. * <p>The implementation should handle the necessary RxJavaPlugins wrapping. * @return the Flowable instance */ Flowable<T> fuseToFlowable(); }