ORE Studio 0.0.4
Loading...
Searching...
No Matches
relative_time_formatter.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_PLATFORM_TIME_RELATIVE_TIME_FORMATTER_HPP
21#define ORES_PLATFORM_TIME_RELATIVE_TIME_FORMATTER_HPP
22
23#include <chrono>
24#include <string>
25
26namespace ores::platform::time {
27
33enum class numeric_style {
37 always,
38
43};
44
50enum class time_unit {
51 second,
52 minute,
53 hour,
54 day,
55 week,
56 month,
57 quarter,
58 year
59};
60
71public:
78
85 std::string format(const std::chrono::system_clock::time_point& tp) const;
86
94 std::string format(
95 const std::chrono::system_clock::time_point& tp,
96 const std::chrono::system_clock::time_point& reference) const;
97
107 std::string format(long long value, time_unit unit) const;
108
109private:
110 numeric_style style_;
111};
112
113}
114
115#endif
Time and datetime utilities.
Definition datetime.hpp:26
time_unit
Enumeration for time units used in relative time formatting.
Definition relative_time_formatter.hpp:50
numeric_style
Enumeration for relative time formatting style.
Definition relative_time_formatter.hpp:33
@ automatic
Use special words where appropriate (e.g., "yesterday", "tomorrow").
@ always
Always use numeric values (e.g., "1 day ago", "in 5 days").
Formats time points as relative time strings.
Definition relative_time_formatter.hpp:70
std::string format(const std::chrono::system_clock::time_point &tp) const
Formats a time point relative to now.
Definition relative_time_formatter.cpp:162