aboutsummaryrefslogtreecommitdiffstats
path: root/daemon/src/routing.cpp
blob: 8dce6956fe99e52aabc0f30d040381e4f190bcd2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#include "routing.h"

#include <chrono>
#include <iostream>

namespace midi_router
{

void
Router::route(Route_Table const & config, bool verbose)
{
    Message m;
    if (m_queue.wait_dequeue_timed(m, std::chrono::milliseconds(500)))
    {
        if (!config.contains(*m.source_id) || !config.at(*m.source_id).contains(m.type()))
        {
            return;
        }

        // LTG: at least one of these map accesses can be avoided
        for (auto const & target: config.at(*m.source_id).at(m.type()))
        {
            if (verbose)
            {
                std::cout << "[" << type2string.at(m.type()) << "] " << *m.source_id << " -> " << target.get().get_id() << " | ";
                for (auto byte : m.bytes) std::cout << static_cast<unsigned>(byte) << " ";
                std::cout << ")\n";
            }
            target.get().send(m.bytes);
        }
    }
}

void
Router::submit(Message const & message)
{
    if (!m_queue.try_enqueue(message)) 
    {
        std::cerr << "Failed to enqueue message from " << *message.source_id << "\n";
    }
}

} // namespace midi_router