/* Copyright © 2017 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 . */ // IMPORTANT NOTE: this file will be renamed to "framebuffer.h" when // stream work is complete #ifndef FRAMEBUFFER_H #define FRAMEBUFFER_H struct Range { double start, end; }; /// Abstract base class for all frame buffers. class FrameBuffer { public: /// Placeholder virtual destructor virtual ~FrameBuffer() {}; /// Returns size of the buffer. virtual unsigned size() const = 0; /// Returns a sample from given index. virtual double sample(unsigned i) const = 0; /// Returns minimum and maximum of the buffer values. virtual Range limits() const = 0; }; /// Common base class for index and writable frame buffers class ResizableBuffer : public FrameBuffer { /// Resize the buffer. /// /// @important Resizing to same value is an error. virtual void resize(unsigned n) = 0; }; /// Abstract base class for writable frame buffers class WFrameBuffer : public ResizableBuffer { /// Add samples to the buffer virtual void addSamples(double* samples, unsigned n) = 0; /// Reset all data to 0 virtual void clear() = 0; }; #endif // FRAMEBUFFER_H