mirror of
https://github.com/mod-playerbots/azerothcore-wotlk.git
synced 2026-01-14 09:39:11 +00:00
feat(Core/DBLayer): replace char const* to std::string_view (#10211)
* feat(Core/DBLayer): replace `char const*` to `std::string_view` * CString * 1 * chore(Core/Misc): code cleanup * cl * db fix * fmt style sql * to fmt * py * del old * 1 * 2 * 3 * 1 * 1
This commit is contained in:
@@ -24,7 +24,8 @@
|
||||
#include "QueryResult.h"
|
||||
|
||||
PreparedStatementBase::PreparedStatementBase(uint32 index, uint8 capacity) :
|
||||
m_index(index), statement_data(capacity) { }
|
||||
m_index(index),
|
||||
statement_data(capacity) { }
|
||||
|
||||
PreparedStatementBase::~PreparedStatementBase() { }
|
||||
|
||||
@@ -36,20 +37,6 @@ Acore::Types::is_non_string_view_v<T> PreparedStatementBase::SetValidData(const
|
||||
statement_data[index].data.emplace<T>(value);
|
||||
}
|
||||
|
||||
template<>
|
||||
void PreparedStatementBase::SetValidData(const uint8 index, std::string const& value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data.emplace<std::string>(value);
|
||||
}
|
||||
|
||||
template<>
|
||||
void PreparedStatementBase::SetValidData(const uint8 index, std::vector<uint8> const& value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data.emplace<std::vector<uint8>>(value);
|
||||
}
|
||||
|
||||
// Non template functions
|
||||
void PreparedStatementBase::SetValidData(const uint8 index)
|
||||
{
|
||||
@@ -73,103 +60,16 @@ template void PreparedStatementBase::SetValidData(const uint8 index, uint64 cons
|
||||
template void PreparedStatementBase::SetValidData(const uint8 index, int64 const& value);
|
||||
template void PreparedStatementBase::SetValidData(const uint8 index, bool const& value);
|
||||
template void PreparedStatementBase::SetValidData(const uint8 index, float const& value);
|
||||
|
||||
// Old api
|
||||
void PreparedStatementBase::setBool(const uint8 index, const bool value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setUInt8(const uint8 index, const uint8 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setUInt16(const uint8 index, const uint16 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setUInt32(const uint8 index, const uint32 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setUInt64(const uint8 index, const uint64 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setInt8(const uint8 index, const int8 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setInt16(const uint8 index, const int16 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setInt32(const uint8 index, const int32 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setInt64(const uint8 index, const int64 value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setFloat(const uint8 index, const float value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setDouble(const uint8 index, const double value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setString(const uint8 index, const std::string& value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setStringView(const uint8 index, const std::string_view value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data.emplace<std::string>(value);
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setBinary(const uint8 index, const std::vector<uint8>& value)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = value;
|
||||
}
|
||||
|
||||
void PreparedStatementBase::setNull(const uint8 index)
|
||||
{
|
||||
ASSERT(index < statement_data.size());
|
||||
statement_data[index].data = nullptr;
|
||||
}
|
||||
template void PreparedStatementBase::SetValidData(const uint8 index, std::string const& value);
|
||||
template void PreparedStatementBase::SetValidData(const uint8 index, std::vector<uint8> const& value);
|
||||
|
||||
//- Execution
|
||||
PreparedStatementTask::PreparedStatementTask(PreparedStatementBase* stmt, bool async) :
|
||||
m_stmt(stmt), m_result(nullptr)
|
||||
m_stmt(stmt),
|
||||
m_result(nullptr)
|
||||
{
|
||||
m_has_result = async; // If it's async, then there's a result
|
||||
|
||||
if (async)
|
||||
m_result = new PreparedQueryResultPromise();
|
||||
}
|
||||
@@ -177,7 +77,8 @@ m_stmt(stmt), m_result(nullptr)
|
||||
PreparedStatementTask::~PreparedStatementTask()
|
||||
{
|
||||
delete m_stmt;
|
||||
if (m_has_result && m_result != nullptr)
|
||||
|
||||
if (m_has_result && m_result)
|
||||
delete m_result;
|
||||
}
|
||||
|
||||
@@ -192,6 +93,7 @@ bool PreparedStatementTask::Execute()
|
||||
m_result->set_value(PreparedQueryResult(nullptr));
|
||||
return false;
|
||||
}
|
||||
|
||||
m_result->set_value(PreparedQueryResult(result));
|
||||
return true;
|
||||
}
|
||||
@@ -202,45 +104,29 @@ bool PreparedStatementTask::Execute()
|
||||
template<typename T>
|
||||
std::string PreparedStatementData::ToString(T value)
|
||||
{
|
||||
return fmt::format("{}", value);
|
||||
return Acore::StringFormatFmt("{}", value);
|
||||
}
|
||||
|
||||
std::string PreparedStatementData::ToString(bool value)
|
||||
{
|
||||
return ToString<uint32>(value);
|
||||
}
|
||||
|
||||
std::string PreparedStatementData::ToString(uint8 value)
|
||||
{
|
||||
return ToString<uint32>(value);
|
||||
}
|
||||
|
||||
template std::string PreparedStatementData::ToString<uint16>(uint16);
|
||||
template std::string PreparedStatementData::ToString<uint32>(uint32);
|
||||
template std::string PreparedStatementData::ToString<uint64>(uint64);
|
||||
|
||||
std::string PreparedStatementData::ToString(int8 value)
|
||||
{
|
||||
return ToString<int32>(value);
|
||||
}
|
||||
|
||||
template std::string PreparedStatementData::ToString<int16>(int16);
|
||||
template std::string PreparedStatementData::ToString<int32>(int32);
|
||||
template std::string PreparedStatementData::ToString<int64>(int64);
|
||||
template std::string PreparedStatementData::ToString<float>(float);
|
||||
template std::string PreparedStatementData::ToString<double>(double);
|
||||
|
||||
std::string PreparedStatementData::ToString(std::string const& value)
|
||||
{
|
||||
return fmt::format("'{}'", value);
|
||||
}
|
||||
|
||||
std::string PreparedStatementData::ToString(std::vector<uint8> const& /*value*/)
|
||||
template<>
|
||||
std::string PreparedStatementData::ToString(std::vector<uint8> /*value*/)
|
||||
{
|
||||
return "BINARY";
|
||||
}
|
||||
|
||||
std::string PreparedStatementData::ToString(std::nullptr_t)
|
||||
template std::string PreparedStatementData::ToString(uint8);
|
||||
template std::string PreparedStatementData::ToString(uint16);
|
||||
template std::string PreparedStatementData::ToString(uint32);
|
||||
template std::string PreparedStatementData::ToString(uint64);
|
||||
template std::string PreparedStatementData::ToString(int8);
|
||||
template std::string PreparedStatementData::ToString(int16);
|
||||
template std::string PreparedStatementData::ToString(int32);
|
||||
template std::string PreparedStatementData::ToString(int64);
|
||||
template std::string PreparedStatementData::ToString(std::string);
|
||||
template std::string PreparedStatementData::ToString(float);
|
||||
template std::string PreparedStatementData::ToString(double);
|
||||
template std::string PreparedStatementData::ToString(bool);
|
||||
|
||||
std::string PreparedStatementData::ToString(std::nullptr_t /*value*/)
|
||||
{
|
||||
return "NULL";
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user