annotate core/RTAudioCommandLine.cpp @ 5:09f03ac40fcc

API improvements and cleanups. Now all common audio command-line options can be parsed automatically.
author andrewm
date Sat, 08 Nov 2014 16:16:55 +0100
parents
children a6beeba3a648
rev   line source
andrewm@5 1 /*
andrewm@5 2 * RTAudioCommandLine.cpp
andrewm@5 3 *
andrewm@5 4 * Created on: Nov 8, 2014
andrewm@5 5 * Author: parallels
andrewm@5 6 */
andrewm@5 7
andrewm@5 8 #include <iostream>
andrewm@5 9 #include <cstdlib>
andrewm@5 10 #include <cstring>
andrewm@5 11 #include <getopt.h>
andrewm@5 12
andrewm@5 13 #include "../include/RTAudio.h"
andrewm@5 14
andrewm@5 15 // Default command-line options for RTAudio
andrewm@5 16 struct option gDefaultLongOptions[] =
andrewm@5 17 {
andrewm@5 18 {"period", 1, NULL, 'p'},
andrewm@5 19 {"verbose", 0, NULL, 'v'},
andrewm@5 20 {"use-matrix", 1, NULL, 'm'},
andrewm@5 21 {"mute-speaker", 1, NULL, 'M'},
andrewm@5 22 {"dac-level", 1, NULL, 'D'},
andrewm@5 23 {"adc-level", 1, NULL, 'A'},
andrewm@5 24 {"hp-level", 1, NULL, 'H'},
andrewm@5 25 {NULL, 0, NULL, 0}
andrewm@5 26 };
andrewm@5 27
andrewm@5 28 const char gDefaultShortOptions[] = "p:vm:M:D:A:H:";
andrewm@5 29
andrewm@5 30 // This function sets the default settings for the RTAudioSettings structure
andrewm@5 31 void BeagleRT_defaultSettings(RTAudioSettings *settings)
andrewm@5 32 {
andrewm@5 33 // Set default values for settings
andrewm@5 34 settings->periodSize = 8;
andrewm@5 35 settings->beginMuted = 0;
andrewm@5 36 settings->dacLevel = DEFAULT_DAC_LEVEL;
andrewm@5 37 settings->adcLevel = DEFAULT_ADC_LEVEL;
andrewm@5 38 settings->headphoneLevel = DEFAULT_HP_LEVEL;
andrewm@5 39 settings->useMatrix = 1;
andrewm@5 40 settings->verbose = 0;
andrewm@5 41 settings->codecI2CAddress = CODEC_I2C_ADDRESS;
andrewm@5 42 settings->ampMutePin = kAmplifierMutePin;
andrewm@5 43 }
andrewm@5 44
andrewm@5 45 // This function drops in place of getopt() in the main() function
andrewm@5 46 // and handles the initialisation of the RTAudio settings using
andrewm@5 47 // standard command-line arguments. System default arguments will
andrewm@5 48 // be stored in settings, otherwise arguments will be returned
andrewm@5 49 // as getopt() normally does.
andrewm@5 50
andrewm@5 51 int BeagleRT_getopt_long(int argc, char *argv[], const char *customShortOptions, const struct option *customLongOptions, RTAudioSettings *settings)
andrewm@5 52 {
andrewm@5 53 static int firstRun = 1;
andrewm@5 54 static char totalShortOptions[256];
andrewm@5 55 static struct option totalLongOptions[256];
andrewm@5 56
andrewm@5 57 int c;
andrewm@5 58
andrewm@5 59 // Prep total option string the first time this is
andrewm@5 60 // run. As a getopt() substitute, it will be called repeatedly working its
andrewm@5 61 // way through argc and argv.
andrewm@5 62 if(firstRun) {
andrewm@5 63 firstRun = 0;
andrewm@5 64
andrewm@5 65 // Copy short options into one string
andrewm@5 66 strcpy(totalShortOptions, gDefaultShortOptions);
andrewm@5 67 strncat(totalShortOptions, customShortOptions, 256 - strlen(gDefaultShortOptions) - 1);
andrewm@5 68
andrewm@5 69 // Copy long options into one array
andrewm@5 70 int n = 0;
andrewm@5 71 while(1) {
andrewm@5 72 if(gDefaultLongOptions[n].name == NULL)
andrewm@5 73 break;
andrewm@5 74 totalLongOptions[n].name = gDefaultLongOptions[n].name;
andrewm@5 75 totalLongOptions[n].has_arg = gDefaultLongOptions[n].has_arg;
andrewm@5 76 totalLongOptions[n].flag = gDefaultLongOptions[n].flag;
andrewm@5 77 totalLongOptions[n].val = gDefaultLongOptions[n].val;
andrewm@5 78 n++;
andrewm@5 79 }
andrewm@5 80
andrewm@5 81 // Copy custom options into the array, if present
andrewm@5 82 if(customLongOptions == 0) {
andrewm@5 83 // Terminate the array
andrewm@5 84 totalLongOptions[n].name = NULL;
andrewm@5 85 totalLongOptions[n].has_arg = 0;
andrewm@5 86 totalLongOptions[n].flag = NULL;
andrewm@5 87 totalLongOptions[n].val = 0;
andrewm@5 88 }
andrewm@5 89 else {
andrewm@5 90 int customIndex = 0;
andrewm@5 91 while(n < 256) {
andrewm@5 92 if(customLongOptions[customIndex].name == NULL)
andrewm@5 93 break;
andrewm@5 94 totalLongOptions[n].name = customLongOptions[customIndex].name;
andrewm@5 95 totalLongOptions[n].has_arg = customLongOptions[customIndex].has_arg;
andrewm@5 96 totalLongOptions[n].flag = customLongOptions[customIndex].flag;
andrewm@5 97 totalLongOptions[n].val = customLongOptions[customIndex].val;
andrewm@5 98 n++;
andrewm@5 99 customIndex++;
andrewm@5 100 }
andrewm@5 101
andrewm@5 102 // Terminate the array
andrewm@5 103 totalLongOptions[n].name = NULL;
andrewm@5 104 totalLongOptions[n].has_arg = 0;
andrewm@5 105 totalLongOptions[n].flag = NULL;
andrewm@5 106 totalLongOptions[n].val = 0;
andrewm@5 107 }
andrewm@5 108 }
andrewm@5 109
andrewm@5 110 while(1) {
andrewm@5 111 if ((c = getopt_long(argc, argv, totalShortOptions, totalLongOptions, NULL)) < 0)
andrewm@5 112 return c;
andrewm@5 113
andrewm@5 114 switch (c) {
andrewm@5 115 case 'p':
andrewm@5 116 settings->periodSize = atoi(optarg);
andrewm@5 117 if(settings->periodSize < 1)
andrewm@5 118 settings->periodSize = 1;
andrewm@5 119 break;
andrewm@5 120 case 'v':
andrewm@5 121 settings->verbose = 1;
andrewm@5 122 break;
andrewm@5 123 case 'm':
andrewm@5 124 settings->useMatrix = atoi(optarg);
andrewm@5 125 break;
andrewm@5 126 case 'M':
andrewm@5 127 settings->beginMuted = atoi(optarg);
andrewm@5 128 break;
andrewm@5 129 case 'D':
andrewm@5 130 settings->dacLevel = atof(optarg);
andrewm@5 131 break;
andrewm@5 132 case 'A':
andrewm@5 133 settings->adcLevel = atof(optarg);
andrewm@5 134 break;
andrewm@5 135 case 'H':
andrewm@5 136 settings->headphoneLevel = atof(optarg);
andrewm@5 137 break;
andrewm@5 138 case '?':
andrewm@5 139 default:
andrewm@5 140 return c;
andrewm@5 141 }
andrewm@5 142 }
andrewm@5 143 }
andrewm@5 144
andrewm@5 145 // This function prints standard usage information for default arguments
andrewm@5 146 // Call from within your own usage function
andrewm@5 147 void BeagleRT_usage()
andrewm@5 148 {
andrewm@5 149 std::cerr << " --period [-p] period: Set the hardware period (buffer) size in matrix samples\n";
andrewm@5 150 std::cerr << " --dac-level [-D] dBs: Set the DAC output level (0dB max; -63.5dB min)\n";
andrewm@5 151 std::cerr << " --adc-level [-A] dBs: Set the ADC input level (0dB max; -12dB min)\n";
andrewm@5 152 std::cerr << " --hp-level [-H] dBs: Set the headphone output level (0dB max; -63.5dB min)\n";
andrewm@5 153 std::cerr << " --mute-speaker [-M] val: Set whether to mute the speaker initially (default: no)\n";
andrewm@5 154 std::cerr << " --use-matrix [-m] val: Set whether to use ADC/DAC matrix\n";
andrewm@5 155 std::cerr << " --verbose [-v]: Enable verbose logging information\n";
andrewm@5 156 }