All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cmonbaby.http.plugins.RxAndroidPlugins Maven / Gradle / Ivy

There is a newer version: 2.0.2
Show newest version
/*
 * 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 com.cmonbaby.http.plugins;

import java.util.concurrent.atomic.AtomicReference;
import rx.annotations.Experimental;

/**
 * Registry for plugin implementations that allows global override and handles the retrieval of
 * correct implementation based on order of precedence:
 * 
    *
  1. plugin registered globally via {@code register} methods in this class
  2. *
  3. default implementation
  4. *
*/ public final class RxAndroidPlugins { private static final RxAndroidPlugins INSTANCE = new RxAndroidPlugins(); public static RxAndroidPlugins getInstance() { return INSTANCE; } private final AtomicReference schedulersHook = new AtomicReference<>(); RxAndroidPlugins() { } /** * Reset any explicit or default-set hooks. *

* Note: This should only be used for testing purposes. */ @Experimental public void reset() { schedulersHook.set(null); } /** * Retrieves the instance of {@link RxAndroidSchedulersHook} to use based on order of * precedence as defined in the {@link RxAndroidPlugins} class header. *

* Override the default by calling {@link #registerSchedulersHook(RxAndroidSchedulersHook)} or by * setting the property {@code rxandroid.plugin.RxAndroidSchedulersHook.implementation} with the * full classname to load. */ public RxAndroidSchedulersHook getSchedulersHook() { if (schedulersHook.get() == null) { schedulersHook.compareAndSet(null, RxAndroidSchedulersHook.getDefaultInstance()); // We don't return from here but call get() again in case of thread-race so the winner will // always get returned. } return schedulersHook.get(); } /** * Registers an {@link RxAndroidSchedulersHook} implementation as a global override of any * injected or default implementations. * * @throws IllegalStateException if called more than once or after the default was initialized * (if usage occurs before trying to register) */ public void registerSchedulersHook(RxAndroidSchedulersHook impl) { if (!schedulersHook.compareAndSet(null, impl)) { throw new IllegalStateException( "Another strategy was already registered: " + schedulersHook.get()); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy