/usr/include/Wt/WLocalDateTime is in libwt-dev 3.3.3+dfsg-4.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 | // This may look like C code, but it's really -*- C++ -*-
/*
* Copyright (C) 2013 Emweb bvba, Kessel-Lo, Belgium.
*
* See the LICENSE file for terms of use.
*/
#ifndef WLOCAL_DATE_TIME_H_
#define WLOCAL_DATE_TIME_H_
#include <Wt/WDllDefs.h>
#include <Wt/WException>
#include <Wt/WLocale>
#include <Wt/WString>
#include <exception>
#include <boost/date_time/local_time/local_time.hpp>
namespace Wt {
/*! \class WLocalDateTime Wt/WLocalDateTime Wt/WLocalDateTime
* \brief A localized calendar date and clock time.
*
* This presents a localized date time, which represents a date time
* in a given locale.
*
* It is recommended to only use this to display timestamps to the
* user, and use WDateTime (which stores UTC time) throughout your
* business logic. For this reason, this class does not contain any
* methods to calculate with time.
*
* \sa WDateTime::toLocalTime()
*/
class WT_API WLocalDateTime
{
public:
/*! \brief Creates a <i>Null</i> datetime.
*
* A time for which isNull() returns \c true. A <i>Null</i> datetime
* is also invalid.
*
* \sa isValid(), isNull()
*/
WLocalDateTime(const WLocale& locale = WLocale::currentLocale());
/*! \brief Creates a datetime given a date and time.
*
* The datetime is valid if both \p date and \p time are valid and the
* given time could correctly be interpreted in the local time zone:
* - the time must exist (on the day that the time changes from 2AM to
* 3AM the time 2.30AM does not exist)
* - the time must be unambiguous. On the day that time changes from
* 3AM to 2AM, the time 2.30AM is not unambiguous. In that case the
* ambiguity must be resolved by using setDateTime() indicating whether
* the time is day light savings time or not.
*/
WLocalDateTime(const WDate& date, const WTime& time,
const WLocale& locale = WLocale::currentLocale());
/*! \brief Returns if this datetime is <i>Null</i>.
*
* A <i>null</i> time is also invalid.
*
* \sa isValid(), WDateTime()
*/
bool isNull() const;
/*! \brief Returns if this datetime is valid.
*
* A date time is only valid if its date and time parts are valid.
*/
bool isValid() const;
/*! \brief Sets the local date and time.
*
* The datetime is valid if both \p date and \p time are valid and the
* given time could correctly be interpreted in the local time zone:
* - the time exists (on the day that the time changes from 2AM to
* 3AM the time 2.30AM does not exist)
* - the time is unambiguous (on the day that time changes from 3AM to 2AM.
* the time 2.30AM is not unambigous). In the latter case,
* setDateTime(const WDate&, const WTime&, bool) may still be used.
*/
void setDateTime(const WDate& date, const WTime& time);
/*! \brief Sets the local date and time, indicating day-light savings.
*
* The datetime is valid if both \p date and \p time are valid and the
* given time could correctly be interpreted in the local time zone with
* the indicated day light savings indication.
*/
void setDateTime(const WDate& date, const WTime& time, bool dst);
/*! \brief Sets the date part.
*
* Changes the date part part, leaving the time unmodified. If no
* time was set, it is set to 00:00.
*
* \sa setTime()
*/
void setDate(const WDate& date);
/*! \brief Returns the date part.
*
* Returns the date part.
*
* \sa time()
*/
WDate date() const;
/*! \brief Sets the time part.
*
* If no valid date is set, the time is not set either.
*
* \sa setDate()
*/
void setTime(const WTime& time);
/*! \brief Returns the time part.
*
* \sa setTime()
*/
WTime time() const;
/*! \brief Returns the time zone offset.
*
* This returns the time zone offset to UTC in minutes. A positive value
* thus means that the local time is ahead of UTC.
*/
int timeZoneOffset() const;
/*! \brief Returns the time zone.
*
* \sa WLocale::setTimeZone()
*/
std::string timeZone() const;
/*! \brief Converts to UTC.
*
* This is the reverse of WDateTime::toLocalTime()
*/
WDateTime toUTC() const;
/*! \brief Formats this datetime to a string using the locale format.
*
* \sa WLocale::dateTimeFormat()
*/
WT_USTRING toString() const;
/*! \brief Formats this datetime to a string in a custom format.
*
* \sa WLocale::dateTimeFormat()
*/
WT_USTRING toString(const WT_USTRING& format) const;
/*! \brief Parses a string to a time using the locale format.
*
* \sa WLocale::dateTimeFormat()
*/
static WLocalDateTime fromString(const WT_USTRING& s,
const WLocale& locale = WLocale::currentLocale());
/*! \brief Reports the current datetime.
*
* This method returns the current datetime in the given
* locale. Note that this is usually accurate even if one does not
* know exactly the user's time zone, since this can be based on the
* timeZoneOffset reported in the WEnvironment.
*/
static WLocalDateTime currentDateTime(const WLocale& locale = WLocale::currentLocale());
/*! \brief Reports the current local server time.
*/
static WLocalDateTime currentServerDateTime();
/*! \brief Compares two values.
*/
bool operator< (const WLocalDateTime& other) const;
/*! \brief Compares two datetime values.
*/
bool operator== (const WLocalDateTime& other) const;
/*! \brief Compares two datetime values.
*/
bool operator!= (const WLocalDateTime& other) const;
private:
boost::local_time::local_date_time datetime_;
WT_USTRING format_;
WLocalDateTime(const boost::local_time::local_date_time& dt,
const WT_USTRING& format);
friend class WDateTime;
void setInvalid();
static WLocalDateTime currentTime(int offset);
};
}
#endif // WLOCAL_DATE_TIME_H_
|