Browse Source

Merge branch 'locals'

v1.x
Tj Holowaychuk 14 years ago
parent
commit
1df7fd81a1
  1. 21
      src/Canvas.cc
  2. 2
      src/Canvas.h

21
src/Canvas.cc

@ -155,12 +155,12 @@ EIO_AfterToBuffer(eio_req *req) {
ev_unref(EV_DEFAULT_UC); ev_unref(EV_DEFAULT_UC);
if (closure->status) { if (closure->status) {
Handle<Value> argv[1] = { Canvas::Error(closure->status) }; Local<Value> argv[1] = { Canvas::Error(closure->status) };
closure->pfn->Call(Context::GetCurrent()->Global(), 1, argv); closure->pfn->Call(Context::GetCurrent()->Global(), 1, argv);
} else { } else {
Buffer *buf = Buffer::New(closure->len); Buffer *buf = Buffer::New(closure->len);
memcpy(buf->data(), closure->data, closure->len); memcpy(buf->data(), closure->data, closure->len);
Handle<Value> argv[2] = { Null(), buf->handle_ }; Local<Value> argv[2] = { Local<Value>::New(Null()), Local<Value>::New(buf->handle_) };
closure->pfn->Call(Context::GetCurrent()->Global(), 2, argv); closure->pfn->Call(Context::GetCurrent()->Global(), 2, argv);
} }
@ -215,14 +215,18 @@ Canvas::ToBuffer(const Arguments &args) {
static cairo_status_t static cairo_status_t
streamPNG(void *c, const uint8_t *data, unsigned len) { streamPNG(void *c, const uint8_t *data, unsigned len) {
HandleScope scope;
closure_t *closure = (closure_t *) c; closure_t *closure = (closure_t *) c;
Buffer *buf = Buffer::New(len); Local<Buffer> buf = Buffer::New(len);
#if NODE_VERSION_AT_LEAST(0,3,0) #if NODE_VERSION_AT_LEAST(0,3,0)
memcpy(Buffer::Data(buf->handle_), data, len); memcpy(Buffer::Data(buf->handle_), data, len);
#else #else
memcpy(buf->data(), data, len); memcpy(buf->data(), data, len);
#endif #endif
Handle<Value> argv[3] = { Null(), buf->handle_, Integer::New(len) }; Local<Value> argv[3] = {
Local<Value>::New(Null())
, Local<Value>::New(buf->handle_)
, Integer::New(len) };
closure->fn->Call(Context::GetCurrent()->Global(), 3, argv); closure->fn->Call(Context::GetCurrent()->Global(), 3, argv);
return CAIRO_STATUS_SUCCESS; return CAIRO_STATUS_SUCCESS;
} }
@ -248,10 +252,13 @@ Canvas::StreamPNGSync(const Arguments &args) {
if (try_catch.HasCaught()) { if (try_catch.HasCaught()) {
return try_catch.ReThrow(); return try_catch.ReThrow();
} else if (status) { } else if (status) {
Handle<Value> argv[1] = { Canvas::Error(status) }; Local<Value> argv[1] = { Canvas::Error(status) };
closure.fn->Call(Context::GetCurrent()->Global(), 1, argv); closure.fn->Call(Context::GetCurrent()->Global(), 1, argv);
} else { } else {
Handle<Value> argv[3] = { Null(), Null(), Integer::New(0) }; Local<Value> argv[3] = {
Local<Value>::New(Null())
, Local<Value>::New(Null())
, Integer::New(0) };
closure.fn->Call(Context::GetCurrent()->Global(), 3, argv); closure.fn->Call(Context::GetCurrent()->Global(), 3, argv);
} }
return Undefined(); return Undefined();
@ -289,7 +296,7 @@ Canvas::resurface() {
* Construct an Error from the given cairo status. * Construct an Error from the given cairo status.
*/ */
Handle<Value> Local<Value>
Canvas::Error(cairo_status_t status) { Canvas::Error(cairo_status_t status) {
return Exception::Error(String::New(cairo_status_to_string(status))); return Exception::Error(String::New(cairo_status_to_string(status)));
} }

2
src/Canvas.h

@ -58,7 +58,7 @@ class Canvas: public node::ObjectWrap {
static void SetWidth(Local<String> prop, Local<Value> val, const AccessorInfo &info); static void SetWidth(Local<String> prop, Local<Value> val, const AccessorInfo &info);
static void SetHeight(Local<String> prop, Local<Value> val, const AccessorInfo &info); static void SetHeight(Local<String> prop, Local<Value> val, const AccessorInfo &info);
static Handle<Value> StreamPNGSync(const Arguments &args); static Handle<Value> StreamPNGSync(const Arguments &args);
static Handle<Value> Error(cairo_status_t status); static Local<Value> Error(cairo_status_t status);
inline cairo_surface_t *getSurface(){ return _surface; } inline cairo_surface_t *getSurface(){ return _surface; }
Canvas(int width, int height); Canvas(int width, int height);
void resurface(); void resurface();

Loading…
Cancel
Save