The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

50 lines
1.6KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2022 - Raw Material Software Limited
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 7 End-User License
  8. Agreement and JUCE Privacy Policy.
  9. End User License Agreement: www.juce.com/juce-7-licence
  10. Privacy Policy: www.juce.com/juce-privacy-policy
  11. Or: You may also use this code under the terms of the GPL v3 (see
  12. www.gnu.org/licenses).
  13. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  14. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  15. DISCLAIMED.
  16. ==============================================================================
  17. */
  18. namespace juce::midi_ci
  19. {
  20. /**
  21. Contains information about a MIDI 2.0 function block.
  22. @tags{Audio}
  23. */
  24. struct FunctionBlock
  25. {
  26. std::byte identifier { 0x7f }; ///< 0x7f == no function block
  27. uint8_t firstGroup = 0; ///< The first group that is part of the block, 0-based
  28. uint8_t numGroups = 1; ///< The number of groups contained in the block
  29. bool operator== (const FunctionBlock& other) const
  30. {
  31. const auto tie = [] (auto& x) { return std::tie (x.identifier, x.firstGroup, x.numGroups); };
  32. return tie (*this) == tie (other);
  33. }
  34. bool operator!= (const FunctionBlock& other) const { return ! operator== (other); }
  35. };
  36. } // namespace juce::midi_ci