
rx.plugins.RxJavaSchedulersHook Maven / Gradle / Ivy
/**
* Copyright 2014 Netflix, Inc.
*
* 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 rx.plugins;
import rx.Scheduler;
import rx.functions.Action0;
/**
* This plugin class provides 2 ways to customize {@link Scheduler} functionality
* 1. You may redefine entire schedulers, if you so choose. To do so, override
* the 3 methods that return Scheduler (io(), computation(), newThread()).
* 2. You may wrap/decorate an {@link Action0}, before it is handed off to a Scheduler. The system-
* supplied Schedulers (Schedulers.ioScheduler, Schedulers.computationScheduler,
* Scheduler.newThreadScheduler) all use this hook, so it's a convenient way to
* modify Scheduler functionality without redefining Schedulers wholesale.
*
* Also, when redefining Schedulers, you are free to use/not use the onSchedule decoration hook.
*
* See {@link RxJavaPlugins} or the RxJava GitHub Wiki for information on configuring plugins:
* https://github.com/ReactiveX/RxJava/wiki/Plugins.
*/
public class RxJavaSchedulersHook {
protected RxJavaSchedulersHook() {
}
private final static RxJavaSchedulersHook DEFAULT_INSTANCE = new RxJavaSchedulersHook();
/**
* Scheduler to return from {@link rx.schedulers.Schedulers#computation()} or null if default should be
* used.
*
* This instance should be or behave like a stateless singleton;
*/
public Scheduler getComputationScheduler() {
return null;
}
/**
* Scheduler to return from {@link rx.schedulers.Schedulers#io()} or null if default should be used.
*
* This instance should be or behave like a stateless singleton;
*/
public Scheduler getIOScheduler() {
return null;
}
/**
* Scheduler to return from {@link rx.schedulers.Schedulers#newThread()} or null if default should be used.
*
* This instance should be or behave like a stateless singleton;
*/
public Scheduler getNewThreadScheduler() {
return null;
}
/**
* Invoked before the Action is handed over to the scheduler. Can be used for wrapping/decorating/logging.
* The default is just a passthrough.
* @param action action to schedule
* @return wrapped action to schedule
*/
public Action0 onSchedule(Action0 action) {
return action;
}
public static RxJavaSchedulersHook getDefaultInstance() {
return DEFAULT_INSTANCE;
}
}