0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-01 02:14:13 +01:00
construct/modules/server/console.cc

173 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."
};