summaryrefslogtreecommitdiff
path: root/util
diff options
context:
space:
mode:
Diffstat (limited to 'util')
-rw-r--r--util/output.hh28
1 files changed, 22 insertions, 6 deletions
diff --git a/util/output.hh b/util/output.hh
index cbb1d05..18bbe90 100644
--- a/util/output.hh
+++ b/util/output.hh
@@ -17,6 +17,8 @@ extern bool pretty;
#include <string>
#include <iostream>
+#include <chrono>
+#include <iomanip>
/*! Bolds output on +stream+ if pretty output is desired.
* @param stream The stream to turn bold.
@@ -40,6 +42,19 @@ inline void reset_if_pretty(std::ostream &stream) {
if(pretty) stream << "\033[0m";
}
+/*! Print the ISO 8601 timestamp with millisecond resolution.
+ * @note See Agent.MessageFormat.
+ */
+inline void output_time() {
+ using namespace std::chrono;
+ auto now = system_clock::now();
+ auto millis = duration_cast<milliseconds>(now.time_since_epoch()) % 1000;
+ auto time = system_clock::to_time_t(now);
+ std::tm utc = *std::gmtime(&time);
+ std::cerr << std::put_time(&utc, "%FT%T") << ".";
+ std::cerr << std::setfill('0') << std::setw(3) << millis.count();
+}
+
/*! Outputs a message of the specified +type+ to the log stream.
* @param type The type of message to output.
* @param colour The colourisation of the message.
@@ -47,9 +62,10 @@ inline void reset_if_pretty(std::ostream &stream) {
* @param message The message.
* @param detail Additional detail for the message, if available.
*/
-inline void output_message(std::string type, std::string colour,
- std::string where, std::string message,
- std::string detail = "") {
+inline void output_log(std::string type, std::string colour, std::string where,
+ std::string message, std::string detail = "") {
+ output_time();
+ std::cerr << "\tlog\t";
std::cerr << where << ": ";
colour_if_pretty(std::cerr, colour);
std::cerr << type << ": ";
@@ -69,7 +85,7 @@ inline void output_message(std::string type, std::string colour,
*/
inline void output_error(std::string where, std::string message,
std::string detail = "") {
- output_message("error", "31", where, message, detail);
+ output_log("error", "31", where, message, detail);
}
/*! Outputs a warning message.
@@ -79,7 +95,7 @@ inline void output_error(std::string where, std::string message,
*/
inline void output_warning(std::string where, std::string message,
std::string detail = "") {
- output_message("warning", "33", where, message, detail);
+ output_log("warning", "33", where, message, detail);
}
/*! Outputs an informational message.
@@ -89,7 +105,7 @@ inline void output_warning(std::string where, std::string message,
*/
inline void output_info(std::string where, std::string message,
std::string detail = "") {
- output_message("info", "36", where, message, detail);
+ output_log("info", "36", where, message, detail);
}
#endif /* !__HORIZON_OUTPUT_HH_ */