0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-09 22:36:00 +01:00
construct/modules/js/console.cc
2018-03-05 05:24:45 -08:00

162 lines
3.5 KiB
C++

// Matrix Construct
//
// Copyright (C) Matrix Construct Developers, Authors & Contributors
// Copyright (C) 2016-2018 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. The
// full license for this software is available in the LICENSE file.
#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."
};