2019-07-23 22:18:36 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <pajlada/serialize.hpp>
|
Sort and force grouping of includes (#4172)
This change enforces strict include grouping using IncludeCategories
In addition to adding this to the .clang-format file and applying it in the tests/src and src directories, I also did the following small changes:
In ChatterSet.hpp, I changed lrucache to a <>include
In Irc2.hpp, I change common/SignalVector.hpp to a "project-include"
In AttachedWindow.cpp, NativeMessaging.cpp, WindowsHelper.hpp, BaseWindow.cpp, and StreamerMode.cpp, I disabled clang-format for the windows-includes
In WindowDescriptors.hpp, I added the missing vector include. It was previously not needed because the include was handled by another file that was previously included first.
clang-format minimum version has been bumped, so Ubuntu version used in the check-formatting job has been bumped to 22.04 (which is the latest LTS)
2022-11-27 19:32:53 +01:00
|
|
|
#include <QString>
|
2019-07-23 22:18:36 +02:00
|
|
|
|
|
|
|
namespace pajlada {
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct Serialize<QString> {
|
|
|
|
static rapidjson::Value get(const QString &value,
|
|
|
|
rapidjson::Document::AllocatorType &a)
|
|
|
|
{
|
|
|
|
return rapidjson::Value(value.toUtf8(), a);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct Deserialize<QString> {
|
|
|
|
static QString get(const rapidjson::Value &value, bool *error = nullptr)
|
|
|
|
{
|
|
|
|
if (!value.IsString())
|
|
|
|
{
|
|
|
|
PAJLADA_REPORT_ERROR(error)
|
|
|
|
return QString{};
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
return QString::fromUtf8(value.GetString(),
|
|
|
|
value.GetStringLength());
|
|
|
|
}
|
|
|
|
catch (const std::exception &)
|
|
|
|
{
|
|
|
|
// int x = 5;
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
// int y = 5;
|
|
|
|
}
|
|
|
|
|
|
|
|
return QString{};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace pajlada
|