Files
@ 5c0005f331cf
Branch filter:
Location: tempo-plotter/src/sink.h - annotation
5c0005f331cf
2.0 KiB
text/plain
various fixes to get stream to compile and some basic tests
d38d528e9c1c 391ab62116c8 d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c 391ab62116c8 391ab62116c8 5c0005f331cf d38d528e9c1c d38d528e9c1c d38d528e9c1c 5c0005f331cf d38d528e9c1c d38d528e9c1c d38d528e9c1c 5c0005f331cf 46213689acd3 46213689acd3 d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c 0bcc3039cc7c 5c0005f331cf d38d528e9c1c d38d528e9c1c 0bcc3039cc7c 5c0005f331cf 46213689acd3 46213689acd3 46213689acd3 46213689acd3 46213689acd3 46213689acd3 d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c d38d528e9c1c 46213689acd3 391ab62116c8 391ab62116c8 d38d528e9c1c d38d528e9c1c d38d528e9c1c | /*
Copyright © 2018 Hasan Yavuz Özderya
This file is part of serialplot.
serialplot is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
serialplot is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with serialplot. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef SINK_H
#define SINK_H
#include <QList>
#include "samplepack.h"
class Source;
class Sink
{
public:
/// Placeholder virtual destructor
virtual ~Sink() {};
/// Connects a sink to get any data that this sink
/// gets. Connecting an already connected sink is an error.
void connectFollower(Sink* sink);
/// Disconnects a follower. Disconnecting an unconnected sink is
/// an error.
void disconnectFollower(Sink* sink);
/// Returns the connected source. `NULL` if it's not connected.
const Source* connectedSource() const;
protected:
/// Entry point for incoming data. Re-implementations should
/// call this function to feed followers.
virtual void feedIn(const SamplePack& data);
/// Is set by connected source. Re-implementations should call
/// this function to update followers.
virtual void setNumChannels(unsigned nc, bool x);
/// Set by the connected source when its connected. When
/// disconnecting it's set to `NULL`.
///
/// @important Trying to connect a source while its already
/// connected is an error.
void setSource(const Source* s);
friend Source;
private:
QList<Sink*> followers;
const Source* source = NULL; ///< source that this sink is connected to
bool _hasX;
unsigned _numChannels;
};
#endif // SINK_H
|