From 4b94a64b06057c723d6fcafeb1a45f55a70d179a Mon Sep 17 00:00:00 2001 From: Peter Johnson Date: Sun, 18 Feb 2024 16:29:58 -0800 Subject: [PATCH] [glass] Fix FMS game data display and editing (#6381) Also don't require Enter for editing game data or match time. --- glass/src/lib/native/cpp/other/FMS.cpp | 25 +++++++++++-------------- 1 file changed, 11 insertions(+), 14 deletions(-) diff --git a/glass/src/lib/native/cpp/other/FMS.cpp b/glass/src/lib/native/cpp/other/FMS.cpp index d49304e0396..4e702e5b481 100644 --- a/glass/src/lib/native/cpp/other/FMS.cpp +++ b/glass/src/lib/native/cpp/other/FMS.cpp @@ -5,6 +5,7 @@ #include "glass/other/FMS.h" #include +#include #include #include "glass/DataSource.h" @@ -58,8 +59,7 @@ void glass::DisplayFMS(FMSModel* model, bool editableDsAttached) { if (auto data = model->GetMatchTimeData()) { double val = data->GetValue(); ImGui::SetNextItemWidth(ImGui::GetFontSize() * 8); - if (ImGui::InputDouble("Match Time", &val, 0, 0, "%.1f", - ImGuiInputTextFlags_EnterReturnsTrue)) { + if (ImGui::InputDouble("Match Time", &val, 0, 0, "%.1f")) { model->SetMatchTime(val); } data->EmitDrag(); @@ -78,16 +78,12 @@ void glass::DisplayFMS(FMSModel* model, bool editableDsAttached) { } // Game Specific Message - // make buffer full 64 width, null terminated, for editability - wpi::SmallString<64> gameSpecificMessage; - model->GetGameSpecificMessage(gameSpecificMessage); - gameSpecificMessage.resize(63); - gameSpecificMessage.push_back('\0'); + wpi::SmallString<64> gameSpecificMessageBuf; + std::string gameSpecificMessage{ + model->GetGameSpecificMessage(gameSpecificMessageBuf)}; ImGui::SetNextItemWidth(ImGui::GetFontSize() * 8); - if (ImGui::InputText("Game Specific", gameSpecificMessage.data(), - gameSpecificMessage.size(), - ImGuiInputTextFlags_EnterReturnsTrue)) { - model->SetGameSpecificMessage(gameSpecificMessage.data()); + if (ImGui::InputText("Game Specific", &gameSpecificMessage)) { + model->SetGameSpecificMessage(gameSpecificMessage); } } @@ -151,9 +147,10 @@ void glass::DisplayFMSReadOnly(FMSModel* model) { } } - wpi::SmallString<64> gameSpecificMessage; - model->GetGameSpecificMessage(gameSpecificMessage); - ImGui::Text("Game Specific: %s", exists ? gameSpecificMessage.c_str() : "?"); + wpi::SmallString<64> gameSpecificMessageBuf; + std::string_view gameSpecificMessage = + model->GetGameSpecificMessage(gameSpecificMessageBuf); + ImGui::Text("Game Specific: %s", exists ? gameSpecificMessage.data() : "?"); if (!exists) { ImGui::PopStyleColor();