From 141ada19b00fb9d0dd1a260d86d97bbb709a0f5e Mon Sep 17 00:00:00 2001 From: Giacomo Pozzoni Date: Sat, 30 May 2020 15:43:54 +0000 Subject: Cherry pick some db commits (#24713) * Core/DBLayer: Implement async transaction completion callbacks (cherry picked from commit 0f0ca3a9194d76afa0227943e86469ad8368c5e2) # Conflicts: # src/server/bnetserver/REST/LoginRESTService.cpp # src/server/bnetserver/Server/Session.cpp # src/server/bnetserver/Server/Session.h # src/server/database/Database/Transaction.cpp # src/server/game/Handlers/CharacterHandler.cpp # src/server/game/Handlers/SpellHandler.cpp # src/server/game/Server/WorldSession.cpp # src/server/game/Server/WorldSocket.cpp # src/server/game/Server/WorldSocket.h * Core/Misc: Fixed char enum packet sometimes not showing newly created character when client latency is too low (cherry picked from commit fc9d2e728e5c21bd2a1645a29be60d0e280ad940) # Conflicts: # src/server/game/Handlers/CharacterHandler.cpp * Fix no-pch build * Core/Player: Wait for correct transaction on character creation (cherry picked from commit 01c68b2aa2ed25ea9b4c007f238a0e958f6525b1) # Conflicts: # src/server/game/Entities/Player/Player.cpp * Fix warning * Remove unused login transaction Co-authored-by: Shauren --- src/server/database/Database/DatabaseEnvFwd.h | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) (limited to 'src/server/database/Database/DatabaseEnvFwd.h') diff --git a/src/server/database/Database/DatabaseEnvFwd.h b/src/server/database/Database/DatabaseEnvFwd.h index dd8cc464cae..930957fb898 100644 --- a/src/server/database/Database/DatabaseEnvFwd.h +++ b/src/server/database/Database/DatabaseEnvFwd.h @@ -24,9 +24,9 @@ class Field; class ResultSet; -typedef std::shared_ptr QueryResult; -typedef std::future QueryResultFuture; -typedef std::promise QueryResultPromise; +using QueryResult = std::shared_ptr; +using QueryResultFuture = std::future; +using QueryResultPromise = std::promise; class CharacterDatabaseConnection; class LoginDatabaseConnection; @@ -42,17 +42,27 @@ using LoginDatabasePreparedStatement = PreparedStatement; class PreparedResultSet; -typedef std::shared_ptr PreparedQueryResult; -typedef std::future PreparedQueryResultFuture; -typedef std::promise PreparedQueryResultPromise; +using PreparedQueryResult = std::shared_ptr; +using PreparedQueryResultFuture = std::future; +using PreparedQueryResultPromise = std::promise; class QueryCallback; +template +class AsyncCallbackProcessor; + +using QueryCallbackProcessor = AsyncCallbackProcessor; + class TransactionBase; +using TransactionFuture = std::future; +using TransactionPromise = std::promise; + template class Transaction; +class TransactionCallback; + template using SQLTransaction = std::shared_ptr>; @@ -61,8 +71,8 @@ using LoginDatabaseTransaction = SQLTransaction; using WorldDatabaseTransaction = SQLTransaction; class SQLQueryHolderBase; -typedef std::future QueryResultHolderFuture; -typedef std::promise QueryResultHolderPromise; +using QueryResultHolderFuture = std::future; +using QueryResultHolderPromise = std::promise; template class SQLQueryHolder; -- cgit v1.2.3