std::chrono::month_weekday::month, std::chrono::month_weekday::weekday_indexed

From cppreference.com
< cpp‎ | chrono‎ | month weekday
Date and time library
Time point
(C++11)
(C++20)
Duration
(C++11)
Clocks
(C++11)
(C++11)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
Time of day
(C++20)(C++20)
(C++20)(C++20)
(C++20)

Calendar
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)(C++20)
Time zone
(C++20)
(C++20)
(C++20) (C++20) (C++20) (C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
chrono I/O
(C++20)
C-style date and time
std::chrono::month_weekday
Member functions
month_weekday::monthmonth_weekday::weekday_indexed
Nonmember functions
Helper classes
constexpr std::chrono::month month( ) const noexcept ;
(1) (since C++20)
constexpr std::chrono::weekday_indexed weekday_indexed( ) const noexcept ;
(2) (since C++20)

Retrieves a copy of the month and weekday_indexed objects stored in *this

Return value

1) A copy of the std::chrono::month object stored in *this.
2) A copy of the std::chrono::weekday_indexed object stored in *this.

Example

#include <chrono>
#include <iostream>
 
int main()
{
    std::cout << std::boolalpha;
 
    auto mwdi{std::chrono::March/std::chrono::Friday[1]}; // 1st Friday in a March
    std::cout << (std::chrono::year_month_day{mwdi/2024} == 
                  std::chrono::year_month_day{std::chrono::March/1/2024})
                  << ' ';
    auto index = mwdi.weekday_indexed().index();
    auto weekday = mwdi.weekday_indexed().weekday();
    mwdi = {mwdi.month(), weekday[index + 4]}; // 5th Friday in a March
    std::cout << (std::chrono::year_month_day{mwdi/2024} == 
                  std::chrono::year_month_day{std::chrono::March/29/2024})
                  << '\n';
}

Output:

true true