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

org.yamcs.yarch.Stream Maven / Gradle / Ivy

There is a newer version: 5.10.9
Show newest version
package org.yamcs.yarch;

import java.util.Collection;
import java.util.Collections;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong;

import org.yamcs.logging.Log;

/**
 * Streams are means to transport tuples.
 *
 */
public abstract class Stream {

    // states
    public static final int SETUP = 0;
    public static final int RUNNING = 1;
    public static final int QUITTING = 2;

    protected String name;
    protected TupleDefinition outputDefinition;
    final protected Collection subscribers = new ConcurrentLinkedQueue<>();

    protected AtomicInteger state = new AtomicInteger(SETUP);

    protected Log log;

    protected YarchDatabaseInstance ydb;
    private volatile AtomicLong dataCount = new AtomicLong();
    private volatile AtomicInteger subscriberCount = new AtomicInteger();
    private ExceptionHandler handler;

    protected Stream(YarchDatabaseInstance ydb, String name, TupleDefinition definition) {
        this.name = name;
        this.outputDefinition = definition;
        this.ydb = ydb;
        log = new Log(getClass(), ydb.getName());
        log.setContext(name);
    }

    /**
     * Start emitting tuples.
     */
    public abstract void doStart();

    public TupleDefinition getDefinition() {
        return outputDefinition;
    }

    public void emitTuple(Tuple tuple) {
        dataCount.incrementAndGet();
        for (StreamSubscriber s : subscribers) {
            try {
                s.onTuple(this, tuple);
            } catch (Exception e) {
                if (handler != null) {
                    handler.handle(tuple, s, e);
                } else {
                    log.warn("Exception received when emitting tuple to subscriber " + s, e);
                    throw e;
                }
            }
        }
    }

    public String getName() {
        return name;
    }

    public void setName(String streamName) {
        this.name = streamName;
    }

    public void addSubscriber(StreamSubscriber s) {
        subscribers.add(s);
        subscriberCount.incrementAndGet();
    }

    public void removeSubscriber(StreamSubscriber s) {
        subscribers.remove(s);
        subscriberCount.decrementAndGet();
    }

    public ColumnDefinition getColumnDefinition(String colName) {
        return outputDefinition.getColumn(colName);
    }

    /**
     * Start the stream by changing the state and calling {@link #doStart()}
     * 

* If the stream is already started, do nothing. */ final public void start() { if (state.compareAndSet(SETUP, RUNNING)) { doStart(); } } protected boolean isRunning() { return state.get() == RUNNING; } protected boolean quitting() { return state.get() == QUITTING; } /** * Closes the stream by changing the state, calling {@link #doClose()} sand then sending the streamClosed signal to * all subscribed clients. *

* if the stream is already closed, do nothing. */ public final void close() { int oldState = state.getAndSet(QUITTING); if (oldState == QUITTING) { return; } ydb.removeStream(name); log.debug("Closed stream {} num emitted tuples: {}", name, getDataCount()); doClose(); for (StreamSubscriber s : subscribers) { s.streamClosed(this); } } protected abstract void doClose(); public int getState() { return state.get(); } public boolean isClosed() { return state.get() == QUITTING; } public long getDataCount() { return dataCount.get(); } public int getSubscriberCount() { return subscriberCount.get(); } public Collection getSubscribers() { return Collections.unmodifiableCollection(subscribers); } public void exceptionHandler(ExceptionHandler h) { this.handler = h; } @Override public String toString() { return name; } public static interface ExceptionHandler { public void handle(Tuple tuple, StreamSubscriber s, Throwable t); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy