/*
 * Copyright (c) 2019-2020 Atmosphère-NX
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#include <stratosphere.hpp>

namespace ams::time {

    Result GetStandardSteadyClockCurrentTimePoint(SteadyClockTimePoint *out) {
        static_assert(sizeof(*out) == sizeof(::TimeSteadyClockTimePoint));
        return ::timeGetStandardSteadyClockTimePoint(reinterpret_cast<::TimeSteadyClockTimePoint *>(out));
    }

    TimeSpan GetStandardSteadyClockInternalOffset() {
        static_assert(sizeof(TimeSpanType) == sizeof(s64));
        TimeSpanType offset;
        R_ABORT_UNLESS(::timeGetStandardSteadyClockInternalOffset(reinterpret_cast<s64 *>(std::addressof(offset))));
        return offset;
    }

    Result StandardSteadyClock::GetCurrentTimePoint(SteadyClockTimePoint *out) {
        return GetStandardSteadyClockCurrentTimePoint(out);
    }

    StandardSteadyClock::time_point StandardSteadyClock::now() {
        SteadyClockTimePoint steady_clock_time_point = {0, util::InvalidUuid};
        if (R_FAILED(StandardSteadyClock::GetCurrentTimePoint(std::addressof(steady_clock_time_point)))) {
            steady_clock_time_point.value     = 0;
            steady_clock_time_point.source_id = util::InvalidUuid;
        }

        return StandardSteadyClock::time_point(StandardSteadyClock::duration(steady_clock_time_point.value));
    }

}