14514f5e3Sopenharmony_ci/*
24514f5e3Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd.
34514f5e3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
44514f5e3Sopenharmony_ci * you may not use this file except in compliance with the License.
54514f5e3Sopenharmony_ci * You may obtain a copy of the License at
64514f5e3Sopenharmony_ci *
74514f5e3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
84514f5e3Sopenharmony_ci *
94514f5e3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
104514f5e3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
114514f5e3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
124514f5e3Sopenharmony_ci * See the License for the specific language governing permissions and
134514f5e3Sopenharmony_ci * limitations under the License.
144514f5e3Sopenharmony_ci */
154514f5e3Sopenharmony_ci
164514f5e3Sopenharmony_ci#ifndef ECMASCRIPT_MEM_CLOCK_SCOPE_H
174514f5e3Sopenharmony_ci#define ECMASCRIPT_MEM_CLOCK_SCOPE_H
184514f5e3Sopenharmony_ci
194514f5e3Sopenharmony_ci#include <ctime>
204514f5e3Sopenharmony_ci#include <chrono>
214514f5e3Sopenharmony_ci
224514f5e3Sopenharmony_cinamespace panda::ecmascript {
234514f5e3Sopenharmony_ciclass ClockScope {
244514f5e3Sopenharmony_ciusing Clock = std::chrono::high_resolution_clock;
254514f5e3Sopenharmony_ciusing Duration = std::chrono::duration<uint64_t, std::nano>;
264514f5e3Sopenharmony_ci
274514f5e3Sopenharmony_cipublic:
284514f5e3Sopenharmony_ci    ClockScope()
294514f5e3Sopenharmony_ci    {
304514f5e3Sopenharmony_ci        start_ = Clock::now();
314514f5e3Sopenharmony_ci    }
324514f5e3Sopenharmony_ci
334514f5e3Sopenharmony_ci    void Reset()
344514f5e3Sopenharmony_ci    {
354514f5e3Sopenharmony_ci        start_ = Clock::now();
364514f5e3Sopenharmony_ci    }
374514f5e3Sopenharmony_ci
384514f5e3Sopenharmony_ci    Duration GetPauseTime() const
394514f5e3Sopenharmony_ci    {
404514f5e3Sopenharmony_ci        return Clock::now() - start_;
414514f5e3Sopenharmony_ci    }
424514f5e3Sopenharmony_ci
434514f5e3Sopenharmony_ci    float TotalSpentTime() const
444514f5e3Sopenharmony_ci    {
454514f5e3Sopenharmony_ci        auto duration = std::chrono::duration_cast<std::chrono::microseconds>(Clock::now() - start_);
464514f5e3Sopenharmony_ci        return (float) duration.count() / MILLION_TIME;
474514f5e3Sopenharmony_ci    }
484514f5e3Sopenharmony_ci
494514f5e3Sopenharmony_ci    int TotalSpentTimeInMicroseconds() const
504514f5e3Sopenharmony_ci    {
514514f5e3Sopenharmony_ci        return std::chrono::duration_cast<std::chrono::microseconds>(Clock::now() - start_).count();
524514f5e3Sopenharmony_ci    }
534514f5e3Sopenharmony_ci
544514f5e3Sopenharmony_ci    double GetCurTime() const
554514f5e3Sopenharmony_ci    {
564514f5e3Sopenharmony_ci        auto curTime_ = Duration(start_.time_since_epoch());
574514f5e3Sopenharmony_ci        return (double) curTime_.count() / MILLION_TIME;
584514f5e3Sopenharmony_ci    }
594514f5e3Sopenharmony_ci
604514f5e3Sopenharmony_ciprivate:
614514f5e3Sopenharmony_ci    NO_COPY_SEMANTIC(ClockScope);
624514f5e3Sopenharmony_ci    NO_MOVE_SEMANTIC(ClockScope);
634514f5e3Sopenharmony_ci
644514f5e3Sopenharmony_ci    Clock::time_point start_;
654514f5e3Sopenharmony_ci    static constexpr uint32_t MILLION_TIME = 1000;
664514f5e3Sopenharmony_ci};
674514f5e3Sopenharmony_ci}  // namespace panda::ecmascript
684514f5e3Sopenharmony_ci#endif  // ECMASCRIPT_MEM_CLOCK_SCOPE_H
69