2 Copyright (C) 2014 Waves Audio Ltd.
\r
4 This program is free software; you can redistribute it and/or modify
\r
5 it under the terms of the GNU General Public License as published by
\r
6 the Free Software Foundation; either version 2 of the License, or
\r
7 (at your option) any later version.
\r
9 This program is distributed in the hope that it will be useful,
\r
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
12 GNU General Public License for more details.
\r
14 You should have received a copy of the GNU General Public License
\r
15 along with this program; if not, write to the Free Software
\r
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
\r
20 #include "waves_audiobackend.h"
\r
21 #include "waves_audioport.h"
\r
22 #include "waves_midiport.h"
\r
23 #include "waves_midi_event.h"
\r
25 using namespace ARDOUR;
\r
28 WavesAudioBackend::port_name_size () const
\r
34 WavesAudioBackend::set_port_name (PortHandle port_handle, const std::string& port_name)
\r
36 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::set_port_name (): [" << std::hex << port_handle << std::dec << "], [" << port_name << "]" << std::endl;
\r
38 if (!_registered (port_handle)) {
\r
39 std::cerr << "WavesAudioBackend::set_port_name (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
43 return ((WavesAudioPort*)port_handle)->set_name (__instantiated_name + ":" + port_name);
\r
48 WavesAudioBackend::get_port_name (PortHandle port_handle) const
\r
50 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_port_name (): [" << std::hex << port_handle << std::dec << "]" << std::endl;
\r
51 if (!_registered (port_handle)) {
\r
52 std::cerr << "WavesAudioBackend::get_port_name (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
53 return std::string ();
\r
55 // COMMENTED DBG LOGS */ else std::cout << "\t[" << ((WavesAudioPort*)port_handle)->name () << "]" << std::endl;
\r
57 return ((WavesAudioPort*)port_handle)->name ();
\r
61 PortEngine::PortHandle
\r
62 WavesAudioBackend::get_port_by_name (const std::string& port_name) const
\r
64 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_port_by_name (): [" << port_name << "]" << std::endl;
\r
66 PortHandle port_handle = (PortHandle)_find_port (port_name);
\r
68 std::cerr << "WavesAudioBackend::get_port_by_name (): Failed to find port [" << port_name << "]!" << std::endl;
\r
76 WavesAudioBackend::_find_port (const std::string& port_name) const
\r
78 for (std::vector<WavesDataPort*>::const_iterator it = _ports.begin (); it != _ports.end (); ++it) {
\r
79 if ((*it)->name () == port_name) {
\r
89 WavesAudioBackend::get_ports (const std::string& port_name_pattern, DataType type, PortFlags flags, std::vector<std::string>& port_names) const
\r
92 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_ports (): \n\tPattern: [" << port_name_pattern << "]\n\tType: " << type << "\n\tFlags: " << flags << endl;
\r
94 unsigned found_ports =0;
\r
96 for (size_t i = 0; i < _ports.size (); ++i) {
\r
97 WavesDataPort* port = _ports[i];
\r
99 if ((port->type () == type) && (port->flags () & flags)) {
\r
100 port_names.push_back (port->name ());
\r
104 return found_ports;
\r
109 WavesAudioBackend::port_data_type (PortHandle port_handle) const
\r
111 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::port_data_type" << std::endl;
\r
113 if (!_registered (port_handle)) {
\r
114 std::cerr << "WavesAudioBackend::port_data_type (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
115 return DataType::NIL;
\r
118 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::port_data_type: " << endl;
\r
120 return ((WavesAudioPort*)port_handle)->type ();
\r
124 PortEngine::PortHandle
\r
125 WavesAudioBackend::register_port (const std::string& shortname, ARDOUR::DataType type, ARDOUR::PortFlags flags)
\r
127 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::register_port (): " << type.to_string () << " [" << shortname << "]" << std::endl;
\r
129 if (shortname.size () == 0) {
\r
130 std::cerr << "WavesAudioBackend::register_port (): Invalid (empty) port name!" << std::endl;
\r
134 if (flags & IsPhysical) {
\r
135 std::cerr << "WavesAudioBackend::register_port (): Unexpected attribute for port [" << shortname << "]! The port must not be physical!";
\r
139 return (PortEngine::PortHandle)_register_port (__instantiated_name + ":" + shortname, type, flags);
\r
144 WavesAudioBackend::_register_port (const std::string& port_name, ARDOUR::DataType type, ARDOUR::PortFlags flags)
\r
146 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::_register_port (): [" << port_name << "]" << std::endl;
\r
148 if (_find_port (port_name) != NULL) {
\r
149 std::cerr << "WavesAudioBackend::register_port () : Port [" << port_name << "] is already registered!" << std::endl;
\r
153 WavesDataPort* port = NULL;
\r
155 case ARDOUR::DataType::AUDIO: {
\r
156 WavesAudioPort* audio_port = new WavesAudioPort (port_name, flags);
\r
157 if (flags & IsPhysical)
\r
159 if (flags & IsOutput)
\r
161 _physical_audio_inputs.push_back (audio_port);
\r
162 // COMMENTED DBG LOGS */ std::cout << "\t\t" << port_name << " added to physical AUDIO Inputs !" << std::endl;
\r
164 else if (flags & IsInput)
\r
166 _physical_audio_outputs.push_back (audio_port);
\r
167 // COMMENTED DBG LOGS */ std::cout << "\t\t" << port_name << " added to physical AUDIO Outputs !" << std::endl;
\r
172 case ARDOUR::DataType::MIDI: {
\r
173 WavesMidiPort* midi_port = new WavesMidiPort (port_name, flags);
\r
174 if (flags & IsPhysical)
\r
176 if (flags & IsOutput)
\r
178 _physical_midi_inputs.push_back (midi_port);
\r
179 // COMMENTED DBG LOGS */ std::cout << "\t\t" << port_name << " added to physical MIDI Inputs !" << std::endl;
\r
181 else if (flags & IsInput)
\r
183 _physical_midi_outputs.push_back (midi_port);
\r
184 // COMMENTED DBG LOGS */ std::cout << "\t\t" << port_name << " added to physical MIDI Outputs !" << std::endl;
\r
190 std::cerr << "WavesAudioBackend::register_port () : Invalid data type (" << (uint32_t)type << ") applied to port [" << port_name << "]!" << std::endl;
\r
194 _ports.push_back (port);
\r
201 WavesAudioBackend::unregister_port (PortHandle port_handle)
\r
203 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::unregister_port ():" << std::hex << port_handle << std::dec << std::endl;
\r
205 // so far we suppose all disconnections will be done prior to unregistering.
\r
206 WavesDataPort* port = (WavesDataPort*)port_handle;
\r
207 std::vector<WavesDataPort*>::iterator port_iterator = std::find (_ports.begin (), _ports.end (), (WavesDataPort*)port_handle);
\r
208 if (port_iterator == _ports.end ()) {
\r
209 std::cerr << "WavesAudioBackend::unregister_port (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
212 // COMMENTED DBG LOGS */ std::cout << "\t[" << ((WavesDataPort*)port_handle)->name () << "]" << std::endl;
\r
214 _ports.erase (port_iterator);
\r
216 if (port->is_physical ()) {
\r
217 if (port->is_output ()) {
\r
218 switch (port->type ()) {
\r
219 case ARDOUR::DataType::AUDIO: {
\r
220 std::vector<WavesAudioPort*>::iterator audio_port_iterator = std::find (_physical_audio_inputs.begin (), _physical_audio_inputs.end (), port);
\r
221 if (audio_port_iterator == _physical_audio_inputs.end ()) {
\r
222 std::cerr << "WavesAudioBackend::unregister_port (): Failed to find port [" << port->name () << "] in the list of registered physical audio inputs!" << std::endl;
\r
225 _physical_audio_inputs.erase (audio_port_iterator);
\r
228 case ARDOUR::DataType::MIDI: {
\r
229 std::vector<WavesMidiPort*>::iterator midi_port_iterator = std::find (_physical_midi_inputs.begin (), _physical_midi_inputs.end (), port);
\r
230 if (midi_port_iterator == _physical_midi_inputs.end ()) {
\r
231 std::cerr << "WavesAudioBackend::unregister_port (): Failed to find port [" << port->name () << "] in the list of registered physical midi inputs!" << std::endl;
\r
234 _physical_midi_inputs.erase (midi_port_iterator);
\r
238 std::cerr << "WavesAudioBackend::unregister_port (): Invalid type (" << port->type () << " applied to [" << port->name () << "]!" << std::endl;
\r
242 else if (port->flags () & IsInput) {
\r
243 switch (port->type ()) {
\r
244 case ARDOUR::DataType::AUDIO: {
\r
245 std::vector<WavesAudioPort*>::iterator audio_port_iterator = std::find (_physical_audio_outputs.begin (), _physical_audio_outputs.end (), port);
\r
246 if (audio_port_iterator == _physical_audio_outputs.end ())
\r
248 std::cerr << "WavesAudioBackend::unregister_port: Failed to find port [" << port->name () << std::dec << "] in the list of registered physical audio outputs!\n";
\r
251 _physical_audio_outputs.erase (audio_port_iterator);
\r
254 case ARDOUR::DataType::MIDI: {
\r
256 std::vector<WavesMidiPort*>::iterator midi_port_iterator = std::find (_physical_midi_outputs.begin (), _physical_midi_outputs.end (), port);
\r
257 if (midi_port_iterator == _physical_midi_outputs.end ())
\r
259 std::cerr << "WavesAudioBackend::unregister_port: Failed to find port [" << port->name () << std::dec << "] in the list of registered physical midi outputs!\n";
\r
262 _physical_midi_outputs.erase (midi_port_iterator);
\r
266 std::cerr << "WavesAudioBackend::unregister_port (): Invalid type (" << port->type () << " applied to [" << port->name () << "]!" << std::endl;
\r
277 WavesAudioBackend::connect (const std::string& src_port_name, const std::string& dst_port_name)
\r
279 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::connect (" << src_port_name << ", " << dst_port_name << "):" << std::endl;
\r
281 WavesDataPort* src_port = _find_port (src_port_name);
\r
282 if (src_port == NULL) {
\r
283 std::cerr << "WavesAudioBackend::connect: Failed to find source port " << src_port_name << " !" << std::endl;
\r
287 WavesDataPort* dst_port = _find_port (dst_port_name);
\r
288 if (dst_port == NULL) {
\r
289 std::cerr << "WavesAudioBackend::connect: Failed to find destination port " << dst_port_name << " !" << std::endl;
\r
293 // COMMENTED DBG LOGS */ std::cout << "\t\t (" << src_port << ", " << dst_port << "):" << std::endl;
\r
294 return src_port->connect (dst_port);
\r
299 WavesAudioBackend::connect (PortHandle src_port_handle, const std::string& dst_port_name)
\r
301 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::connect ():" << std::endl;
\r
302 if (!_registered (src_port_handle)) {
\r
303 std::cerr << "WavesAudioBackend::connect: Failed to find source port [" << std::hex << src_port_handle << std::dec << "]!" << std::endl;
\r
307 // COMMENTED DBG LOGS */ std::cout << "\t[" << std::hex << src_port_handle << std::dec << "]" << std::endl;
\r
308 // COMMENTED DBG LOGS */ std::cout << "\t[" << dst_port_name << "]" << std::endl;
\r
310 WavesDataPort* dst_port = _find_port (dst_port_name);
\r
311 if (dst_port == NULL) {
\r
312 std::cerr << "WavesAudioBackend::connect (): Failed to find destination port [" << dst_port_name << "]!" << std::endl;
\r
316 return ((WavesDataPort*)src_port_handle)->connect (dst_port);
\r
321 WavesAudioBackend::disconnect (PortHandle src_port_handle, const std::string& dst_port_name)
\r
323 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::disconnect (" << src_port_handle << ", " << dst_port_name << "):" << std::endl;
\r
324 if (!_registered (src_port_handle)) {
\r
325 std::cerr << "WavesAudioBackend::disconnect (): Failed to find source port [" << std::hex << src_port_handle << std::dec << "]!" << std::endl;
\r
329 // COMMENTED DBG LOGS */ std::cout << "\t[" << std::hex << src_port_handle << std::dec << "]" << std::endl;
\r
330 // COMMENTED DBG LOGS */ std::cout << "\t[" << dst_port_name << "]" << std::endl;
\r
332 WavesDataPort* dst_port = _find_port (dst_port_name);
\r
333 if (dst_port == NULL) {
\r
334 std::cerr << "WavesAudioBackend::disconnect (): Failed to find destination port [" << dst_port_name << "]!" << std::endl;
\r
338 return ((WavesDataPort*)src_port_handle)->disconnect (dst_port);
\r
343 WavesAudioBackend::disconnect_all (PortHandle port_handle)
\r
345 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::disconnect_all ():" << std::endl;
\r
346 if (!_registered (port_handle)) {
\r
347 std::cerr << "WavesAudioBackend::disconnect_all : Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
351 ((WavesDataPort*)port_handle)->disconnect_all ();
\r
358 WavesAudioBackend::disconnect (const std::string& src_port_name, const std::string& dst_port_name)
\r
360 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::disconnect (" << src_port_name << ", " << dst_port_name << "):" << std::endl;
\r
362 WavesDataPort* src_port = _find_port (src_port_name);
\r
363 if (src_port == NULL) {
\r
364 std::cerr << "WavesAudioBackend::disconnect : Failed to find source port!\n";
\r
368 WavesDataPort* dst_port = _find_port (dst_port_name);
\r
369 if (dst_port == NULL) {
\r
370 std::cerr << "WavesAudioBackend::disconnect : Failed to find destination port!\n";
\r
374 return dst_port->disconnect (src_port);
\r
379 WavesAudioBackend::connected (PortHandle port_handle, bool process_callback_safe)
\r
381 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::connected ():" << std::endl;
\r
382 if (!_registered (port_handle)) {
\r
383 std::cerr << "WavesAudioBackend::connected (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
387 return ((WavesDataPort*)port_handle)->is_connected ();
\r
392 WavesAudioBackend::connected_to (PortHandle src_port_handle, const std::string& dst_port_name, bool process_callback_safe)
\r
394 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::connected_to (" << src_port_handle << ", " << dst_port_name << ")" << std::endl;
\r
396 if (!_registered (src_port_handle)) {
\r
397 std::cerr << "WavesAudioBackend::connected_to : Failed to find source port!" << std::endl;
\r
401 WavesDataPort* dst_port = _find_port (dst_port_name);
\r
402 if (dst_port == NULL) {
\r
403 std::cerr << "WavesAudioBackend::connected_to : Failed to find destination port!" << std::endl;
\r
406 // COMMENTED DBG LOGS */ std::cout << "\t return " << ((((WavesDataPort*)src_port_handle)->is_connected (dst_port)) ? "YES":"NO") << ", " << dst_port_name << ")" << std::endl;
\r
407 return ((WavesDataPort*)src_port_handle)->is_connected (dst_port);
\r
412 WavesAudioBackend::physically_connected (PortHandle port_handle, bool process_callback_safe)
\r
414 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::physically_connected ():" << std::endl;
\r
416 if (!_registered (port_handle)) {
\r
417 std::cerr << "WavesAudioBackend::physically_connected (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
421 return ((WavesDataPort*)port_handle)->is_physically_connected ();
\r
426 WavesAudioBackend::get_connections (PortHandle port_handle, std::vector<std::string>& names, bool process_callback_safe)
\r
428 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_connections ()" << std::endl;
\r
430 if (!_registered (port_handle)) {
\r
431 std::cerr << "WavesAudioBackend::get_connections (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
435 if (names.size ()) {
\r
436 std::cerr << "WavesAudioBackend::get_connections () : Parameter 'names' is not empty!\n";
\r
440 const std::vector<WavesDataPort*>& connected_ports = ((WavesDataPort*)port_handle)->get_connections ();
\r
442 for (std::vector<WavesDataPort*>::const_iterator it = connected_ports.begin (); it != connected_ports.end (); ++it) {
\r
443 names.push_back ((*it)->name ());
\r
446 return (int)names.size ();
\r
451 WavesAudioBackend::request_input_monitoring (PortHandle, bool)
\r
453 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::request_input_monitoring: " << std::endl;
\r
459 WavesAudioBackend::ensure_input_monitoring (PortHandle, bool)
\r
461 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::ensure_input_monitoring: " << std::endl;
\r
467 WavesAudioBackend::monitoring_input (PortHandle)
\r
469 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::monitoring_input: " << std::endl;
\r
475 WavesAudioBackend::port_is_physical (PortHandle port_handle) const
\r
478 if (!_registered (port_handle)) {
\r
479 std::cerr << "WavesAudioBackend::port_is_physical (): Failed to find port [" << std::hex << port_handle << std::dec << "]!" << std::endl;
\r
483 return (((WavesAudioPort*)port_handle)->flags () & IsPhysical) != 0;
\r
488 WavesAudioBackend::get_physical_outputs (DataType type, std::vector<std::string>& names)
\r
490 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_physical_outputs ():" << std::endl << "\tdatatype = " << type << std::endl;
\r
493 case ARDOUR::DataType::AUDIO: {
\r
494 for (std::vector<WavesAudioPort*>::iterator it = _physical_audio_outputs.begin (); it != _physical_audio_outputs.end (); ++it) {
\r
495 // COMMENTED DBG LOGS */ std::cout << "\t" << (*it)->name () << std::endl;
\r
496 names.push_back ((*it)->name ());
\r
499 case ARDOUR::DataType::MIDI: {
\r
500 for (std::vector<WavesMidiPort*>::iterator it = _physical_midi_outputs.begin (); it != _physical_midi_outputs.end (); ++it) {
\r
501 // COMMENTED DBG LOGS */ std::cout << "\t" << (*it)->name () << std::endl;
\r
502 names.push_back ((*it)->name ());
\r
512 WavesAudioBackend::get_physical_inputs (DataType type, std::vector<std::string>& names)
\r
514 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::get_physical_inputs ():" << std::endl << "\tdatatype = " << type << std::endl;
\r
516 case ARDOUR::DataType::AUDIO: {
\r
517 for (std::vector<WavesAudioPort*>::iterator it = _physical_audio_inputs.begin (); it != _physical_audio_inputs.end (); ++it) {
\r
518 // COMMENTED DBG LOGS */ std::cout << "\t" << (*it)->name () << std::endl;
\r
519 names.push_back ((*it)->name ());
\r
522 case ARDOUR::DataType::MIDI: {
\r
523 for (std::vector<WavesMidiPort*>::iterator it = _physical_midi_inputs.begin (); it != _physical_midi_inputs.end (); ++it) {
\r
524 // COMMENTED DBG LOGS */ std::cout << "\t" << (*it)->name () << std::endl;
\r
525 names.push_back ((*it)->name ());
\r
535 WavesAudioBackend::n_physical_outputs () const
\r
537 ChanCount chan_count;
\r
538 chan_count.set (DataType::AUDIO, _physical_audio_outputs.size ());
\r
539 chan_count.set (DataType::MIDI, _physical_midi_outputs.size ());
\r
541 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::n_physical_outputs ():" << std::endl << "\ttotal = " << chan_count.n_total () << std::endl;
\r
548 WavesAudioBackend::n_physical_inputs () const
\r
550 ChanCount chan_count;
\r
551 chan_count.set (DataType::AUDIO, _physical_audio_inputs.size ());
\r
552 chan_count.set (DataType::MIDI, _physical_midi_inputs.size ());
\r
554 // COMMENTED DBG LOGS */ std::cout << "WavesAudioBackend::n_physical_outputs ():" << std::endl << "\ttotal = " << chan_count.n_total () << std::endl;
\r
561 WavesAudioBackend::get_buffer (PortHandle port_handle, pframes_t nframes)
\r
563 // Here we would check if the port is registered. However, we will not do it as
\r
564 // it's relatively VERY SLOW operation. So let's count on consistency
\r
565 // of the caller as get_buffer normally is called hundreds of "kilotimes" per second.
\r
567 if (port_handle == NULL) {
\r
568 std::cerr << "WavesAudioBackend::get_buffer : Invalid port handler <NULL>!" << std::endl;
\r
572 return ((WavesAudioPort*)port_handle)->get_buffer (nframes);
\r
577 WavesAudioBackend::_register_system_audio_ports ()
\r
580 std::cerr << "WavesAudioBackend::_register_system_audio_ports (): No device is set!" << std::endl;
\r
584 std::vector<std::string> input_channels = _device->InputChannels ();
\r
585 _max_input_channels = input_channels.size ();
\r
587 uint32_t channels = (_input_channels ? _input_channels : input_channels.size ());
\r
588 uint32_t port_number = 0;
\r
590 LatencyRange lr = {0,0};
\r
592 // Get latency for capture
\r
593 lr.min = lr.max = _device->GetLatency (false) + _device->CurrentBufferSize () + _systemic_input_latency;
\r
594 for (std::vector<std::string>::iterator it = input_channels.begin ();
\r
595 (port_number < channels) && (it != input_channels.end ());
\r
597 std::ostringstream port_name;
\r
598 port_name << "capture_" << ++port_number;
\r
600 WavesDataPort* port = _register_port ("system:" + port_name.str (), DataType::AUDIO , static_cast<PortFlags> (IsOutput | IsPhysical | IsTerminal));
\r
601 if (port == NULL) {
\r
602 std::cerr << "WavesAudioBackend::_create_system_audio_ports (): Failed registering port [" << port_name << "] for [" << _device->DeviceName () << "]" << std::endl;
\r
605 set_latency_range (port, false, lr);
\r
608 std::vector<std::string> output_channels = _device->OutputChannels ();
\r
609 _max_output_channels = output_channels.size ();
\r
610 channels = (_output_channels ? _output_channels : _max_output_channels);
\r
613 // Get latency for playback
\r
614 lr.min = lr.max = _device->GetLatency (true) + _device->CurrentBufferSize () + _systemic_output_latency;
\r
616 for (std::vector<std::string>::iterator it = output_channels.begin ();
\r
617 (port_number < channels) && (it != output_channels.end ());
\r
619 std::ostringstream port_name;
\r
620 port_name << "playback_" << ++port_number;
\r
621 WavesDataPort* port = _register_port ("system:" + port_name.str (), DataType::AUDIO , static_cast<PortFlags> (IsInput| IsPhysical | IsTerminal));
\r
622 if (port == NULL) {
\r
623 std::cerr << "WavesAudioBackend::_create_system_audio_ports (): Failed registering port ]" << port_name << "] for [" << _device->DeviceName () << "]" << std::endl;
\r
626 set_latency_range (port, true, lr);
\r
634 WavesAudioBackend::_unregister_system_audio_ports ()
\r
636 std::vector<WavesAudioPort*> physical_audio_ports = _physical_audio_inputs;
\r
637 physical_audio_ports.insert (physical_audio_ports.begin (), _physical_audio_outputs.begin (), _physical_audio_outputs.end ());
\r
639 for (std::vector<WavesAudioPort*>::const_iterator it = physical_audio_ports.begin (); it != physical_audio_ports.end (); ++it) {
\r
640 std::vector<WavesDataPort*>::iterator port_iterator = std::find (_ports.begin (), _ports.end (), *it);
\r
641 if (port_iterator == _ports.end ()) {
\r
642 std::cerr << "WavesAudioBackend::_unregister_system_audio_ports (): Failed to find port [" << (*it)->name () << "]!" << std::endl;
\r
645 _ports.erase (port_iterator);
\r
650 _physical_audio_inputs.clear ();
\r
651 _physical_audio_outputs.clear ();
\r