From 5da556b9a4094da461a4c88249fb0359172d72d2 Mon Sep 17 00:00:00 2001 From: Shauren Date: Fri, 3 Jan 2025 13:04:19 +0100 Subject: Core/Database: Added std::span based functions to Field and PreparedStatement (cherry picked from commit 27860c3316b7354c6bf17cac82992085d2905934) # Conflicts: # src/server/game/Entities/Player/Player.cpp --- src/server/database/Database/Field.cpp | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) (limited to 'src/server/database/Database/Field.cpp') diff --git a/src/server/database/Database/Field.cpp b/src/server/database/Database/Field.cpp index 664090839c0..6045e8dee81 100644 --- a/src/server/database/Database/Field.cpp +++ b/src/server/database/Database/Field.cpp @@ -124,26 +124,20 @@ char const* Field::GetCString() const std::string Field::GetString() const { - if (!_value) - return ""; - - char const* string = GetCString(); - if (!string) - return ""; + std::string result; + if (char const* string = GetCString()) + result.assign(string, _length); - return std::string(string, _length); + return result; } std::string_view Field::GetStringView() const { - if (!_value) - return {}; - - char const* const string = GetCString(); - if (!string) - return {}; + std::string_view result; + if (char const* const string = GetCString()) + result = { string, _length }; - return { string, _length }; + return result; } std::vector Field::GetBinary() const @@ -157,6 +151,11 @@ std::vector Field::GetBinary() const return result; } +std::span Field::GetBinaryView() const +{ + return { reinterpret_cast(_value), _length }; +} + void Field::GetBinarySizeChecked(uint8* buf, size_t length) const { ASSERT(_value && (_length == length), "Expected %zu-byte binary blob, got %sdata (%u bytes) instead", length, _value ? "" : "no ", _length); -- cgit v1.2.3