mirror of
https://github.com/matrix-construct/construct
synced 2024-11-18 16:00:57 +01:00
174 lines
4.1 KiB
C++
174 lines
4.1 KiB
C++
|
/*
|
||
|
* Copyright (C) 2016 Charybdis Development Team
|
||
|
* Copyright (C) 2016 Jason Volk <jason@zemos.net>
|
||
|
*
|
||
|
* 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 is present in all copies.
|
||
|
*
|
||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
||
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||
|
*/
|
||
|
|
||
|
#include <ircd/js/js.h>
|
||
|
|
||
|
namespace ircd {
|
||
|
namespace js {
|
||
|
|
||
|
struct console
|
||
|
:trap
|
||
|
{
|
||
|
static const char *const source;
|
||
|
struct module module;
|
||
|
|
||
|
console();
|
||
|
}
|
||
|
static console;
|
||
|
|
||
|
console::console()
|
||
|
:trap
|
||
|
{
|
||
|
"__console",
|
||
|
JSCLASS_HAS_PRIVATE
|
||
|
}
|
||
|
,module
|
||
|
{
|
||
|
JS::CompileOptions(*cx),
|
||
|
locale::char16::conv(source),
|
||
|
this,
|
||
|
true
|
||
|
}
|
||
|
{
|
||
|
}
|
||
|
|
||
|
const char *const
|
||
|
console::source
|
||
|
{R"(
|
||
|
|
||
|
export function critical(msg) { __console.critical(msg); }
|
||
|
export function error(msg) { __console.error(msg); }
|
||
|
export function warn(msg) { __console.warn(msg); }
|
||
|
export function notice(msg) { __console.notice(msg); }
|
||
|
export function info(msg) { __console.info(msg); }
|
||
|
export function debug(msg) { __console.debug(msg); }
|
||
|
|
||
|
export function cout(msg) { __console.cout(msg); }
|
||
|
export function log(msg) { __console.info(msg); }
|
||
|
|
||
|
)"};
|
||
|
|
||
|
struct console_critical
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log(ircd::log::CRITICAL, "%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_critical{console, "critical"};
|
||
|
|
||
|
struct console_error
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log(ircd::log::ERROR, "%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_error{console, "error"};
|
||
|
|
||
|
struct console_warn
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log(ircd::log::WARNING, "%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_warn{console, "warn"};
|
||
|
|
||
|
struct console_notice
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log(ircd::log::NOTICE, "%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_notice{console, "notice"};
|
||
|
|
||
|
struct console_info
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log(ircd::log::INFO, "%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_info{console, "info"};
|
||
|
|
||
|
struct console_debug
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
ircd::js::log.debug("%s", std::string(args[0]));
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_debug{console, "debug"};
|
||
|
|
||
|
struct console_cout
|
||
|
:trap::function
|
||
|
{
|
||
|
value on_call(object::handle obj, value::handle _this, const args &args) override
|
||
|
{
|
||
|
std::cout << string(args[0]) << std::endl;
|
||
|
return {};
|
||
|
}
|
||
|
|
||
|
using trap::function::function;
|
||
|
}
|
||
|
static console_cout{console, "cout"};
|
||
|
|
||
|
} // namespace js
|
||
|
} // namespace ircd
|
||
|
|
||
|
extern "C" ircd::js::module *
|
||
|
IRCD_JS_MODULE
|
||
|
{
|
||
|
&ircd::js::console.module
|
||
|
};
|
||
|
|
||
|
ircd::mapi::header
|
||
|
IRCD_MODULE
|
||
|
{
|
||
|
"Provides simple I/O for debugging similar to that found in web browsers."
|
||
|
};
|