summaryrefslogtreecommitdiff
path: root/deno2/deno.cc
diff options
context:
space:
mode:
authorRyan Dahl <ry@tinyclouds.org>2018-06-11 21:57:25 +0200
committerRyan Dahl <ry@tinyclouds.org>2018-06-11 21:57:25 +0200
commit7242f2b5a5118ee5b5cd2295761a703b54cee771 (patch)
tree5d7b787b28cdff2c0057d7903efeca7aaeba143c /deno2/deno.cc
parent997b300745b343feab58e715aa225396f9b896c8 (diff)
Add channel to pub/sub
Diffstat (limited to 'deno2/deno.cc')
-rw-r--r--deno2/deno.cc26
1 files changed, 14 insertions, 12 deletions
diff --git a/deno2/deno.cc b/deno2/deno.cc
index de03ed426..7b84abf22 100644
--- a/deno2/deno.cc
+++ b/deno2/deno.cc
@@ -133,16 +133,22 @@ void Pub(const v8::FunctionCallbackInfo<v8::Value>& args) {
v8::Locker locker(d->isolate);
v8::EscapableHandleScope handle_scope(isolate);
- v8::Local<v8::Value> v = args[0];
- assert(v->IsArrayBuffer());
+ assert(args.Length() == 2);
+ v8::Local<v8::Value> channel_v = args[0];
+ assert(channel_v->IsString());
+ v8::String::Utf8Value channel_vstr(isolate, channel_v);
+ const char* channel = *channel_vstr;
+
+ v8::Local<v8::Value> ab_v = args[1];
+ assert(ab_v->IsArrayBuffer());
- auto ab = v8::Local<v8::ArrayBuffer>::Cast(v);
+ auto ab = v8::Local<v8::ArrayBuffer>::Cast(ab_v);
auto contents = ab->GetContents();
void* buf = contents.Data();
int buflen = static_cast<int>(contents.ByteLength());
- auto retbuf = d->cb(d, deno_buf{buf, buflen});
+ auto retbuf = d->cb(d, channel, deno_buf{buf, buflen});
if (retbuf.data) {
// TODO(ry) Support zero-copy.
auto ab = v8::ArrayBuffer::New(d->isolate, retbuf.len);
@@ -270,10 +276,7 @@ bool deno_execute(Deno* d, const char* js_filename, const char* js_source) {
return deno::Execute(context, js_filename, js_source);
}
-// Routes message to the javascript callback set with deno_sub().
-// False return value indicates error. Check deno_last_exception() for exception
-// text. Caller owns buf.
-bool deno_pub(Deno* d, deno_buf buf) {
+bool deno_pub(Deno* d, const char* channel, deno_buf buf) {
v8::Locker locker(d->isolate);
v8::Isolate::Scope isolate_scope(d->isolate);
v8::HandleScope handle_scope(d->isolate);
@@ -293,10 +296,9 @@ bool deno_pub(Deno* d, deno_buf buf) {
auto ab = v8::ArrayBuffer::New(d->isolate, buf.len);
memcpy(ab->GetContents().Data(), buf.data, buf.len);
- v8::Local<v8::Value> args[1];
- args[0] = ab;
- assert(!args[0].IsEmpty());
- assert(!try_catch.HasCaught());
+ v8::Local<v8::Value> args[2];
+ args[0] = deno::v8_str(channel);
+ args[1] = ab;
sub->Call(context->Global(), 1, args);