aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2018-03-04 22:35:59 +0100
committerClifford Wolf <clifford@clifford.at>2018-03-04 22:35:59 +0100
commite5534a080e953b7935defa92bed9452ed1616047 (patch)
treef24a97ef4f8c33e3c740f9e1a90eafce18140e39 /kernel
parent2935e8ea4152b0678314f79bae91258565592032 (diff)
downloadyosys-e5534a080e953b7935defa92bed9452ed1616047.tar.gz
yosys-e5534a080e953b7935defa92bed9452ed1616047.tar.bz2
yosys-e5534a080e953b7935defa92bed9452ed1616047.zip
Improve handling of warning messages
Signed-off-by: Clifford Wolf <clifford@clifford.at>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/driver.cc2
-rw-r--r--kernel/log.cc50
-rw-r--r--kernel/log.h2
3 files changed, 42 insertions, 12 deletions
diff --git a/kernel/driver.cc b/kernel/driver.cc
index f49f6023b..97a78cd16 100644
--- a/kernel/driver.cc
+++ b/kernel/driver.cc
@@ -480,6 +480,8 @@ int main(int argc, char **argv)
if (mode_v && !mode_q)
log_files.push_back(stderr);
+ if (log_warnings_count)
+ log("Warnings: %d unique messages, %d total\n", GetSize(log_warnings), log_warnings_count);
#ifdef _WIN32
log("End of script. Logfile hash: %s\n", hash.c_str());
#else
diff --git a/kernel/log.cc b/kernel/log.cc
index 8b12008bc..de564cb36 100644
--- a/kernel/log.cc
+++ b/kernel/log.cc
@@ -42,6 +42,8 @@ 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::set<std::string> log_warnings;
+int log_warnings_count = 0;
bool log_hdump_all = false;
FILE *log_errfile = NULL;
SHA1 *log_hasher = NULL;
@@ -216,14 +218,26 @@ void logv_warning(const char *format, va_list ap)
}
else
{
- if (log_errfile != NULL && !log_quiet_warnings)
- log_files.push_back(log_errfile);
+ if (log_warnings.count(message))
+ {
+ log("Warning: %s", message.c_str());
+ log_flush();
+ }
+ else
+ {
+ if (log_errfile != NULL && !log_quiet_warnings)
+ log_files.push_back(log_errfile);
- log("Warning: %s", message.c_str());
- log_flush();
+ log("Warning: %s", message.c_str());
+ log_flush();
- if (log_errfile != NULL && !log_quiet_warnings)
- log_files.pop_back();
+ if (log_errfile != NULL && !log_quiet_warnings)
+ log_files.pop_back();
+
+ log_warnings.insert(message);
+ }
+
+ log_warnings_count++;
}
}
@@ -242,14 +256,26 @@ void logv_warning_noprefix(const char *format, va_list ap)
}
else
{
- if (log_errfile != NULL && !log_quiet_warnings)
- log_files.push_back(log_errfile);
+ if (log_warnings.count(message))
+ {
+ log("%s", message.c_str());
+ log_flush();
+ }
+ else
+ {
+ if (log_errfile != NULL && !log_quiet_warnings)
+ log_files.push_back(log_errfile);
- log("%s", message.c_str());
- log_flush();
+ log("%s", message.c_str());
+ log_flush();
+
+ if (log_errfile != NULL && !log_quiet_warnings)
+ log_files.pop_back();
+
+ log_warnings.insert(message);
+ }
- if (log_errfile != NULL && !log_quiet_warnings)
- log_files.pop_back();
+ log_warnings_count++;
}
}
diff --git a/kernel/log.h b/kernel/log.h
index e27dafab9..a8aa58a9e 100644
--- a/kernel/log.h
+++ b/kernel/log.h
@@ -50,6 +50,8 @@ extern std::vector<FILE*> log_files;
extern std::vector<std::ostream*> log_streams;
extern std::map<std::string, std::set<std::string>> log_hdump;
extern std::vector<std::regex> log_warn_regexes, log_nowarn_regexes;
+extern std::set<std::string> log_warnings;
+extern int log_warnings_count;
extern bool log_hdump_all;
extern FILE *log_errfile;
extern SHA1 *log_hasher;