annotate src/portaudio/bindings/cpp/include/portaudiocpp/Stream.hxx @ 107:71c914cf6201

Portaudio: add missed file
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 26 Mar 2013 12:14:11 +0000
parents 8a15ff55d9af
children
rev   line source
cannam@89 1 #ifndef INCLUDED_PORTAUDIO_STREAM_HXX
cannam@89 2 #define INCLUDED_PORTAUDIO_STREAM_HXX
cannam@89 3
cannam@89 4 #include "portaudio.h"
cannam@89 5
cannam@89 6 // ---------------------------------------------------------------------------------------
cannam@89 7
cannam@89 8 // Forward declaration(s):
cannam@89 9 namespace portaudio
cannam@89 10 {
cannam@89 11 class StreamParameters;
cannam@89 12 }
cannam@89 13
cannam@89 14 // ---------------------------------------------------------------------------------------
cannam@89 15
cannam@89 16 // Declaration(s):
cannam@89 17 namespace portaudio
cannam@89 18 {
cannam@89 19
cannam@89 20
cannam@89 21 //////
cannam@89 22 /// @brief A Stream represents an active or inactive input and/or output data
cannam@89 23 /// stream in the System.
cannam@89 24 ///
cannam@89 25 /// Concrete Stream classes should ensure themselves being in a closed state at
cannam@89 26 /// destruction (i.e. by calling their own close() method in their deconstructor).
cannam@89 27 /// Following good C++ programming practices, care must be taken to ensure no
cannam@89 28 /// exceptions are thrown by the deconstructor of these classes. As a consequence,
cannam@89 29 /// clients need to explicitly call close() to ensure the stream closed successfully.
cannam@89 30 ///
cannam@89 31 /// The Stream object can be used to manipulate the Stream's state. Also, time-constant
cannam@89 32 /// and time-varying information about the Stream can be retreived.
cannam@89 33 //////
cannam@89 34 class Stream
cannam@89 35 {
cannam@89 36 public:
cannam@89 37 // Opening/closing:
cannam@89 38 virtual ~Stream();
cannam@89 39
cannam@89 40 virtual void close();
cannam@89 41 bool isOpen() const;
cannam@89 42
cannam@89 43 // Additional set up:
cannam@89 44 void setStreamFinishedCallback(PaStreamFinishedCallback *callback);
cannam@89 45
cannam@89 46 // State management:
cannam@89 47 void start();
cannam@89 48 void stop();
cannam@89 49 void abort();
cannam@89 50
cannam@89 51 bool isStopped() const;
cannam@89 52 bool isActive() const;
cannam@89 53
cannam@89 54 // Stream info (time-constant, but might become time-variant soon):
cannam@89 55 PaTime inputLatency() const;
cannam@89 56 PaTime outputLatency() const;
cannam@89 57 double sampleRate() const;
cannam@89 58
cannam@89 59 // Stream info (time-varying):
cannam@89 60 PaTime time() const;
cannam@89 61
cannam@89 62 // Accessors for PortAudio PaStream, useful for interfacing
cannam@89 63 // with PortAudio add-ons (such as PortMixer) for instance:
cannam@89 64 const PaStream *paStream() const;
cannam@89 65 PaStream *paStream();
cannam@89 66
cannam@89 67 protected:
cannam@89 68 Stream(); // abstract class
cannam@89 69
cannam@89 70 PaStream *stream_;
cannam@89 71
cannam@89 72 private:
cannam@89 73 Stream(const Stream &); // non-copyable
cannam@89 74 Stream &operator=(const Stream &); // non-copyable
cannam@89 75 };
cannam@89 76
cannam@89 77
cannam@89 78 } // namespace portaudio
cannam@89 79
cannam@89 80
cannam@89 81 #endif // INCLUDED_PORTAUDIO_STREAM_HXX
cannam@89 82