2 * Copyright (C) 2017 Robin Gareus <robin@gareus.org>
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version 2
7 * of the License, or (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 #ifndef _ardour_surfaces_fp8base_h_
20 #define _ardour_surfaces_fp8base_h_
25 #include "pbd/signals.h"
28 #define FP_NAMESPACE FP16
30 #define FP_NAMESPACE FP8
33 namespace ArdourSurface { namespace FP_NAMESPACE {
35 /* conveniece wrappers depending on "FP8Base& _base" */
36 #define fp8_loop dynamic_cast<BaseUI*>(&_base)->main_loop
37 #define fp8_context() dynamic_cast<BaseUI*>(&_base)
38 #define fp8_protocol() dynamic_cast<ControlProtocol*>(&_base)
40 /** Virtual abstract base of the FaderPort8 control surface
42 * This is passed as handle to all elements (buttons, lights,..)
43 * to inteface common functionality for the current instance:
45 * - global events (signals)
48 * It is implemented by FaderPort8
55 virtual size_t tx_midi (std::vector<uint8_t> const&) const = 0;
56 virtual std::string const& timecode () const = 0;
57 virtual std::string const& musical_time () const = 0;
58 virtual bool shift_mod () const = 0;
59 virtual bool show_meters () const = 0;
60 virtual bool show_panner () const = 0;
61 virtual bool twolinetext () const = 0;
62 virtual uint32_t clock_mode () const = 0;
64 size_t tx_midi2 (uint8_t sb, uint8_t d1) const
66 std::vector<uint8_t> d;
72 size_t tx_midi3 (uint8_t sb, uint8_t d1, uint8_t d2) const
74 std::vector<uint8_t> d;
81 size_t tx_sysex (size_t count, ...)
83 std::vector<uint8_t> d;
87 va_start (var_args, count);
88 for (size_t i = 0; i < count; ++i)
90 // uint8_t {aka unsigned char} is promoted to βintβ when passed through β...β
91 uint8_t b = va_arg (var_args, int);
100 size_t tx_text (uint8_t id, uint8_t line, uint8_t align, std::string const& txt)
102 std::vector<uint8_t> d;
105 d.push_back (id & 0x0f);
106 d.push_back (line & 0x03);
107 d.push_back (align & 0x07);
109 for (size_t i = 0; i < txt.size(); ++i)
111 d.push_back (txt[i]);
121 PBD::Signal1<void, bool> ShiftButtonChange;
122 PBD::Signal1<void, bool> ARMButtonChange;
125 PBD::Signal1<void, bool> BlinkIt;
126 PBD::Signal0<void> Periodic;
129 void sysexhdr (std::vector<uint8_t>& d)
131 /* faderport8 <SysExHdr> */
153 enum NavigationMode {
180 #endif /* _ardour_surfaces_fp8base_h_ */