|
17 | 17 | namespace node {
|
18 | 18 |
|
19 | 19 | using v8::Array;
|
| 20 | +using v8::ArrayBuffer; |
20 | 21 | using v8::Boolean;
|
21 | 22 | using v8::Context;
|
22 | 23 | using v8::FunctionCallbackInfo;
|
@@ -303,17 +304,29 @@ int StreamBase::WriteString(const FunctionCallbackInfo<Value>& args) {
|
303 | 304 | }
|
304 | 305 |
|
305 | 306 |
|
306 |
| -void StreamBase::CallJSOnreadMethod(ssize_t nread, Local<Object> buf) { |
| 307 | +void StreamBase::CallJSOnreadMethod(ssize_t nread, |
| 308 | + Local<ArrayBuffer> ab, |
| 309 | + size_t offset) { |
307 | 310 | Environment* env = env_;
|
308 | 311 |
|
| 312 | +#ifdef DEBUG |
| 313 | + CHECK_EQ(static_cast<int32_t>(nread), nread); |
| 314 | + CHECK_EQ(static_cast<int32_t>(offset), offset); |
| 315 | + |
| 316 | + if (ab.IsEmpty()) { |
| 317 | + CHECK_EQ(offset, 0); |
| 318 | + CHECK_LE(nread, 0); |
| 319 | + } else { |
| 320 | + CHECK_GE(nread, 0); |
| 321 | + } |
| 322 | +#endif |
| 323 | + env->stream_base_state()[kReadBytesOrError] = nread; |
| 324 | + env->stream_base_state()[kArrayBufferOffset] = offset; |
| 325 | + |
309 | 326 | Local<Value> argv[] = {
|
310 |
| - Integer::New(env->isolate(), nread), |
311 |
| - buf |
| 327 | + ab.IsEmpty() ? Undefined(env->isolate()).As<Value>() : ab.As<Value>() |
312 | 328 | };
|
313 | 329 |
|
314 |
| - if (argv[1].IsEmpty()) |
315 |
| - argv[1] = Undefined(env->isolate()); |
316 |
| - |
317 | 330 | AsyncWrap* wrap = GetAsyncWrap();
|
318 | 331 | CHECK_NOT_NULL(wrap);
|
319 | 332 | wrap->MakeCallback(env->onread_string(), arraysize(argv), argv);
|
@@ -366,14 +379,18 @@ void EmitToJSStreamListener::OnStreamRead(ssize_t nread, const uv_buf_t& buf) {
|
366 | 379 | if (nread <= 0) {
|
367 | 380 | free(buf.base);
|
368 | 381 | if (nread < 0)
|
369 |
| - stream->CallJSOnreadMethod(nread, Local<Object>()); |
| 382 | + stream->CallJSOnreadMethod(nread, Local<ArrayBuffer>()); |
370 | 383 | return;
|
371 | 384 | }
|
372 | 385 |
|
373 | 386 | CHECK_LE(static_cast<size_t>(nread), buf.len);
|
374 | 387 | char* base = Realloc(buf.base, nread);
|
375 | 388 |
|
376 |
| - Local<Object> obj = Buffer::New(env, base, nread).ToLocalChecked(); |
| 389 | + Local<ArrayBuffer> obj = ArrayBuffer::New( |
| 390 | + env->isolate(), |
| 391 | + base, |
| 392 | + nread, |
| 393 | + v8::ArrayBufferCreationMode::kInternalized); // Transfer ownership to V8. |
377 | 394 | stream->CallJSOnreadMethod(nread, obj);
|
378 | 395 | }
|
379 | 396 |
|
|
0 commit comments