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/PreparedStatement.cpp | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'src/server/database/Database/PreparedStatement.cpp') diff --git a/src/server/database/Database/PreparedStatement.cpp b/src/server/database/Database/PreparedStatement.cpp index 684d3ee4eb6..c0c14beec7b 100644 --- a/src/server/database/Database/PreparedStatement.cpp +++ b/src/server/database/Database/PreparedStatement.cpp @@ -100,22 +100,28 @@ void PreparedStatementBase::setDate(uint8 index, SystemTimePoint value) statement_data[index].data = value; } -void PreparedStatementBase::setString(uint8 index, std::string const& value) +void PreparedStatementBase::setString(uint8 index, std::string&& value) { ASSERT(index < statement_data.size()); - statement_data[index].data = value; + statement_data[index].data = std::move(value); } -void PreparedStatementBase::setStringView(uint8 index, std::string_view value) +void PreparedStatementBase::setString(uint8 index, std::string_view value) { ASSERT(index < statement_data.size()); statement_data[index].data.emplace(value); } -void PreparedStatementBase::setBinary(uint8 index, std::vector const& value) +void PreparedStatementBase::setBinary(uint8 index, std::vector&& value) { ASSERT(index < statement_data.size()); - statement_data[index].data = value; + statement_data[index].data = std::move(value); +} + +void PreparedStatementBase::setBinary(uint8 index, std::span value) +{ + ASSERT(index < statement_data.size()); + statement_data[index].data.emplace>(value.begin(), value.end()); } void PreparedStatementBase::setNull(uint8 index) -- cgit v1.2.3