0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-12-29 17:04:03 +01:00

ircd::js: Fixes for js bitrot / maintenance cleanup.

This commit is contained in:
Jason Volk 2018-07-03 15:40:36 -07:00
parent cc4bc23a22
commit ae5678269c
4 changed files with 59 additions and 66 deletions

View file

@ -28,14 +28,14 @@ struct jserror
void create(JSErrorReport &);
void create(const JSErrorReport &);
void generate(const JSExnType &type, const char *const &fmt, va_list ap);
void generate(const JSExnType &type, const char *const &fmt, const va_rtti &ap);
void set_pending() const;
void set_uncatchable() const;
jserror(pending_t);
jserror(generate_skip_t);
jserror(const JSErrorReport &);
jserror(const char *fmt = " ", ...) AFP(2, 3);
template<class... args> jserror(const char *const &fmt = " ", args&&...);
jserror(JSObject &);
jserror(JSObject *const &);
jserror(const JS::Value &);
@ -65,3 +65,12 @@ IRCD_JS_ERROR_DEF( uri_error, JSEXN_URIERR )
} // namespace js
} // namespace ircd
template<class... args>
ircd::js::jserror::jserror(const char *const &fmt,
args&&... a)
:ircd::js::error{generate_skip}
,val{}
{
generate(JSEXN_ERR, fmt, va_rtti{std::forward<args>(a)...});
}

View file

@ -531,7 +531,7 @@ inline auto
hash(const string &s)
{
//TODO: optimize
return ircd::util::hash(std::u16string(s));
return ircd::hash(std::u16string(s));
}
template<class A,

View file

