Namespaces
Variants
Views
Actions

std::chrono::year::ok

From cppreference.com
< cpp‎ | chrono‎ | year
 
 
Utilities library
Language support
Type support (basic types, RTTI)
Library feature-test macros (C++20)
Dynamic memory management
Program utilities
Coroutine support (C++20)
Variadic functions
Debugging support
(C++26)
Three-way comparison
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
General utilities
Date and time
Function objects
Formatting library (C++20)
(C++11)
Relational operators (deprecated in C++20)
Integer comparison functions
(C++20)(C++20)(C++20)   
(C++20)
Swap and type operations
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Common vocabulary types
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Elementary string conversions
(C++17)
(C++17)

 
 
 
constexpr bool ok() const noexcept;
(since C++20)

Checks if the year value stored in *this is in the valid range, i.e., [-3276732767].

[edit] Return value

true if the year value stored in *this is in the range [-3276732767]. Otherwise false.

[edit] Possible implementation

See the implementations in libstdc++, libc++, and Howard Hinnant's date.h.

class Year
{
    short year_;   // exposition-only
 
public:
 
    bool ok() const noexcept { return year_ != std::numeric_limits<short>::min(); }
 
    /*...*/
};

[edit] Example

#include <chrono>
#include <iomanip>
#include <iostream>
 
int main()
{
    std::cout << "input year │ internal value │ ok()\n" << std::boolalpha;
 
    for (const int i : {2020, 0x8000, 0x8001, 0xFFFF, 0x18000})
    {
        const std::chrono::year y{i};
        std::cout << std::setw(10) << i << " │ "
                  << std::setw(14) << static_cast<int>(y) << " │ "
                  << y.ok() << '\n';
    }
}

Possible output:

input year │ internal value │ ok()
      2020 │           2020 │ true
     32768 │         -32768 │ false
     32769 │         -32767 │ true
     65535 │             -1 │ true
     98304 │         -32768 │ false