1
0
forked from blue/lmdbal
lmdbal/exceptions.cpp

118 lines
3.4 KiB
C++
Raw Normal View History

2022-09-09 17:15:40 +00:00
// Squawk messenger.
// Copyright (C) 2019 Yury Gubich <blue@macaw.me>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#include "exceptions.h"
2023-03-20 15:37:13 +00:00
LMDBDataBase::Exception::Exception():
std::exception()
{}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Exception::~Exception() {}
2023-03-20 15:37:13 +00:00
const char* LMDBDataBase::Exception::what() const noexcept( true ) {
std::string* msg = new std::string(getMessage());
return msg->c_str();
}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Directory::Directory(const std::string& p_path):
2022-09-09 17:15:40 +00:00
Exception(),
path(p_path) {}
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::Directory::getMessage() const {
2022-09-09 17:15:40 +00:00
return "Can't create directory for database at " + path;}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Closed::Closed(
2022-09-09 17:15:40 +00:00
const std::string& p_operation,
const std::string& p_dbName,
const std::optional<std::string>& p_tableName
2022-09-09 17:15:40 +00:00
):
Exception(),
operation(p_operation),
dbName(p_dbName),
tableName(p_tableName) {}
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::Closed::getMessage() const {
std::string msg = "An attempt to perform operation " + operation
+ " on closed database " + dbName;
2023-03-20 15:37:13 +00:00
if (tableName.has_value())
msg += + " on table " + tableName.value();
2023-03-20 15:37:13 +00:00
return msg;
2022-09-09 17:15:40 +00:00
}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Opened::Opened(const std::string& p_dbName, const std::string& p_action):
2022-09-09 17:15:40 +00:00
Exception(),
dbName(p_dbName),
action(p_action) {}
2022-09-09 17:15:40 +00:00
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::Opened::getMessage() const {
return "An attempt to " + action
+ " (the database " + dbName
+ ") but it's can't be done because the DataBase is already opened";
2022-09-09 17:15:40 +00:00
}
2023-03-20 15:37:13 +00:00
LMDBDataBase::NotFound::NotFound(
2022-09-09 17:15:40 +00:00
const std::string& p_key,
const std::string& p_dbName,
const std::string& p_tableName
):
Exception(),
key(p_key),
dbName(p_dbName),
tableName(p_tableName) {}
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::NotFound::getMessage() const {
2022-09-09 17:15:40 +00:00
return "Element for id " + key + " wasn't found "
+ " in database " + dbName
+ " in table " + tableName;}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Exist::Exist(
2022-09-09 17:15:40 +00:00
const std::string& p_key,
const std::string& p_dbName,
const std::string& p_tableName
):
Exception(),
key(p_key),
dbName(p_dbName),
tableName(p_tableName) {}
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::Exist::getMessage() const {
2022-09-09 17:15:40 +00:00
return "An attempt to insert element with key " + key
+ " to database " + dbName
+ " to table " + tableName
+ " but it already has an element with given id";
}
2023-03-20 15:37:13 +00:00
LMDBDataBase::Unknown::Unknown(
2022-09-09 17:15:40 +00:00
const std::string& p_dbName,
const std::string& message,
const std::optional<std::string>& p_tableName
):
Exception(),
dbName(p_dbName),
tableName(p_tableName),
msg(message) {}
2023-03-20 15:37:13 +00:00
std::string LMDBDataBase::Unknown::getMessage() const {
2022-09-09 17:15:40 +00:00
std::string result = "Unknown error in database " + dbName;
2023-03-20 15:37:13 +00:00
if (tableName.has_value())
2022-09-09 17:15:40 +00:00
result += " in table " + tableName.value();
2023-03-20 15:37:13 +00:00
2022-09-09 17:15:40 +00:00
result += ": " + msg;
return result;
}