@ -21,15 +21,16 @@
// Use JS_DEBUG as an analog instead.
#undef DEBUG
namespace ircd {
namespace js {
// Logging facility for this submodule with SNOMASK.
struct log::log log
decltype(ircd::js::log)
ircd::js::log
{
"js", 'J'
};
namespace ircd {
namespace js {
// Location of the thread_local runtext (js/context.h)
// If this is null, js is not available on your thread.
__thread context *cx;
@ -333,7 +334,7 @@ ircd::js::global::import(module &importer,
fname = substr(fname, 0, fname.size() - 1);
fname += ".so";
ircd::module *const m(new ircd::module(fname));
ircd::module *const m(new ircd::module(std::string(fname)));
const auto exporter(m->get<module *>("IRCD_JS_MODULE"));
const auto iit(imports.emplace(requesting, exporter));
const string name(exporter->trap->name);
@ -752,14 +753,12 @@ ircd::js::trap::prototype(const object::handle &globals)
{ 0 }
};
/*
std::transform(begin(this->memfunc), end(this->memfunc), begin(memfunc), []
(const auto &it)
{
const auto &function(*it.second);
return function.spec;
});
*/
// std::transform(begin(this->memfunc), end(this->memfunc), begin(memfunc), []
// (const auto &it)
// {
// const auto &function(*it.second);
// return function.spec;
// });
// Create object
const object proto
@ -1303,27 +1302,23 @@ bool
ircd::js::trap::on_has(object::handle,
id::handle id)
{
/*
const string sid(id);
if(children.count(sid))
return false;
if(std::any_of(begin(memfun), end(memfun), [&sid]
(const auto &it)
{
const auto &memfun(*it.second);
return sid == memfun.name;
}))
return false;
*/
/*
value val;
const auto flags(JSPROP_SHARED | JSPROP_ENUMERATE);
if(!JS_DefinePropertyById(*cx, obj, id, val, flags, handle_getter, handle_setter))
throw jserror("Failed to define property '%s'", sid.c_str());
*/
// const string sid(id);
// if(children.count(sid))
// return false;
//
// if(std::any_of(begin(memfun), end(memfun), [&sid]
// (const auto &it)
// {
// const auto &memfun(*it.second);
// return sid == memfun.name;
// }))
// return false;
//
// value val;
// const auto flags(JSPROP_SHARED | JSPROP_ENUMERATE);
// if(!JS_DefinePropertyById(*cx, obj, id, val, flags, handle_getter, handle_setter))
// throw jserror("Failed to define property '%s'", sid.c_str());
//
// const auto flags(0);
// if(!JS_DefineObject(*cx, obj, sid.c_str(), &jsclass(), flags))
// throw jserror("Failed to define property '%s'", sid.c_str());
@ -1464,13 +1459,11 @@ noexcept
{
// This frame is entered on a thread owned by SpiderMonkey, not IRCd. Do not call
// ircd::log from here, it is not thread-safe.
/*
printf("[thread %s]: context(%p): compile(%p) READY (priv: %p)\n",
ircd::string(std::this_thread::get_id()).c_str(),
(const void *)cx,
token,
priv);
*/
// printf("[thread %s]: context(%p): compile(%p) READY (priv: %p)\n",
// ircd::string(std::this_thread::get_id()).c_str(),
// (const void *)cx,
// token,
// priv);
// Setting the value of the promise and then deleting the promise is thread-safe.
// Note that JS::FinishOffThreadScript(); will need to be called on the main thread.
@ -1813,7 +1806,7 @@ ircd::js::del(const object::handle &src,
object obj(src);
const char *fail(nullptr);
char buffer[strlen(path) + 1];
ircd::tokens(path, ".", buffer, sizeof(buffer), [&path, &val, &obj, &fail]
ircd::tokens(path, ".", mutable_buffer{buffer, sizeof(buffer)}, [&path, &val, &obj, &fail]
(const string_view &part)
{
if(fail)
@ -1889,7 +1882,7 @@ ircd::js::set(const object::handle &src,
object obj(src);
char buffer[strlen(path) + 1];
const char *fail(nullptr), *key(nullptr);
ircd::tokens(path, ".", buffer, sizeof(buffer), [&path, &obj, &fail, &key]
ircd::tokens(path, ".", mutable_buffer{buffer, sizeof(buffer)}, [&path, &obj, &fail, &key]
(const string_view &part)
{
if(fail)
@ -1981,8 +1974,8 @@ ircd::js::get(const object::handle &src,
value ret;
object obj(src);
const char *fail(nullptr);
char buf[strlen(path) + 1];
ircd::tokens(path, ".", buf, sizeof(buf), [&obj, &path, &ret, &fail]
char buffer[strlen(path) + 1];
ircd::tokens(path, ".", mutable_buffer{buffer, sizeof(buffer)}, [&obj, &path, &ret, &fail]
(const string_view &part)
{
if(fail)
@ -2046,8 +2039,8 @@ ircd::js::has(const object::handle &src,
bool ret(true);
object obj(src);
const char *fail(nullptr);
char buf[strlen(path) + 1];
ircd::tokens(path, ".", buf, sizeof(buf), [&obj, &path, &ret, &fail]
char buffer[strlen(path) + 1];
ircd::tokens(path, ".", mutable_buffer{buffer, sizeof(buffer)}, [&obj, &path, &ret, &fail]
(const string_view &part)
{
if(fail)
@ -2391,17 +2384,6 @@ ircd::js::jserror::jserror(generate_skip_t)
{
}
ircd::js::jserror::jserror(const char *const fmt,
...)
:ircd::js::error{generate_skip}
,val{}
{
va_list ap;
va_start(ap, fmt);
generate(JSEXN_ERR, fmt, ap);
va_end(ap);
}
ircd::js::jserror::jserror(const JSErrorReport &report)
:ircd::js::error{generate_skip}
,val{}
@ -2455,7 +2437,7 @@ const
void
ircd::js::jserror::generate(const JSExnType &type,
const char *const &fmt,
va_list ap)
const va_rtti &ap)
{
ircd::exception::generate(fmt, ap);
const auto msg(locale::char16::conv(what()));

View file

@ -8,7 +8,7 @@
// 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/listen.h>
#include <ircd/net/listener.h>
#include <ircd/js/js.h>
namespace ircd {
@ -29,11 +29,13 @@ static listener;
struct listener::listen
:trap::function
{
ircd::listener *l;
net::listener *l;
value on_call(object::handle obj, value::handle _this, const args &args) override
{
l = new ircd::listener(std::string(args[0]));
const std::string a(args[0]);
const ircd::json::object o(a);
l = new net::listener(o.get("name", "js"), o);
return {};
}
@ -81,7 +83,7 @@ ircd::js::listener::listener()
{
}
extern "C" ircd::js::module *
ircd::js::module *
IRCD_JS_MODULE
{
&ircd::js::listener.module