diff options
author | Clifford Wolf <clifford@clifford.at> | 2015-01-30 22:12:26 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2015-01-30 22:12:26 +0100 |
commit | 114a78d11a629f030e5fd0b6e5655ed70ee7ca9b (patch) | |
tree | a11ee61253fb3cfb3438fb8038d7f14f27ce5dd8 | |
parent | 9ebf803cbe6cd3329da1908bbf0763baaabcc48f (diff) | |
download | yosys-114a78d11a629f030e5fd0b6e5655ed70ee7ca9b.tar.gz yosys-114a78d11a629f030e5fd0b6e5655ed70ee7ca9b.tar.bz2 yosys-114a78d11a629f030e5fd0b6e5655ed70ee7ca9b.zip |
Some cleanups in log.cc
-rw-r--r-- | kernel/log.cc | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/kernel/log.cc b/kernel/log.cc index 401dbeeb0..061c5074c 100644 --- a/kernel/log.cc +++ b/kernel/log.cc @@ -49,10 +49,10 @@ bool log_cmd_error_throw = false; bool log_quiet_warnings = false; int log_verbose_level; -std::vector<int> header_count; -std::set<RTLIL::IdString> log_id_cache; -std::list<std::string> string_buf; -int string_buf_size = 0; +vector<int> header_count; +pool<RTLIL::IdString> log_id_cache; +vector<string> string_buf; +int string_buf_index = -1; static struct timeval initial_tv = { 0, 0 }; static bool next_print_log = false; @@ -249,7 +249,7 @@ void log_pop() header_count.pop_back(); log_id_cache.clear(); string_buf.clear(); - string_buf_size = 0; + string_buf_index = -1; log_flush(); } @@ -352,7 +352,7 @@ void log_reset_stack() header_count.pop_back(); log_id_cache.clear(); string_buf.clear(); - string_buf_size = 0; + string_buf_index = -1; log_flush(); } @@ -374,20 +374,22 @@ const char *log_signal(const RTLIL::SigSpec &sig, bool autoint) std::stringstream buf; ILANG_BACKEND::dump_sigspec(buf, sig, autoint); - if (string_buf_size < 100) - string_buf_size++; - else - string_buf.pop_front(); - string_buf.push_back(buf.str()); - - return string_buf.back().c_str(); + if (string_buf.size() < 100) { + string_buf.push_back(buf.str()); + return string_buf.back().c_str(); + } else { + if (++string_buf_index == 100) + string_buf_index = 0; + string_buf[string_buf_index] = buf.str(); + return string_buf[string_buf_index].c_str(); + } } const char *log_id(RTLIL::IdString str) { log_id_cache.insert(str); const char *p = str.c_str(); - if (p[0] == '\\' && p[1] != '$' && p[1] != 0) + if (p[0] == '\\' && p[1] != '$' && p[1] != '\\' && p[1] != 0) return p+1; return p; } |