mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-19 00:41:43 +00:00
Replace std::snprintf() with wpi::format_to_n_c_str() (#5645)
fmtlib uses consteval format string processing, which makes it more efficient than std::snprintf(). snprintf()s in libuv, mpack, processstarter, and wpigui were left alone. processstarter uses stdlib only, and wpigui only depends on imgui. fmt::format_to_n() is analogous to std::format_to_n() (https://en.cppreference.com/w/cpp/utility/format/format_to_n) wpi::format_to_n_c_str() is a wrapper which adds the trailing NUL.
This commit is contained in:
@@ -6,7 +6,6 @@
|
||||
|
||||
#include <cinttypes>
|
||||
#include <concepts>
|
||||
#include <cstdio>
|
||||
#include <cstring>
|
||||
#include <initializer_list>
|
||||
#include <memory>
|
||||
@@ -1177,12 +1176,17 @@ static void EmitValueTree(
|
||||
ImGui::TableNextRow();
|
||||
ImGui::TableNextColumn();
|
||||
EmitValueName(child.source.get(), child.name.c_str(), child.path.c_str());
|
||||
|
||||
ImGui::TableNextColumn();
|
||||
if (!child.valueChildren.empty()) {
|
||||
char label[64];
|
||||
std::snprintf(label, sizeof(label),
|
||||
child.valueChildrenMap ? "{...}##v_%s" : "[...]##v_%s",
|
||||
child.name.c_str());
|
||||
if (child.valueChildrenMap) {
|
||||
wpi::format_to_n_c_str(label, sizeof(label), "{{...}}##v_{}",
|
||||
child.name);
|
||||
} else {
|
||||
wpi::format_to_n_c_str(label, sizeof(label), "[...]##v_{}", child.name);
|
||||
}
|
||||
|
||||
if (TreeNodeEx(label, ImGuiTreeNodeFlags_SpanFullWidth)) {
|
||||
EmitValueTree(child.valueChildren, flags);
|
||||
TreePop();
|
||||
@@ -1208,10 +1212,16 @@ static void EmitEntry(NetworkTablesModel* model,
|
||||
ImGui::TableNextColumn();
|
||||
if (!entry.valueChildren.empty()) {
|
||||
auto pos = ImGui::GetCursorPos();
|
||||
|
||||
char label[64];
|
||||
std::snprintf(label, sizeof(label),
|
||||
entry.valueChildrenMap ? "{...}##v_%s" : "[...]##v_%s",
|
||||
entry.info.name.c_str());
|
||||
if (entry.valueChildrenMap) {
|
||||
wpi::format_to_n_c_str(label, sizeof(label), "{{...}}##v_{}",
|
||||
entry.info.name.c_str());
|
||||
} else {
|
||||
wpi::format_to_n_c_str(label, sizeof(label), "[...]##v_{}",
|
||||
entry.info.name.c_str());
|
||||
}
|
||||
|
||||
valueChildrenOpen =
|
||||
TreeNodeEx(label, ImGuiTreeNodeFlags_SpanFullWidth |
|
||||
ImGuiTreeNodeFlags_AllowItemOverlap);
|
||||
|
||||
Reference in New Issue
Block a user