aboutsummaryrefslogtreecommitdiffstats
path: root/daemon/src/device_connection.h
diff options
context:
space:
mode:
Diffstat (limited to 'daemon/src/device_connection.h')
-rw-r--r--daemon/src/device_connection.h35
1 files changed, 26 insertions, 9 deletions
diff --git a/daemon/src/device_connection.h b/daemon/src/device_connection.h
index 5f2b051..9113f04 100644
--- a/daemon/src/device_connection.h
+++ b/daemon/src/device_connection.h
@@ -14,11 +14,18 @@ namespace midi_router
struct Device_Connection : public Sender
{
- Device_Connection(Device_Id const & source_id, std::string const & device_name, Submitter & submitter, RtMidiIn::RtMidiCallback callback):
+ Device_Connection(Device_Id const & source_id, std::string const & device_name, Submitter & submitter, RtMidiIn::RtMidiCallback callback, bool virtual_device):
source_id(source_id),
device_name(device_name),
- submitter(submitter)
+ submitter(submitter),
+ virtual_device(virtual_device)
{
+ if (virtual_device)
+ {
+ midi_in.openVirtualPort(device_name + " In");
+ midi_out.openVirtualPort(device_name + " Out");
+ }
+
midi_in.setCallback(callback, this);
midi_in.ignoreTypes(true, false, true);
}
@@ -26,6 +33,7 @@ struct Device_Connection : public Sender
Device_Id const & source_id;
std::string const & device_name;
Submitter & submitter;
+ bool const virtual_device;
RtMidiIn midi_in {};
RtMidiOut midi_out {};
std::mutex mutex {};
@@ -34,7 +42,10 @@ struct Device_Connection : public Sender
send(std::vector<std::uint8_t> const & payload) override
{
const std::lock_guard<std::mutex> lock(mutex);
- if (midi_out.isPortOpen()) midi_out.sendMessage(&payload);
+ if (midi_out.isPortOpen() || virtual_device)
+ {
+ midi_out.sendMessage(&payload);
+ }
}
std::string
@@ -46,17 +57,23 @@ struct Device_Connection : public Sender
void
connect(std::size_t port)
{
- const std::lock_guard<std::mutex> lock(mutex);
- if (!midi_in.isPortOpen()) midi_in.openPort(port);
- if (!midi_out.isPortOpen()) midi_out.openPort(port);
+ if (!virtual_device)
+ {
+ const std::lock_guard<std::mutex> lock(mutex);
+ if (!midi_in.isPortOpen()) midi_in.openPort(port);
+ if (!midi_out.isPortOpen()) midi_out.openPort(port);
+ }
}
void
disconnect()
{
- const std::lock_guard<std::mutex> lock(mutex);
- if (midi_in.isPortOpen()) midi_in.closePort();
- if (midi_out.isPortOpen()) midi_out.closePort();
+ if (!virtual_device)
+ {
+ const std::lock_guard<std::mutex> lock(mutex);
+ if (midi_in.isPortOpen()) midi_in.closePort();
+ if (midi_out.isPortOpen()) midi_out.closePort();
+ }
}
};