File: date_and_time.cpp

package info (click to toggle)
sight 25.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 43,252 kB
  • sloc: cpp: 310,629; xml: 17,622; ansic: 9,960; python: 1,379; sh: 144; makefile: 33
file content (149 lines) | stat: -rw-r--r-- 4,912 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
/************************************************************************
 *
 * Copyright (C) 2009-2023 IRCAD France
 * Copyright (C) 2012-2020 IHU Strasbourg
 *
 * This file is part of Sight.
 *
 * Sight is free software: you can redistribute it and/or modify it under
 * the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Sight is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with Sight. If not, see <https://www.gnu.org/licenses/>.
 *
 ***********************************************************************/

#include "core/tools/date_and_time.hpp"

#include <core/base.hpp>

#include <boost/lexical_cast.hpp>

#include <regex>

namespace sight::core::tools
{

//------------------------------------------------------------------------------

boost::gregorian::date str_to_boost_date(const std::string& _date_str)
{
    boost::gregorian::date res_date(boost::gregorian::from_undelimited_string("19000101"));
    if(_date_str.size() < 8)
    {
        SIGHT_WARN(
            "The string length is too short (<8) : " << _date_str
            << ". The string is initialized with \"19000101\"."
        );
    }
    else if(_date_str.size() > 8)
    {
        SIGHT_WARN("The string length is too long (>8) : " << _date_str << ".. The string is trunked to 8 characters.");
        res_date = str_to_boost_date(_date_str.substr(0, 8));
    }
    else
    {
        std::regex is_number("[0-9]+");

        if(std::regex_match(_date_str, is_number))
        {
            res_date = boost::gregorian::date(boost::gregorian::from_undelimited_string(_date_str));
        }
        else
        {
            SIGHT_WARN(
                "The string not contains 8 numbers : " << _date_str
                << ". The string is initialized with \"19000101\"."
            );
        }
    }

    return res_date;
}

//------------------------------------------------------------------------------

boost::posix_time::time_duration str_to_boost_time(const std::string& _time_str)
{
    using boost::posix_time::time_duration;
    using boost::posix_time::hours;
    using boost::posix_time::minutes;
    using boost::posix_time::seconds;

    time_duration td;
    if(_time_str.size() < 6)
    {
        SIGHT_WARN(
            "The string length is too short (<6) : " << _time_str
            << ".  The string is initialized with \"000000\"."
        );
        td = hours(0) + minutes(0) + seconds(0);
    }
    else if(_time_str.size() > 6)
    {
        SIGHT_WARN("The string length is too short (>6) : " << _time_str << ". This string is trunked.");
        td = str_to_boost_time(_time_str.substr(0, 6));
    }
    else
    {
        std::regex is_number("[0-9]+");
        if(std::regex_match(_time_str, is_number))
        {
            auto h = boost::lexical_cast<std::uint16_t>(_time_str.substr(0, 2));
            auto m = boost::lexical_cast<std::uint16_t>(_time_str.substr(2, 2));
            auto s = boost::lexical_cast<std::uint16_t>(_time_str.substr(4, 2));
            td = hours(h) + minutes(m) + seconds(s);
        }
        else
        {
            SIGHT_WARN(
                "The string not contains 6 numbers : " << _time_str
                << ". The string is initialized with \"000000\"."
            );
            td = hours(0) + minutes(0) + seconds(0);
        }
    }

    return td;
}

//------------------------------------------------------------------------------

boost::posix_time::ptime str_to_boost_date_and_time(const std::string& _date_str, const std::string& _time_str)
{
    return {str_to_boost_date(_date_str), str_to_boost_time(_time_str)};
}

//------------------------------------------------------------------------------

std::string get_date(const boost::posix_time::ptime& _date_and_time)
{
    std::string date_and_time_str = boost::posix_time::to_iso_string(_date_and_time);
    return date_and_time_str.substr(0, 8);
}

//------------------------------------------------------------------------------

std::string get_time(const boost::posix_time::ptime& _date_and_time)
{
    std::string date_and_time_str = boost::posix_time::to_iso_string(_date_and_time);
    return date_and_time_str.substr(9, 6);
}

//------------------------------------------------------------------------------

std::string get_current_time()
{
    boost::posix_time::ptime now = boost::posix_time::second_clock::local_time();
    std::string now_str          = boost::posix_time::to_simple_string(now);
    return now_str.substr(0, 21);
}

} // namespace sight::core::tools