/* SPDX-License-Identifier: LGPL-2.1-or-later */ #include "analyze.h" #include "analyze-timestamp.h" #include "format-table.h" #include "terminal-util.h" static int test_timestamp_one(const char *p) { _cleanup_(table_unrefp) Table *table = NULL; TableCell *cell; usec_t usec; int r; r = parse_timestamp(p, &usec); if (r < 0) { log_error_errno(r, "Failed to parse \"%s\": %m", p); time_parsing_hint(p, /* calendar= */ true, /* timestamp= */ false, /* timespan= */ true); return r; } table = table_new_vertical(); if (!table) return log_oom(); assert_se(cell = table_get_cell(table, 0, 0)); r = table_set_ellipsize_percent(table, cell, 100); if (r < 0) return r; assert_se(cell = table_get_cell(table, 0, 1)); r = table_set_ellipsize_percent(table, cell, 100); if (r < 0) return r; r = table_add_many(table, TABLE_FIELD, "Original form", TABLE_STRING, p, TABLE_FIELD, "Normalized form", TABLE_TIMESTAMP, usec, TABLE_SET_COLOR, ansi_highlight_blue()); if (r < 0) return table_log_add_error(r); if (!in_utc_timezone()) { r = table_add_many(table, TABLE_FIELD, "(in UTC)", TABLE_TIMESTAMP_UTC, usec); if (r < 0) return table_log_add_error(r); } r = table_add_cell(table, NULL, TABLE_FIELD, "UNIX seconds"); if (r < 0) return table_log_add_error(r); if (usec % USEC_PER_SEC == 0) r = table_add_cell_stringf(table, NULL, "@%"PRI_USEC, usec / USEC_PER_SEC); else r = table_add_cell_stringf(table, NULL, "@%"PRI_USEC".%06"PRI_USEC"", usec / USEC_PER_SEC, usec % USEC_PER_SEC); if (r < 0) return r; r = table_add_many(table, TABLE_FIELD, "From now", TABLE_TIMESTAMP_RELATIVE, usec); if (r < 0) return table_log_add_error(r); return table_print(table, NULL); } int verb_timestamp(int argc, char *argv[], void *userdata) { int r = 0; STRV_FOREACH(p, strv_skip(argv, 1)) { int k; k = test_timestamp_one(*p); if (r == 0 && k < 0) r = k; if (p[1]) putchar('\n'); } return r; }