1
0
Fork 0
mirror of https://github.com/juce-framework/JUCE.git synced 2026-01-18 00:54:19 +00:00
JUCE/modules/juce_midi_ci/ci/juce_CIEncoding.h
2023-11-20 13:14:20 +00:00

108 lines
2.8 KiB
C++

/*
==============================================================================
This file is part of the JUCE library.
Copyright (c) 2022 - Raw Material Software Limited
JUCE is an open source library subject to commercial or open-source
licensing.
By using JUCE, you agree to the terms of both the JUCE 7 End-User License
Agreement and JUCE Privacy Policy.
End User License Agreement: www.juce.com/juce-7-licence
Privacy Policy: www.juce.com/juce-privacy-policy
Or: You may also use this code under the terms of the GPL v3 (see
www.gnu.org/licenses).
JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
DISCLAIMED.
==============================================================================
*/
namespace juce::midi_ci
{
#define JUCE_ENCODINGS X(ascii, "ASCII") X(mcoded7, "Mcoded7") X(zlibAndMcoded7, "zlib+Mcoded7")
/**
Identifies different encodings that may be used by property exchange messages.
@tags{Audio}
*/
enum class Encoding
{
#define X(name, unused) name,
JUCE_ENCODINGS
#undef X
};
/**
Utility functions for working with the Encoding enum.
@tags{Audio}
*/
struct EncodingUtils
{
EncodingUtils() = delete;
/** Converts an Encoding to a human-readable string. */
static const char* toString (Encoding e)
{
switch (e)
{
#define X(name, string) case Encoding::name: return string;
JUCE_ENCODINGS
#undef X
}
return nullptr;
}
/** Converts an encoding string from a property exchange JSON header to
an Encoding.
*/
static std::optional<Encoding> toEncoding (const char* str)
{
#define X(name, string) if (std::string_view (str) == std::string_view (string)) return Encoding::name;
JUCE_ENCODINGS
#undef X
return {};
}
};
#undef JUCE_ENCODINGS
} // namespace juce::midi_ci
#ifndef DOXYGEN
namespace juce
{
template <>
struct SerialisationTraits<midi_ci::Encoding>
{
static constexpr auto marshallingVersion = std::nullopt;
template <typename Archive>
void load (Archive& archive, midi_ci::Encoding& t)
{
String encoding;
archive (encoding);
t = midi_ci::EncodingUtils::toEncoding (encoding.toRawUTF8()).value_or (midi_ci::Encoding{});
}
template <typename Archive>
void save (Archive& archive, const midi_ci::Encoding& t)
{
archive (midi_ci::EncodingUtils::toString (t));
}
};
} // namespace juce
#endif // ifndef DOXYGEN