Mercurial > malikania
view libcommon-js/malikania/js_elapsed_timer.cpp @ 158:4b292c20124c
Misc: update copyrights
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 09 Jan 2018 13:15:07 +0100 |
parents | 858621081b95 |
children |
line wrap: on
line source
/* * js_elapsed_timer.cpp -- ElapsedTimer (JavaScript binding) * * Copyright (c) 2013-2018 David Demelier <markand@malikania.fr> * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include <boost/timer/timer.hpp> #include <cassert> #include <string> #include "duktape.hpp" namespace mlk { namespace { const std::string signature("\xff" "\xff" "malikania-elapsed-timer-ptr"); boost::timer::cpu_timer& self(duk_context* ctx) { dukx_stack_assert sa(ctx); duk_push_this(ctx); duk_get_prop_string(ctx, -1, signature.c_str()); auto ptr = duk_to_pointer(ctx, -1); duk_pop_2(ctx); if (!ptr) { duk_error(ctx, DUK_ERR_TYPE_ERROR, "not an ElapsedTimer object"); } return *static_cast<boost::timer::cpu_timer*>(ptr); } /* * Method: ElapsedTimer.pause * ------------------------------------------------------------------ * * Pause the timer, without resetting the current elapsed time stored. */ duk_ret_t pause(duk_context* ctx) { self(ctx).stop(); return 0; } /* * Method: ElapsedTimer.reset * ------------------------------------------------------------------ * * Reset the elapsed time to 0, the status is not modified. */ duk_ret_t reset(duk_context* ctx) { self(ctx).start(); return 0; } /* * Method: ElapsedTimer.restart * ------------------------------------------------------------------ * * Restart the timer without resetting the current elapsed time. */ duk_ret_t restart(duk_context* ctx) { self(ctx).resume(); return 0; } /* * Method: ElapsedTimer.elapsed * ------------------------------------------------------------------ * * Get the number of elapsed milliseconds. * * Returns: * The time elapsed. */ duk_ret_t elapsed(duk_context* ctx) { duk_push_uint(ctx, self(ctx).elapsed().wall / 1000000LL); return 1; } /* * Function: Malikania.ElapsedTimer() [constructor] * ------------------------------------------------------------------ * * Construct a new ElapsedTimer object. */ duk_ret_t constructor(duk_context* ctx) { duk_push_this(ctx); duk_push_pointer(ctx, new boost::timer::cpu_timer); duk_put_prop_string(ctx, -2, signature.c_str()); duk_pop(ctx); return 0; } /* * Function: Malikania.ElapsedTimer() [destructor] * ------------------------------------------------------------------ * * Destroy the timer. */ duk_ret_t destructor(duk_context* ctx) { duk_get_prop_string(ctx, 0, signature.c_str()); delete static_cast<boost::timer::cpu_timer*>(duk_to_pointer(ctx, -1)); duk_pop(ctx); duk_del_prop_string(ctx, 0, signature.c_str()); return 0; } const duk_function_list_entry methods[] = { { "elapsed", elapsed, 0 }, { "pause", pause, 0 }, { "reset", reset, 0 }, { "restart", restart, 0 }, { nullptr, nullptr, 0 } }; } // !namespace void dukx_load_elapsedtimer(duk_context* ctx) noexcept { dukx_stack_assert sa(ctx); duk_get_global_string(ctx, "Malikania"); duk_push_c_function(ctx, constructor, 0); duk_push_object(ctx); duk_put_function_list(ctx, -1, methods); duk_push_c_function(ctx, destructor, 1); duk_set_finalizer(ctx, -2); duk_put_prop_string(ctx, -2, "prototype"); duk_put_prop_string(ctx, -2, "ElapsedTimer"); duk_pop(ctx); } } // !mlk