diff options
author | Shauren <shauren.trinity@gmail.com> | 2025-01-03 13:04:19 +0100 |
---|---|---|
committer | Ovahlord <dreadkiller@gmx.de> | 2025-01-03 18:05:04 +0100 |
commit | 5da556b9a4094da461a4c88249fb0359172d72d2 (patch) | |
tree | a18f013ee77e9f2bb9397c63d240cc4e49b12f6e /src/server/database/Database/Field.cpp | |
parent | a7587de5ede4da43cdc87a98322e2002093985bf (diff) |
Core/Database: Added std::span based functions to Field and PreparedStatement
(cherry picked from commit 27860c3316b7354c6bf17cac82992085d2905934)
# Conflicts:
# src/server/game/Entities/Player/Player.cpp
Diffstat (limited to 'src/server/database/Database/Field.cpp')
-rw-r--r-- | src/server/database/Database/Field.cpp | 27 |
1 files changed, 13 insertions, 14 deletions
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<uint8> Field::GetBinary() const @@ -157,6 +151,11 @@ std::vector<uint8> Field::GetBinary() const return result; } +std::span<uint8 const> Field::GetBinaryView() const +{ + return { reinterpret_cast<uint8 const*>(_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); |