Removed -pthread and -fno-strict-aliasing flags
This commit is contained in:
parent
8eba81ca4b
commit
e7979589ee
2
Makefile
2
Makefile
@ -28,7 +28,7 @@ HDRS := $(filter-out $(LIBNAME).hpp,$(wildcard *.hpp))
|
|||||||
|
|
||||||
CXX ?= g++
|
CXX ?= g++
|
||||||
|
|
||||||
CXXFLAGS := $(CXXFLAGS) -Wshadow -Wall -Wpedantic -Wextra -g -fno-strict-aliasing -std=c++17 -fPIC
|
CXXFLAGS += -Wshadow -Wall -Wpedantic -Wextra -g -std=c++17 -fPIC
|
||||||
ifeq ($(DEBUG),1)
|
ifeq ($(DEBUG),1)
|
||||||
CXXFLAGS += -D DEBUG -O0
|
CXXFLAGS += -D DEBUG -O0
|
||||||
else
|
else
|
||||||
|
38
throw.cpp
38
throw.cpp
@ -11,7 +11,10 @@
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
static string combine_message_elements(const char* file, unsigned int line, const char* user_message, const char* sys_message)
|
static string combine_message_elements(const char* file,
|
||||||
|
unsigned int line,
|
||||||
|
const char* user_message,
|
||||||
|
const char* sys_message)
|
||||||
{
|
{
|
||||||
ostringstream msg;
|
ostringstream msg;
|
||||||
string f {file};
|
string f {file};
|
||||||
@ -22,32 +25,41 @@ static string combine_message_elements(const char* file, unsigned int line, cons
|
|||||||
return msg.str();
|
return msg.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void __throw_if_min1(int x, const char* file, unsigned int line, const char* message)
|
void __throw_if_min1(int x,
|
||||||
|
const char* file,
|
||||||
|
unsigned int line,
|
||||||
|
const char* message)
|
||||||
{
|
{
|
||||||
if (x == -1) {
|
if (x == -1) {
|
||||||
error_code ec {errno, system_category()};
|
error_code ec {errno, system_category()};
|
||||||
ostringstream ec_str;
|
ostringstream ec_str;
|
||||||
ec_str << "system error " << ec.value() << ": " << ec.message();
|
ec_str << "system error " << ec.value() << ": " << ec.message();
|
||||||
string msg {combine_message_elements(file, line, message, ec_str.str().c_str())};
|
string msg {combine_message_elements(file, line, message, ec_str.str().c_str())};
|
||||||
throw system_error {ec, msg};
|
throw system_error {ec, msg};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void __throw_if_null(const void* p, const char* file, unsigned int line, const char* message)
|
void __throw_if_null(const void* p,
|
||||||
|
const char* file,
|
||||||
|
unsigned int line,
|
||||||
|
const char* message)
|
||||||
{
|
{
|
||||||
if (p == nullptr) {
|
if (p == nullptr) {
|
||||||
string msg {combine_message_elements(file, line, message, "null pointer exception")};
|
string msg {combine_message_elements(file, line, message, "null pointer exception")};
|
||||||
throw runtime_error {msg};
|
throw runtime_error {msg};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void __throw_if_err(int err, const char* file, unsigned int line, const char* message)
|
void __throw_if_err(int err,
|
||||||
|
const char* file,
|
||||||
|
unsigned int line,
|
||||||
|
const char* message)
|
||||||
{
|
{
|
||||||
if (err != 0) {
|
if (err != 0) {
|
||||||
error_code ec {err, system_category()};
|
error_code ec {err, system_category()};
|
||||||
ostringstream ec_str;
|
ostringstream ec_str;
|
||||||
ec_str << "error " << err;
|
ec_str << "error " << err;
|
||||||
string msg {combine_message_elements(file, line, message, ec_str.str().c_str())};
|
string msg {combine_message_elements(file, line, message, ec_str.str().c_str())};
|
||||||
throw system_error {ec, msg};
|
throw system_error {ec, msg};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// throw macros for OS X and other POSIX systems
|
// throw macros for OS X and other POSIX systems
|
||||||
// adapted for Windows as well, november 2014
|
// adapted for Windows as well, november 2014
|
||||||
// copyright © 2002-2014 Bob Polis
|
// copyright © 2002-2022 Bob Polis
|
||||||
|
|
||||||
#ifndef __throw__
|
#ifndef __throw__
|
||||||
#define __throw__
|
#define __throw__
|
||||||
@ -16,6 +16,6 @@ void __throw_if_err(int err, const char* file, unsigned int line, const char* me
|
|||||||
|
|
||||||
#define throw_if_min1_msg(___x___, ___msg___) __throw_if_min1((___x___), __FILE__, __LINE__, ___msg___)
|
#define throw_if_min1_msg(___x___, ___msg___) __throw_if_min1((___x___), __FILE__, __LINE__, ___msg___)
|
||||||
#define throw_if_null_msg(__ptr__, ___msg___) __throw_if_null((__ptr__), __FILE__, __LINE__, ___msg___)
|
#define throw_if_null_msg(__ptr__, ___msg___) __throw_if_null((__ptr__), __FILE__, __LINE__, ___msg___)
|
||||||
#define throw_if_err_msg(__err__, ___msg___) __throw_if_err((__err__), __FILE__, __LINE__, ___msg___)
|
#define throw_if_err_msg(__err__, ___msg___) __throw_if_err((__err__), __FILE__, __LINE__, ___msg___)
|
||||||
|
|
||||||
#endif /* defined(__throw__) */
|
#endif /* defined(__throw__) */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user