Browse Source

Merge pull request #712 from LinusU/segfault-fix

fix segfault on node 0.10.x
v1.x
Linus Unnebäck 9 years ago
parent
commit
398a91466f
  1. 8
      src/CanvasRenderingContext2d.cc

8
src/CanvasRenderingContext2d.cc

@ -731,13 +731,13 @@ NAN_METHOD(Context2d::GetImageData) {
int dstStride = sw * 4; int dstStride = sw * 4;
uint8_t *src = canvas->data(); uint8_t *src = canvas->data();
#if NODE_MAJOR_VERSION == 0 && NODE_MINOR_VERSION <= 10 #if NODE_MAJOR_VERSION == 0 && NODE_MINOR_VERSION <= 10
Local<Object> global = Context::GetCurrent()->Global(); Local<Object> global = Context::GetCurrent()->Global();
Local<Int32> sizeHandle = Nan::New(size); Local<Int32> sizeHandle = Nan::New(size);
Local<Value> caargv[] = { sizeHandle }; Local<Value> caargv[] = { sizeHandle };
Local<Object> clampedArray = global->Get(Nan::New("Uint8ClampedArray").ToLocalChecked()).As<Function>()->NewInstance(3, caargv); Local<Object> clampedArray = global->Get(Nan::New("Uint8ClampedArray").ToLocalChecked()).As<Function>()->NewInstance(1, caargv);
#else #else
Local<ArrayBuffer> buffer = ArrayBuffer::New(Isolate::GetCurrent(), size); Local<ArrayBuffer> buffer = ArrayBuffer::New(Isolate::GetCurrent(), size);
Local<Uint8ClampedArray> clampedArray = Uint8ClampedArray::New(buffer, 0, size); Local<Uint8ClampedArray> clampedArray = Uint8ClampedArray::New(buffer, 0, size);
@ -745,7 +745,7 @@ NAN_METHOD(Context2d::GetImageData) {
Nan::TypedArrayContents<uint8_t> typedArrayContents(clampedArray); Nan::TypedArrayContents<uint8_t> typedArrayContents(clampedArray);
uint8_t* dst = *typedArrayContents; uint8_t* dst = *typedArrayContents;
// Normalize data (argb -> rgba) // Normalize data (argb -> rgba)
for (int y = 0; y < sh; ++y) { for (int y = 0; y < sh; ++y) {
uint32_t *row = (uint32_t *)(src + srcStride * (y + sy)); uint32_t *row = (uint32_t *)(src + srcStride * (y + sy));
@ -902,7 +902,7 @@ NAN_METHOD(Context2d::DrawImage) {
dx - sx + (context->state->shadowOffsetX / fx) - pad + 1.4, dx - sx + (context->state->shadowOffsetX / fx) - pad + 1.4,
dy - sy + (context->state->shadowOffsetY / fy) - pad + 1.4); dy - sy + (context->state->shadowOffsetY / fy) - pad + 1.4);
cairo_paint(ctx); cairo_paint(ctx);
// cleanup // cleanup
cairo_destroy(shadow_context); cairo_destroy(shadow_context);
cairo_surface_destroy(shadow_surface); cairo_surface_destroy(shadow_surface);

Loading…
Cancel
Save