manually merge current version of WavesMidiDevice::{open,close}()

This commit is contained in:
Paul Davis 2015-03-31 17:08:21 -04:00
parent 83001e7e52
commit 458fc3ad75

View file

@ -68,74 +68,132 @@ WavesMidiDevice::~WavesMidiDevice ()
int int
WavesMidiDevice::open (PmTimeProcPtr time_proc, void* time_info) WavesMidiDevice::open (PmTimeProcPtr time_proc, void* time_info)
{ {
DEBUG_TRACE (DEBUG::WavesMIDI, string_compose ("WavesMidiDevice::open (): %1", name ())); DEBUG_TRACE (DEBUG::WavesMIDI, string_compose ("WavesMidiDevice::open (): %1", name ()));
if (is_input () ) { if (is_input () ) {
std::cout << "WavesMidiDevice::open (): INPUT" << _pm_input_id << "-[" << name () << "]!" << std::endl; // COMMENTED DBG LOGS */ std::cout << "WavesMidiDevice::open (): INPUT" << _pm_input_id << "-[" << name () << "]" << std::endl;
if (!_input_queue) {
_input_queue = Pm_QueueCreate (QUEUE_LENGTH, sizeof (const WavesMidiEvent*));
if (NULL == _input_queue) {
std::cerr << "WavesMidiDevice::open (): _input_queue = Pm_QueueCreate () failed for " << _pm_input_id << "-[" << name () << "]!" << std::endl;
return -1;
}
}
if (!_input_pm_stream) { if (!_input_pm_stream) {
if (pmNoError != Pm_OpenInput (&_input_pm_stream, // create queue
_pm_input_id, if (!_input_queue) {
NULL, // COMMENTED DBG LOGS */ std::cout << " going to Pm_QueueCreate for INPUT: " << std::endl;
1024, _input_queue = Pm_QueueCreate (QUEUE_LENGTH, sizeof (const WavesMidiEvent*));
time_proc, // COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
time_info)) { if (NULL == _input_queue) {
char* err_msg = new char[256]; std::cerr << "WavesMidiDevice::open (): _input_queue = Pm_QueueCreate () failed for " << _pm_input_id << "-[" << name () << "]!" << std::endl;
Pm_GetHostErrorText(err_msg, 256); return -1;
std::cerr << "WavesMidiDevice::open (): Pm_OpenInput () failed for " << _pm_input_id << "-[" << name () << "]!" << std::endl; }
std::cerr << "Error: " << err_msg << std::endl; }
_input_pm_stream = NULL; // create stream
_pm_input_id = pmNoDevice; // COMMENTED DBG LOGS */ std::cout << " going to Pm_OpenInput : " << std::endl;
close (); if (pmNoError != Pm_OpenInput (&_input_pm_stream,
return -1; _pm_input_id,
} NULL,
} 1024,
} time_proc,
time_info)) {
// COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
char* err_msg = new char[256];
Pm_GetHostErrorText(err_msg, 256);
std::cerr << "WavesMidiDevice::open (): Pm_OpenInput () failed for " << _pm_input_id << "-[" << name () << "]!" << std::endl;
std::cerr << " Port Midi Host Error: " << err_msg << std::endl;
close ();
return -1;
}
// COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
}
}
if (is_output () ) { if (is_output () ) {
std::cout << "WavesMidiDevice::open (): OUTPUT" << _pm_output_id << "-[" << name () << "]!" << std::endl; // COMMENTED DBG LOGS */ std::cout << "WavesMidiDevice::open (): OUTPUT" << _pm_output_id << "-[" << name () << "]" << std::endl;
if (!_output_queue) { if (!_output_pm_stream) {
_output_queue = Pm_QueueCreate (QUEUE_LENGTH, sizeof (const WavesMidiEvent*)); // create queue
if (NULL == _output_queue) { if (!_output_queue) {
std::cerr << "WavesMidiDevice::open (): _output_queue = Pm_QueueCreate () failed for " << _pm_output_id << "-[" << name () << "]!" << std::endl; // COMMENTED DBG LOGS */ std::cout << " going to Pm_QueueCreate for OUTPUT : " << std::endl;
return -1; _output_queue = Pm_QueueCreate (QUEUE_LENGTH, sizeof (const WavesMidiEvent*));
} // COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
} if (NULL == _output_queue) {
std::cerr << "WavesMidiDevice::open (): _output_queue = Pm_QueueCreate () failed for " << _pm_output_id << "-[" << name () << "]!" << std::endl;
if (!_output_pm_stream) { return -1;
if (pmNoError != Pm_OpenOutput (&_output_pm_stream, }
_pm_output_id, }
NULL, // create stream
1024, // COMMENTED DBG LOGS */ std::cout << " going to Pm_OpenOutput : " << std::endl;
time_proc, if (pmNoError != Pm_OpenOutput (&_output_pm_stream,
time_info, _pm_output_id,
LATENCY)) { NULL,
char* err_msg = new char[256]; 1024,
Pm_GetHostErrorText(err_msg, 256); time_proc,
std::cerr << "WavesMidiDevice::open (): Pm_OpenOutput () failed for " << _pm_output_id << "-[" << name () << "]!" << std::endl; time_info,
std::cerr << "Error: " << err_msg << std::endl; LATENCY)) {
_output_pm_stream = NULL; // COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
_pm_output_id = pmNoDevice; char* err_msg = new char[256];
return -1; Pm_GetHostErrorText(err_msg, 256);
} std::cerr << "WavesMidiDevice::open (): Pm_OpenOutput () failed for " << _pm_output_id << "-[" << name () << "]!" << std::endl;
} std::cerr << " Port Midi Host Error: " << err_msg << std::endl;
} close ();
return -1;
return 0; }
// COMMENTED DBG LOGS */ std::cout << " DONE : " << std::endl;
}
}
return 0;
} }
void
WavesMidiDevice::close () WavesMidiDevice::close ()
{ {
DEBUG_TRACE (DEBUG::WavesMIDI, string_compose ("WavesMidiDevice::close (): %1\n", name ()));
WavesMidiEvent *waves_midi_event;
// save _input_pm_stream and _output_pm_stream to local buf
PmStream* input_pm_stream = _input_pm_stream;
PmStream* output_pm_stream = _output_pm_stream;
_input_pm_stream = _output_pm_stream = NULL;
//input
if (input_pm_stream) {
// close stream
PmError err = Pm_Close (input_pm_stream);
if (err != pmNoError) {
char* err_msg = new char[256];
Pm_GetHostErrorText(err_msg, 256);
std::cerr << "WavesMidiDevice::close (): Pm_Close (input_pm_stream) failed (" << err << ") for " << input_pm_stream << "-[" << name () << "]!" << std::endl;
std::cerr << " Port Midi Host Error: " << err_msg << std::endl;
}
_pm_input_id = pmNoDevice;
}
// close queue
if (_input_queue) {
while (1 == Pm_Dequeue (_input_queue, &waves_midi_event)) {
delete waves_midi_event; // XXX possible dup free in ~WavesMidiBuffer() (?)
}
Pm_QueueDestroy (_input_queue);
_input_queue = NULL;
}
//output
if ( output_pm_stream ) {
// close stream
PmError err = Pm_Close (output_pm_stream);
if (err != pmNoError) {
char* err_msg = new char[256];
Pm_GetHostErrorText(err_msg, 256);
std::cerr << "WavesMidiDevice::close (): Pm_Close (output_pm_stream) failed (" << err << ") for " << output_pm_stream << "-[" << name () << "]!" << std::endl;
std::cerr << " Port Midi Host Error: " << err_msg << std::endl;
}
_pm_output_id = pmNoDevice;
}
// close queue
if (_output_queue) {
while (1 == Pm_Dequeue (_output_queue, &waves_midi_event)) {
delete waves_midi_event; // XXX possible dup free in ~WavesMidiBuffer() (?)
}
Pm_QueueDestroy (_output_queue);
_output_queue = NULL;
}
} }
void void