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

co.paralleluniverse.strands.channels.reactivestreams.ChannelPublisher Maven / Gradle / Ivy

/*
 * Quasar: lightweight threads and actors for the JVM.
 * Copyright (c) 2013-2015, Parallel Universe Software Co. All rights reserved.
 * 
 * This program and the accompanying materials are dual-licensed under
 * either the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation
 *  
 *   or (per the licensee's choosing)
 *  
 * under the terms of the GNU Lesser General Public License version 3.0
 * as published by the Free Software Foundation.
 */
package co.paralleluniverse.strands.channels.reactivestreams;

import co.paralleluniverse.fibers.Fiber;
import co.paralleluniverse.fibers.FiberFactory;
import co.paralleluniverse.strands.SuspendableCallable;
import co.paralleluniverse.strands.channels.ReceivePort;
import java.util.concurrent.atomic.AtomicBoolean;
import org.reactivestreams.Publisher;
import org.reactivestreams.Subscriber;

/**
 *
 * @author pron
 */
class ChannelPublisher implements Publisher {
    private final FiberFactory ff;
    private final Object channel;
    private final AtomicBoolean subscribed;

    public ChannelPublisher(FiberFactory ff, Object channel, boolean singleSubscriber) {
        this.ff = ff != null ? ff : defaultFiberFactory;
        this.channel = channel;

        subscribed = singleSubscriber ? new AtomicBoolean() : null;
    }

    @Override
    public void subscribe(Subscriber s) {
        if (s == null)
            throw new NullPointerException(); // #1.9
        try {
            if (subscribed != null && !subscribed.compareAndSet(false, true))
                throw new RuntimeException("already subscribed");
            else
                ff.newFiber(newChannelSubscription(s, channel)).start();
        } catch (Exception e) {
            failedSubscribe(s, e);
        }
    }

    protected void failedSubscribe(Subscriber s, Throwable t) {
        s.onSubscribe(newChannelSubscription(s, channel));
        s.onError(t);
    }

    protected ChannelSubscription newChannelSubscription(Subscriber s, Object channel) {
        return new ChannelSubscription<>(s, (ReceivePort) channel);
    }

    private static final FiberFactory defaultFiberFactory = new FiberFactory() {
        @Override
        public  Fiber newFiber(SuspendableCallable target) {
            return new Fiber(target);
        }
    };
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy