]> git.sesse.net Git - nageru/blobdiff - midi_mapper.h
Add an editor for the MIDI mappings.
[nageru] / midi_mapper.h
index 5b8b98ec37cfc38bef11e874cbb2c0125e6ffe25..84baf1f98d707760051e0142bf35f067b7a2cce0 100644 (file)
 #include <atomic>
 #include <functional>
 #include <memory>
+#include <mutex>
 #include <string>
 #include <thread>
 
 class MIDIMappingProto;
+typedef struct snd_seq_addr snd_seq_addr_t;
+typedef struct snd_seq_event snd_seq_event_t;
+typedef struct _snd_seq snd_seq_t;
 
 // Interface for receiving interpreted controller messages.
 class ControllerReceiver {
@@ -43,10 +47,12 @@ public:
        virtual ~MIDIMapper();
        void set_midi_mapping(const MIDIMappingProto &new_mapping);
        void start_thread();
-       const MIDIMappingProto &get_current_mapping() const { return *mapping_proto; }
+       const MIDIMappingProto &get_current_mapping() const;
 
 private:
        void thread_func();
+       void handle_event(snd_seq_t *seq, snd_seq_event_t *event);
+       void subscribe_to_port(snd_seq_t *seq, const snd_seq_addr_t &addr);
        void match_controller(int controller, int field_number, int bank_field_number, float value, std::function<void(unsigned, float)> func);
        void match_button(int note, int field_number, int bank_field_number, std::function<void(unsigned)> func);
        bool bank_mismatch(int bank_field_number);
@@ -55,9 +61,10 @@ private:
        std::atomic<bool> should_quit{false};
        int should_quit_fd;
 
-       std::unique_ptr<MIDIMappingProto> mapping_proto;
-       int num_controller_banks;
-       int current_controller_bank = 0;
+       mutable std::mutex mapping_mu;
+       std::unique_ptr<MIDIMappingProto> mapping_proto;  // Under <mapping_mu>.
+       int num_controller_banks;  // Under <mapping_mu>.
+       std::atomic<int> current_controller_bank{0};
 
        std::thread midi_thread;
 };