1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/components/sqlite3/transaction.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

59 lines
1.9 KiB
C++
Raw Normal View History

2021-10-16 13:03:15 +02:00
#include "transaction.hpp"
#include <components/debug/debuglog.hpp>
#include <sqlite3.h>
#include <stdexcept>
#include <string>
namespace Sqlite3
{
namespace
{
const char* getBeginStatement(TransactionMode mode)
{
switch (mode)
{
case TransactionMode::Default:
return "BEGIN";
case TransactionMode::Deferred:
return "BEGIN DEFERRED";
case TransactionMode::Immediate:
return "BEGIN IMMEDIATE";
case TransactionMode::Exclusive:
return "BEGIN EXCLUSIVE";
}
throw std::logic_error("Invalid transaction mode: "
+ std::to_string(static_cast<std::underlying_type_t<TransactionMode>>(mode)));
}
}
2021-10-16 13:03:15 +02:00
void Rollback::operator()(sqlite3* db) const
{
if (db == nullptr)
return;
if (const int ec = sqlite3_exec(db, "ROLLBACK", nullptr, nullptr, nullptr); ec != SQLITE_OK)
Log(Debug::Debug) << "Failed to rollback SQLite3 transaction: " << sqlite3_errmsg(db) << " (" << ec << ")";
2021-10-16 13:03:15 +02:00
}
Transaction::Transaction(sqlite3& db, TransactionMode mode)
2021-10-16 13:03:15 +02:00
: mDb(&db)
{
if (const int ec = sqlite3_exec(&db, getBeginStatement(mode), nullptr, nullptr, nullptr); ec != SQLITE_OK)
{
(void)mDb.release();
throw std::runtime_error(
"Failed to start transaction: " + std::string(sqlite3_errmsg(&db)) + " (" + std::to_string(ec) + ")");
}
2021-10-16 13:03:15 +02:00
}
void Transaction::commit()
{
if (const int ec = sqlite3_exec(mDb.get(), "COMMIT", nullptr, nullptr, nullptr); ec != SQLITE_OK)
throw std::runtime_error("Failed to commit transaction: " + std::string(sqlite3_errmsg(mDb.get())) + " ("
+ std::to_string(ec) + ")");
2021-10-16 13:03:15 +02:00
(void)mDb.release();
}
}