summaryrefslogtreecommitdiff
path: root/src/core/Database/Transaction.cpp
diff options
context:
space:
mode:
authorYehonal <yehonal.azeroth@gmail.com>2017-10-12 20:00:52 +0200
committerYehonal <yehonal.azeroth@gmail.com>2017-10-12 20:00:52 +0200
commitf06f32849f1e2c72dc73287c73361174c07ed29e (patch)
tree70ace68e849cd5ca446fb36279f8125127bb8693 /src/core/Database/Transaction.cpp
parent4df28fd29c6978e669f9950bd38e853fabf9fc8d (diff)
Directory Structure [step 1]: moving files
working on #672 NOTE: This commit can't be compiled!!
Diffstat (limited to 'src/core/Database/Transaction.cpp')
-rw-r--r--src/core/Database/Transaction.cpp82
1 files changed, 82 insertions, 0 deletions
diff --git a/src/core/Database/Transaction.cpp b/src/core/Database/Transaction.cpp
new file mode 100644
index 0000000000..a2dfb9beea
--- /dev/null
+++ b/src/core/Database/Transaction.cpp
@@ -0,0 +1,82 @@
+/*
+ * Copyright (C)
+ *
+ * Copyright (C) 2008-2016 TrinityCore <http://www.trinitycore.org/>
+ * Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
+ */
+
+#include "DatabaseEnv.h"
+#include "Transaction.h"
+
+//- Append a raw ad-hoc query to the transaction
+void Transaction::Append(const char* sql)
+{
+ SQLElementData data;
+ data.type = SQL_ELEMENT_RAW;
+ data.element.query = strdup(sql);
+ m_queries.push_back(data);
+}
+
+void Transaction::PAppend(const char* sql, ...)
+{
+ va_list ap;
+ char szQuery [MAX_QUERY_LEN];
+ va_start(ap, sql);
+ vsnprintf(szQuery, MAX_QUERY_LEN, sql, ap);
+ va_end(ap);
+
+ Append(szQuery);
+}
+
+//- Append a prepared statement to the transaction
+void Transaction::Append(PreparedStatement* stmt)
+{
+ SQLElementData data;
+ data.type = SQL_ELEMENT_PREPARED;
+ data.element.stmt = stmt;
+ m_queries.push_back(data);
+}
+
+void Transaction::Cleanup()
+{
+ // This might be called by explicit calls to Cleanup or by the auto-destructor
+ if (_cleanedUp)
+ return;
+
+ while (!m_queries.empty())
+ {
+ SQLElementData const &data = m_queries.front();
+ switch (data.type)
+ {
+ case SQL_ELEMENT_PREPARED:
+ delete data.element.stmt;
+ break;
+ case SQL_ELEMENT_RAW:
+ free((void*)(data.element.query));
+ break;
+ }
+
+ m_queries.pop_front();
+ }
+
+ _cleanedUp = true;
+}
+
+bool TransactionTask::Execute()
+{
+ if (m_conn->ExecuteTransaction(m_trans))
+ return true;
+
+ if (m_conn->GetLastError() == 1213)
+ {
+ uint8 loopBreaker = 5; // Handle MySQL Errno 1213 without extending deadlock to the core itself
+ for (uint8 i = 0; i < loopBreaker; ++i)
+ if (m_conn->ExecuteTransaction(m_trans))
+ return true;
+ }
+
+ // Clean up now.
+ m_trans->Cleanup();
+
+ return false;
+}