summaryrefslogtreecommitdiff
path: root/tests/twostreams.cpp
diff options
context:
space:
mode:
authorStephen Sinclair <sinclair@music.mcgill.ca>2013-10-10 23:55:47 +0200
committerStephen Sinclair <sinclair@music.mcgill.ca>2013-10-10 23:55:47 +0200
commit71d678163c1a267fd006dbddf5f7ff42a5986366 (patch)
treec47a187349966891fb32ad1435dfd75b3c493634 /tests/twostreams.cpp
parent9f727b28665547db7609c0baf5c39ca96af71565 (diff)
parenta3d2ee35944db4dd0a3a342bb7f2df69f229f45d (diff)
Merge 2.1 into releases
Diffstat (limited to 'tests/twostreams.cpp')
-rw-r--r--tests/twostreams.cpp34
1 files changed, 25 insertions, 9 deletions
diff --git a/tests/twostreams.cpp b/tests/twostreams.cpp
index 2356a5f..94a036c 100644
--- a/tests/twostreams.cpp
+++ b/tests/twostreams.cpp
@@ -3,7 +3,7 @@
twostreams.cpp
by Gary P. Scavone, 2001
- Text executable for audio playback,
+ Test executable for audio playback,
recording, duplex operation, stopping,
starting, and aborting operations.
Takes number of channels and sample
@@ -33,15 +33,17 @@ typedef signed short MY_TYPE;
typedef signed long MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_SINT32
#define SCALE 2147483647.0
+*/
typedef float MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_FLOAT32
#define SCALE 1.0
-*/
+/*
typedef double MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_FLOAT64
#define SCALE 1.0
+*/
#define BASE_RATE 0.005
#define TIME 2.0
@@ -50,30 +52,32 @@ void usage(void) {
/* Error function in case of incorrect command-line
argument specifications
*/
- cout << "\nuseage: twostreams N fs\n";
+ cout << "\nuseage: twostreams N fs <device>\n";
cout << " where N = number of channels,\n";
- cout << " and fs = the sample rate.\n\n";
+ cout << " fs = the sample rate,\n";
+ cout << " and device = the device to use (default = 0).\n\n";
exit(0);
}
int main(int argc, char *argv[])
{
- int chans, fs, device, buffer_size, stream1, stream2;
+ int chans, fs, buffer_size, stream1 = 0, stream2 = 0, device = 0;
long frames, counter = 0, i, j;
MY_TYPE *buffer1, *buffer2;
RtAudio *audio;
FILE *fd;
- double *data;
+ double *data = 0;
// minimal command-line checking
- if (argc != 3) usage();
+ if (argc != 3 && argc != 4 ) usage();
chans = (int) atoi(argv[1]);
fs = (int) atoi(argv[2]);
+ if ( argc == 4 )
+ device = (int) atoi(argv[3]);
// Open the realtime output device
buffer_size = 512;
- device = 0; // default device
try {
audio = new RtAudio();
}
@@ -86,6 +90,12 @@ int main(int argc, char *argv[])
FORMAT, fs, &buffer_size, 8);
stream2 = audio->openStream(0, 0, device, chans,
FORMAT, fs, &buffer_size, 8);
+ }
+ catch (RtError &) {
+ goto cleanup;
+ }
+
+ try {
buffer1 = (MY_TYPE *) audio->getStreamBuffer(stream1);
buffer2 = (MY_TYPE *) audio->getStreamBuffer(stream2);
}
@@ -126,7 +136,6 @@ int main(int argc, char *argv[])
cout << "\nStopping playback stream." << endl;
try {
audio->stopStream(stream1);
- audio->startStream(stream2);
}
catch (RtError &) {
goto cleanup;
@@ -134,6 +143,13 @@ int main(int argc, char *argv[])
fd = fopen("test.raw","wb");
+ try {
+ audio->startStream(stream2);
+ }
+ catch (RtError &) {
+ goto cleanup;
+ }
+
counter = 0;
cout << "\nStarting recording stream for " << TIME << " seconds." << endl;
while (counter < frames) {