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
// SPDX-FileCopyrightText: 2022 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 cxx::{type_id, ExternType};
#[cxx::bridge]
mod ffi {
unsafe extern "C++" {
include!("cxx-qt-lib/qdate.h");
type QDate = super::QDate;
/// Returns the year of this date.
fn year(self: &QDate) -> i32;
/// Returns the month-number for the date.
///
/// Numbers the months of the year starting with 1 for the first
fn month(self: &QDate) -> i32;
/// Returns the day of the month for this date.
fn day(self: &QDate) -> i32;
/// Sets this to represent the date, in the Gregorian calendar, with the given year, month and day numbers.
/// Returns true if the resulting date is valid, otherwise it sets this to represent an invalid date and returns false.
#[rust_name = "set_date"]
fn setDate(self: &mut QDate, y: i32, m: i32, d: i32) -> bool;
}
#[namespace = "rust::cxxqtlib1"]
unsafe extern "C++" {
#[doc(hidden)]
#[rust_name = "qdate_init_default"]
fn qdateInitDefault() -> QDate;
#[doc(hidden)]
#[rust_name = "qdate_init"]
fn qdateInit(y: i32, m: i32, d: i32) -> QDate;
}
}
/// The QDate class provides date functions.
#[derive(Debug, Clone)]
#[repr(C)]
pub struct QDate {
jd: i64,
}
impl Default for QDate {
/// Constructs a null date. Null dates are invalid.
fn default() -> Self {
ffi::qdate_init_default()
}
}
impl QDate {
/// Constructs a date with year y, month m and day d.
pub fn new(y: i32, m: i32, d: i32) -> Self {
ffi::qdate_init(y, m, d)
}
}
// Safety:
//
// Static checks on the C++ side ensure that QDate is trivial.
unsafe impl ExternType for QDate {
type Id = type_id!("QDate");
type Kind = cxx::kind::Trivial;
}