fish-shell/src/sanity.cpp
Fabian Homborg d73ee4d54b More using FLOGF when formatting is needed
sed-patched, every time a "%" is used in a call to `FLOG`, we use
`FLOGF` instead.
2019-05-30 11:54:09 +02:00

35 lines
951 B
C++

// Functions for performing sanity checks on the program state.
#include "config.h" // IWYU pragma: keep
#include <unistd.h>
#include "common.h"
#include "fallback.h" // IWYU pragma: keep
#include "flog.h"
#include "global_safety.h"
#include "history.h"
#include "kill.h"
#include "proc.h"
#include "reader.h"
#include "sanity.h"
/// Status from earlier sanity checks.
static relaxed_atomic_bool_t insane{false};
void sanity_lose() {
FLOG(error, _(L"Errors detected, shutting down. Break on sanity_lose() to debug."));
insane = true;
}
void validate_pointer(const void *ptr, const wchar_t *err, int null_ok) {
// Test if the pointer data crosses a segment boundary.
if ((0x00000003l & (intptr_t)ptr) != 0) {
FLOGF(error, _(L"The pointer '%ls' is invalid"), err);
sanity_lose();
}
if ((!null_ok) && (ptr == 0)) {
FLOGF(error, _(L"The pointer '%ls' is null"), err);
sanity_lose();
}
}