diff options
author | 2024-11-16 00:32:45 +0600 | |
---|---|---|
committer | 2024-11-16 00:32:45 +0600 | |
commit | 47d602cf884b14e4c529286238e2085fe97338d7 (patch) | |
tree | 8d7bb77e1dac06f96845ff6c4d092f3a8d4cb0c3 | |
parent | 1f0ff6b0675f514b394c2c6fd44e4ce32b84c7b0 (diff) | |
download | log-parser-master.tar.gz log-parser-master.zip |
Signed-off-by: Mubashshir <ahmubashshir@gmail.com>
-rw-r--r-- | src/system.yy | 6 | ||||
-rw-r--r-- | src/util.h | 19 |
2 files changed, 23 insertions, 2 deletions
diff --git a/src/system.yy b/src/system.yy index cd6ddc9..0727213 100644 --- a/src/system.yy +++ b/src/system.yy @@ -27,6 +27,7 @@ bool legacy = true; #include <cstdint> #include "lexer.h" #include "location.h" +#include "util.h" } //%locations @@ -69,7 +70,8 @@ block_end: ofstream f(p, ios_base::out | ios_base::binary); msg.SerializeToOstream(&f); f.close(); - } + } else + throw syntax_error(string_format("Block EPOCH mismatch: begin:%llu, end:%llu", msg.epoch(), $ULONG)); msg.Clear(); } @@ -275,7 +277,7 @@ namespace yy // Report an error to the user. auto parser::error (const std::string& msg) -> void { - std::cerr << msg << " on line " << lexer.lineno() << '\n'; + std::cerr << "\nERROR: " << msg << " on line " << lexer.lineno() - 1<< '\n'; } } diff --git a/src/util.h b/src/util.h new file mode 100644 index 0000000..a54d3eb --- /dev/null +++ b/src/util.h @@ -0,0 +1,19 @@ +#ifndef __UTIL_H__ +#define __UTIL_H__ + +#include <memory> +#include <string> +#include <stdexcept> + +template<typename ... Args> +std::string string_format( const std::string& format, Args ... args ) +{ + int size_s = std::snprintf( nullptr, 0, format.c_str(), args ... ) + 1; // Extra space for '\0' + if( size_s <= 0 ){ throw std::runtime_error( "Error during formatting." ); } + auto size = static_cast<size_t>( size_s ); + std::unique_ptr<char[]> buf( new char[ size ] ); + std::snprintf( buf.get(), size, format.c_str(), args ... ); + return std::string( buf.get(), buf.get() + size - 1 ); // We don't want the '\0' inside +} + +#endif /* __UTIL_H__ */ |