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
// SPDX-FileCopyrightText: 2023 Klarälvdalens Datakonsult AB, a KDAB Group company <info@kdab.com>
// SPDX-FileContributor: Andrew Hayzen <andrew.hayzen@kdab.com>
//
// SPDX-License-Identifier: MIT OR Apache-2.0
use std::fmt;
#[cxx::bridge]
mod ffi {
unsafe extern "C++" {
include!("cxx-qt-lib/qbytearray.h");
type QByteArray = crate::QByteArray;
include!("cxx-qt-lib/qdatetime.h");
type QDateTime = crate::QDateTime;
include!("cxx-qt-lib/qlist.h");
type QList_QByteArray = crate::QList<crate::QByteArray>;
include!("cxx-qt-lib/qstring.h");
type QString = crate::QString;
include!("cxx-qt-lib/qtimezone.h");
/// The QTimeZone class converts between UTC and local time in a specific time zone.
//
// QTimeZone only has a copy-constructor and not a move-constructor, which means that the following is true
// "When the move constructor is not implicitly declared or explicitly supplied, expressions
// that otherwise would have invoked the move constructor may instead invoke a copy constructor."
//
// Therefore the internal QSharedDataPointer is incremented causing a memory leak, so use an opaque type.
type QTimeZone;
/// Returns the time zone abbreviation at the given atDateTime. The abbreviation may change depending on DST or even historical events.
fn abbreviation(self: &QTimeZone, atDateTime: &QDateTime) -> QString;
/// Returns any comment for the time zone.
fn comment(self: &QTimeZone) -> QString;
/// Returns the daylight-saving time offset at the given atDateTime,
/// i.e. the number of seconds to add to the standard time offset to obtain the local daylight-saving time.
#[rust_name = "daylight_time_offset"]
fn daylightTimeOffset(self: &QTimeZone, atDateTime: &QDateTime) -> i32;
/// Returns true if the time zone has practiced daylight-saving at any time.
#[rust_name = "has_daylight_time"]
fn hasDaylightTime(self: &QTimeZone) -> bool;
/// Returns true if the system backend supports obtaining transitions.
#[rust_name = "has_transitions"]
fn hasTransitions(self: &QTimeZone) -> bool;
/// Returns the IANA ID for the time zone.
fn id(self: &QTimeZone) -> QByteArray;
/// Returns true if daylight-saving was in effect at the given atDateTime.
#[rust_name = "is_daylight_time"]
fn isDaylightTime(self: &QTimeZone, atDateTime: &QDateTime) -> bool;
/// Returns true if this time zone is valid.
#[rust_name = "is_valid"]
fn isValid(self: &QTimeZone) -> bool;
/// Returns the total effective offset at the given atDateTime, i.e. the number of seconds to add to UTC to obtain the local time.
/// This includes any DST offset that may be in effect, i.e. it is the sum of standardTimeOffset() and daylightTimeOffset() for the given datetime.
#[rust_name = "offset_from_utc"]
fn offsetFromUtc(self: &QTimeZone, atDateTime: &QDateTime) -> i32;
/// Returns the standard time offset at the given atDateTime, i.e. the number of seconds to add to UTC to obtain the local Standard Time.
/// This excludes any DST offset that may be in effect.
#[rust_name = "standard_time_offset"]
fn standardTimeOffset(self: &QTimeZone, atDateTime: &QDateTime) -> i32;
}
#[namespace = "rust::cxxqtlib1"]
unsafe extern "C++" {
#[doc(hidden)]
#[rust_name = "qtimezone_available_time_zone_ids"]
fn qtimezoneAvailableTimeZoneIds() -> QList_QByteArray;
#[doc(hidden)]
#[rust_name = "qtimezone_clone"]
fn qtimezoneClone(timezone: &QTimeZone) -> UniquePtr<QTimeZone>;
#[doc(hidden)]
#[rust_name = "qtimezone_default"]
fn qtimezoneDefault() -> UniquePtr<QTimeZone>;
#[doc(hidden)]
#[rust_name = "qtimezone_from_offset_seconds"]
fn qtimezoneFromOffsetSeconds(offset_seconds: i32) -> UniquePtr<QTimeZone>;
#[doc(hidden)]
#[rust_name = "qtimezone_from_iana"]
fn qtimezoneFromIana(iana_id: &QByteArray) -> UniquePtr<QTimeZone>;
#[doc(hidden)]
#[rust_name = "qtimezone_system_time_zone"]
fn qtimezoneSystemTimeZone() -> UniquePtr<QTimeZone>;
#[doc(hidden)]
#[rust_name = "qtimezone_system_time_zone_id"]
fn qtimezoneSystemTimeZoneId() -> QByteArray;
#[doc(hidden)]
#[rust_name = "qtimezone_utc"]
fn qtimezoneUtc() -> UniquePtr<QTimeZone>;
}
#[namespace = "rust::cxxqtlib1"]
unsafe extern "C++" {
include!("cxx-qt-lib/common.h");
#[doc(hidden)]
#[rust_name = "qtimezone_eq"]
fn operatorEq(a: &QTimeZone, b: &QTimeZone) -> bool;
#[doc(hidden)]
#[rust_name = "qtimezone_to_qstring"]
fn toQString(value: &QTimeZone) -> QString;
}
// QTimeZone only has a copy-constructor and not a move-constructor, which means that the following is true
// "When the move constructor is not implicitly declared or explicitly supplied, expressions
// that otherwise would have invoked the move constructor may instead invoke a copy constructor."
//
// Therefore the internal QSharedDataPointer is incremented causing a memory leak, so use an opaque type.
impl UniquePtr<QTimeZone> {}
}
pub use ffi::QTimeZone;
impl QTimeZone {
/// Returns a list of all available IANA time zone IDs on this system.
pub fn available_time_zone_ids() -> ffi::QList_QByteArray {
ffi::qtimezone_available_time_zone_ids()
}
/// Creates an instance of a time zone with the requested Offset from UTC of offsetSeconds.
pub fn from_offset_seconds(offset_seconds: i32) -> cxx::UniquePtr<Self> {
ffi::qtimezone_from_offset_seconds(offset_seconds)
}
/// Creates an instance of the requested time zone ianaId.
pub fn from_iana(iana_id: &ffi::QByteArray) -> cxx::UniquePtr<Self> {
ffi::qtimezone_from_iana(iana_id)
}
/// Create a null/invalid time zone instance.
pub fn new() -> cxx::UniquePtr<Self> {
ffi::qtimezone_default()
}
/// Returns a QTimeZone object that refers to the local system time, as specified by systemTimeZoneId().
pub fn system_time_zone() -> cxx::UniquePtr<Self> {
ffi::qtimezone_system_time_zone()
}
/// Returns the current system time zone IANA ID.
pub fn system_time_zone_id() -> ffi::QByteArray {
ffi::qtimezone_system_time_zone_id()
}
/// Copy constructor, create a copy of the QTimeZone.
pub fn to_owned(&self) -> cxx::UniquePtr<Self> {
ffi::qtimezone_clone(self)
}
/// Returns a QTimeZone object that refers to UTC (Universal Time Coordinated).
pub fn utc() -> cxx::UniquePtr<Self> {
ffi::qtimezone_utc()
}
}
impl std::cmp::PartialEq for QTimeZone {
fn eq(&self, other: &Self) -> bool {
ffi::qtimezone_eq(self, other)
}
}
impl std::cmp::Eq for QTimeZone {}
impl fmt::Display for QTimeZone {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", ffi::qtimezone_to_qstring(self))
}
}
impl fmt::Debug for QTimeZone {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{self}")
}
}