Brought line numbers back for the dbc.cpp logging stuff. May not work in clang because of the bug they have (had?).

This commit is contained in:
Zed A. Shaw 2025-03-17 23:16:51 -04:00
parent 0efb17371b
commit 5ed8196c80
3 changed files with 49 additions and 22 deletions

31
dbc.cpp
View file

@ -1,44 +1,47 @@
#include "dbc.hpp"
#include <iostream>
void dbc::log(const string &message) {
std::cerr << "!!!!!!!!!!" << message << std::endl;
void dbc::log(const string &message, const std::source_location location) {
std::clog << '[' << location.file_name() << ':'
<< location.line() << "|"
<< location.function_name() << "] "
<< message << std::endl;
}
void dbc::sentinel(const string &message) {
void dbc::sentinel(const string &message, const std::source_location location) {
string err = fmt::format("[SENTINEL!] {}", message);
dbc::log(err);
dbc::log(err, location);
throw dbc::SentinelError{err};
}
void dbc::pre(const string &message, bool test) {
void dbc::pre(const string &message, bool test, const std::source_location location) {
if(!test) {
string err = fmt::format("[PRE!] {}", message);
dbc::log(err);
dbc::log(err, location);
throw dbc::PreCondError{err};
}
}
void dbc::pre(const string &message, std::function<bool()> tester) {
dbc::pre(message, tester());
void dbc::pre(const string &message, std::function<bool()> tester, const std::source_location location) {
dbc::pre(message, tester(), location);
}
void dbc::post(const string &message, bool test) {
void dbc::post(const string &message, bool test, const std::source_location location) {
if(!test) {
string err = fmt::format("[POST!] {}", message);
dbc::log(err);
dbc::log(err, location);
throw dbc::PostCondError{err};
}
}
void dbc::post(const string &message, std::function<bool()> tester) {
dbc::post(message, tester());
void dbc::post(const string &message, std::function<bool()> tester, const std::source_location location) {
dbc::post(message, tester(), location);
}
void dbc::check(bool test, const string &message) {
void dbc::check(bool test, const string &message, const std::source_location location) {
if(!test) {
string err = fmt::format("[CHECK!] {}\n", message);
dbc::log(err);
dbc::log(err, location);
throw dbc::CheckError{err};
}
}