mirror of
https://github.com/cookiengineer/audacity
synced 2025-07-14 15:48:21 +02:00
Ensures that all files that Git considers to be text will have normalized (LF) line endings in the repository. When core.eol is set to native (which is the default), Git will convert the line endings of normalized files in your working directory back to your platform's native line ending. See also https://git-scm.com/docs/gitattributes
78 lines
2.5 KiB
C++
78 lines
2.5 KiB
C++
#ifndef INCLUDED_PORTAUDIO_STREAMPARAMETERS_HXX
|
|
#define INCLUDED_PORTAUDIO_STREAMPARAMETERS_HXX
|
|
|
|
// ---------------------------------------------------------------------------------------
|
|
|
|
#include "portaudio.h"
|
|
|
|
#include "portaudiocpp/DirectionSpecificStreamParameters.hxx"
|
|
|
|
// ---------------------------------------------------------------------------------------
|
|
|
|
// Declaration(s):
|
|
namespace portaudio
|
|
{
|
|
|
|
//////
|
|
/// @brief The entire set of parameters needed to configure and open
|
|
/// a Stream.
|
|
///
|
|
/// It contains parameters of input, output and shared parameters.
|
|
/// Using the isSupported() method, the StreamParameters can be
|
|
/// checked if opening a Stream using this StreamParameters would
|
|
/// succeed or not. Accessors are provided to higher-level parameters
|
|
/// aswell as the lower-level parameters which are mainly intended for
|
|
/// internal use.
|
|
//////
|
|
class StreamParameters
|
|
{
|
|
public:
|
|
StreamParameters();
|
|
StreamParameters(const DirectionSpecificStreamParameters &inputParameters,
|
|
const DirectionSpecificStreamParameters &outputParameters, double sampleRate,
|
|
unsigned long framesPerBuffer, PaStreamFlags flags);
|
|
|
|
// Set up for direction-specific:
|
|
void setInputParameters(const DirectionSpecificStreamParameters ¶meters);
|
|
void setOutputParameters(const DirectionSpecificStreamParameters ¶meters);
|
|
|
|
// Set up for common parameters:
|
|
void setSampleRate(double sampleRate);
|
|
void setFramesPerBuffer(unsigned long framesPerBuffer);
|
|
void setFlag(PaStreamFlags flag);
|
|
void unsetFlag(PaStreamFlags flag);
|
|
void clearFlags();
|
|
|
|
// Validation:
|
|
bool isSupported() const;
|
|
|
|
// Accessors (direction-specific):
|
|
DirectionSpecificStreamParameters &inputParameters();
|
|
const DirectionSpecificStreamParameters &inputParameters() const;
|
|
DirectionSpecificStreamParameters &outputParameters();
|
|
const DirectionSpecificStreamParameters &outputParameters() const;
|
|
|
|
// Accessors (common):
|
|
double sampleRate() const;
|
|
unsigned long framesPerBuffer() const;
|
|
PaStreamFlags flags() const;
|
|
bool isFlagSet(PaStreamFlags flag) const;
|
|
|
|
private:
|
|
// Half-duplex specific parameters:
|
|
DirectionSpecificStreamParameters inputParameters_;
|
|
DirectionSpecificStreamParameters outputParameters_;
|
|
|
|
// Common parameters:
|
|
double sampleRate_;
|
|
unsigned long framesPerBuffer_;
|
|
PaStreamFlags flags_;
|
|
};
|
|
|
|
|
|
} // namespace portaudio
|
|
|
|
// ---------------------------------------------------------------------------------------
|
|
|
|
#endif // INCLUDED_PORTAUDIO_STREAMPARAMETERS_HXX
|