Namespaces
Variants

std::chrono::year_month_day:: ok

From cppreference.net
constexpr bool ok ( ) const noexcept ;
(C++20부터)

year_month_day 객체가 유효한 캘린더 날짜를 나타내는지 확인합니다.

반환값

true 만약 이 year_month_day 객체가 유효한 달력 날짜를 나타내는 경우, 즉 저장된 연도, 월, 일 값이 모두 유효하고 저장된 일 값이 주어진 연도와 월의 일 수 범위 내에 있을 때. 그렇지 않으면 false 를 반환합니다.

가능한 구현

constexpr bool std::chrono::year_month_day::ok() const noexcept
{
    return year().ok() && month().ok() && day().ok() &&
        day() <= (year()/month()/std::chrono::last).day();
}

예제

#include <chrono>
int main()
{
    constexpr auto ymd1 {std::chrono::day(1)/std::chrono::July/2020};
    static_assert(ymd1.ok());
    constexpr auto ymd2 {std::chrono::year(2020)/7/42};
    static_assert(not ymd2.ok());
    constexpr auto ymd3 {std::chrono::February/29/2020}; // 유효함, 윤년
    static_assert(ymd3.ok());
    constexpr auto ymd4 = ymd3 + std::chrono::years{1}; // 잘못됨, 윤년이 아님
    static_assert(ymd4 == std::chrono::February/29/2021 and not ymd4.ok());
    // 잘못된 날짜를 수정하려면 해당 월의 마지막 날로 조정할 수 있습니다:
    if constexpr (!ymd4.ok())
    {
        constexpr auto ymd = ymd4.year()/ymd4.month()/std::chrono::last;
        static_assert(ymd == std::chrono::February/28/2021 and ymd.ok());
    }
    // 또는 다음 달로 넘어가도록 할 수도 있습니다:
    if constexpr (!ymd4.ok())
    {
        constexpr auto st = std::chrono::sys_time<std::chrono::days>{ymd4};
        constexpr auto ymd = std::chrono::year_month_day{st};
        static_assert(ymd == std::chrono::March/1/2021 and ymd.ok());
    }
}