GraphicsTarget: Reduce object churn a little
This commit is contained in:
parent
1b7da37114
commit
7a59ecc39d
|
@ -155,45 +155,43 @@ std::optional<std::string> ExtractTextureFilenameForConfig(const picojson::objec
|
||||||
|
|
||||||
void SerializeTargetToConfig(picojson::object& json_obj, const GraphicsTargetConfig& target)
|
void SerializeTargetToConfig(picojson::object& json_obj, const GraphicsTargetConfig& target)
|
||||||
{
|
{
|
||||||
std::visit(
|
std::visit(overloaded{
|
||||||
overloaded{
|
|
||||||
[&](const DrawStartedTextureTarget& the_target) {
|
[&](const DrawStartedTextureTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"draw_started"};
|
json_obj.emplace("type", "draw_started");
|
||||||
json_obj["texture_filename"] = picojson::value{the_target.m_texture_info_string};
|
json_obj.emplace("texture_filename", the_target.m_texture_info_string);
|
||||||
},
|
},
|
||||||
[&](const LoadTextureTarget& the_target) {
|
[&](const LoadTextureTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"load_texture"};
|
json_obj.emplace("type", "load_texture");
|
||||||
json_obj["texture_filename"] = picojson::value{the_target.m_texture_info_string};
|
json_obj.emplace("texture_filename", the_target.m_texture_info_string);
|
||||||
},
|
},
|
||||||
[&](const CreateTextureTarget& the_target) {
|
[&](const CreateTextureTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"create_texture"};
|
json_obj.emplace("type", "create_texture");
|
||||||
json_obj["texture_filename"] = picojson::value{the_target.m_texture_info_string};
|
json_obj.emplace("texture_filename", the_target.m_texture_info_string);
|
||||||
},
|
},
|
||||||
[&](const EFBTarget& the_target) {
|
[&](const EFBTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"efb"};
|
json_obj.emplace("type", "efb");
|
||||||
json_obj["texture_filename"] = picojson::value{
|
json_obj.emplace("texture_filename",
|
||||||
fmt::format("{}_{}x{}_{}", EFB_DUMP_PREFIX, the_target.m_width, the_target.m_height,
|
fmt::format("{}_{}x{}_{}", EFB_DUMP_PREFIX, the_target.m_width,
|
||||||
static_cast<int>(the_target.m_texture_format))};
|
the_target.m_height,
|
||||||
|
static_cast<int>(the_target.m_texture_format)));
|
||||||
},
|
},
|
||||||
[&](const XFBTarget& the_target) {
|
[&](const XFBTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"xfb"};
|
json_obj.emplace("type", "xfb");
|
||||||
json_obj["texture_filename"] = picojson::value{
|
json_obj.emplace("texture_filename",
|
||||||
fmt::format("{}_{}x{}_{}", XFB_DUMP_PREFIX, the_target.m_width, the_target.m_height,
|
fmt::format("{}_{}x{}_{}", XFB_DUMP_PREFIX, the_target.m_width,
|
||||||
static_cast<int>(the_target.m_texture_format))};
|
the_target.m_height,
|
||||||
|
static_cast<int>(the_target.m_texture_format)));
|
||||||
},
|
},
|
||||||
[&](const ProjectionTarget& the_target) {
|
[&](const ProjectionTarget& the_target) {
|
||||||
json_obj["type"] = picojson::value{"projection"};
|
const char* type_name = "3d";
|
||||||
if (the_target.m_projection_type == ProjectionType::Orthographic)
|
if (the_target.m_projection_type == ProjectionType::Orthographic)
|
||||||
{
|
type_name = "2d";
|
||||||
json_obj["type"] = picojson::value{"2d"};
|
|
||||||
}
|
json_obj.emplace("type", type_name);
|
||||||
else
|
|
||||||
{
|
|
||||||
json_obj["type"] = picojson::value{"3d"};
|
|
||||||
}
|
|
||||||
if (the_target.m_texture_info_string)
|
if (the_target.m_texture_info_string)
|
||||||
{
|
{
|
||||||
json_obj["texture_filename"] = picojson::value{*the_target.m_texture_info_string};
|
json_obj.emplace("texture_filename", *the_target.m_texture_info_string);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue