aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/log.cc
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2018-05-04 15:27:28 +0200
committerClifford Wolf <clifford@clifford.at>2018-05-04 15:27:28 +0200
commit5c03aeac60b8f8e88367d3bbf3b13b84a54ef11b (patch)
treed56b5370ec336ba4edd4171ae1f02cc367594fd3 /kernel/log.cc
parent47eb150eec1530384c586971bcf8ec270e1d6acc (diff)
downloadyosys-5c03aeac60b8f8e88367d3bbf3b13b84a54ef11b.tar.gz
yosys-5c03aeac60b8f8e88367d3bbf3b13b84a54ef11b.tar.bz2
yosys-5c03aeac60b8f8e88367d3bbf3b13b84a54ef11b.zip
Add "yosys -e regex" for turning warnings into errors
Signed-off-by: Clifford Wolf <clifford@clifford.at>
Diffstat (limited to 'kernel/log.cc')
-rw-r--r--kernel/log.cc10
1 files changed, 9 insertions, 1 deletions
diff --git a/kernel/log.cc b/kernel/log.cc
index de564cb36..ff171f3e6 100644
--- a/kernel/log.cc
+++ b/kernel/log.cc
@@ -41,7 +41,7 @@ YOSYS_NAMESPACE_BEGIN
std::vector<FILE*> log_files;
std::vector<std::ostream*> log_streams;
std::map<std::string, std::set<std::string>> log_hdump;
-std::vector<std::regex> log_warn_regexes, log_nowarn_regexes;
+std::vector<std::regex> log_warn_regexes, log_nowarn_regexes, log_werror_regexes;
std::set<std::string> log_warnings;
int log_warnings_count = 0;
bool log_hdump_all = false;
@@ -218,6 +218,10 @@ void logv_warning(const char *format, va_list ap)
}
else
{
+ for (auto &re : log_werror_regexes)
+ if (std::regex_search(message, re))
+ log_error("%s", message.c_str());
+
if (log_warnings.count(message))
{
log("Warning: %s", message.c_str());
@@ -256,6 +260,10 @@ void logv_warning_noprefix(const char *format, va_list ap)
}
else
{
+ for (auto &re : log_werror_regexes)
+ if (std::regex_search(message, re))
+ log_error("%s", message.c_str());
+
if (log_warnings.count(message))
{
log("%s", message.c_str());