1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
|
// outputfunction.h
/******************************************************************************
*
* MiXViews - an X window system based sound & data editor/processor
*
* Copyright (c) 1993, 1994 Regents of the University of California
*
* Author: Douglas Scott
* Date: December 13, 1994
*
* Permission to use, copy and modify this software and its documentation
* for research and/or educational purposes and without fee is hereby granted,
* provided that the above copyright notice appear in all copies and that
* both that copyright notice and this permission notice appear in
* supporting documentation. The author reserves the right to distribute this
* software and its documentation. The University of California and the author
* make no representations about the suitability of this software for any
* purpose, and in no event shall University of California be liable for any
* damage, loss of data, or profits resulting from its use.
* It is provided "as is" without express or implied warranty.
*
******************************************************************************/
// Subclasses of ProcessFunction designed for producing samples rather than
// processing them. Direct subclasses of this are used for synthesis objects
// (see synthfunction.h). Other subclasses include the InputOutputFunction
// class (see iofunction.h).
//
// The current class heirarchy here is unsatisfactory, and will be reworked
// in a later version.
#ifndef OUTPUTFUNCTION_H
#ifdef __GNUG__
#pragma interface
#endif
#define OUTPUTFUNCTION_H
#include "localdefs.h"
#include "processfun.h"
#include "queue.h"
class Data;
// an OutputFunction produces samples but takes no samples as input
class OutputFunction : public ProcessFunction {
public:
OutputFunction(Data* output) : ProcessFunction(output) {}
virtual double operator () (RunStatus *status) = 0;
protected:
redefined int doApply(Data *);
};
// a QueuedOutputFunction buffers output data before returning it
class QueuedOutputFunction : public OutputFunction {
public:
QueuedOutputFunction(Data* output, int queueSize);
virtual ~QueuedOutputFunction() {}
redefined void restoreState();
redefined double operator () (RunStatus *status);
protected:
virtual RunStatus runProcess();
virtual int doProcessing() = 0;
int outQueueEmpty();
int outQueueFull();
int addToOutQueue(double value);
double takeFromOutQueue();
void setOutQueueSize(int size);
private:
Queue outputQueue;
};
inline int
QueuedOutputFunction::outQueueEmpty() { return outputQueue.empty(); }
inline int
QueuedOutputFunction::outQueueFull() { return outputQueue.full(); }
inline int
QueuedOutputFunction::addToOutQueue(double value) {
BUG("OutputFunction::addToOutQueue()");
return (outputQueue.addTo(value).full() != true);
}
inline double
QueuedOutputFunction::takeFromOutQueue() {
BUG("OutputFunction::takeFromOutQueue()");
return outputQueue.takeFrom();
}
#endif
|