Browse Source

Merge pull request #717 from LinusU/new-type-error

require new in constructor
v1.x
Linus Unnebäck 9 years ago
parent
commit
181686463c
  1. 4
      src/Canvas.cc
  2. 4
      src/CanvasGradient.cc
  3. 4
      src/CanvasPattern.cc
  4. 4
      src/CanvasRenderingContext2d.cc
  5. 5
      src/FontFace.cc
  6. 4
      src/Image.cc
  7. 4
      src/ImageData.cc
  8. 4
      test/canvas.test.js
  9. 4
      test/image.test.js
  10. 4
      test/imageData.test.js

4
src/Canvas.cc

@ -63,6 +63,10 @@ Canvas::Initialize(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target) {
*/ */
NAN_METHOD(Canvas::New) { NAN_METHOD(Canvas::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
int width = 0, height = 0; int width = 0, height = 0;
canvas_type_t type = CANVAS_TYPE_IMAGE; canvas_type_t type = CANVAS_TYPE_IMAGE;
if (info[0]->IsNumber()) width = info[0]->Uint32Value(); if (info[0]->IsNumber()) width = info[0]->Uint32Value();

4
src/CanvasGradient.cc

@ -35,6 +35,10 @@ Gradient::Initialize(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target) {
*/ */
NAN_METHOD(Gradient::New) { NAN_METHOD(Gradient::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
// Linear // Linear
if (4 == info.Length()) { if (4 == info.Length()) {
Gradient *grad = new Gradient( Gradient *grad = new Gradient(

4
src/CanvasPattern.cc

@ -37,6 +37,10 @@ Pattern::Initialize(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target) {
*/ */
NAN_METHOD(Pattern::New) { NAN_METHOD(Pattern::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
int w = 0 int w = 0
, h = 0; , h = 0;
cairo_surface_t *surface; cairo_surface_t *surface;

4
src/CanvasRenderingContext2d.cc

@ -536,6 +536,10 @@ Context2d::blur(cairo_surface_t *surface, int radius) {
*/ */
NAN_METHOD(Context2d::New) { NAN_METHOD(Context2d::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
Local<Object> obj = info[0]->ToObject(); Local<Object> obj = info[0]->ToObject();
if (!Nan::New(Canvas::constructor)->HasInstance(obj)) if (!Nan::New(Canvas::constructor)->HasInstance(obj))
return Nan::ThrowTypeError("Canvas expected"); return Nan::ThrowTypeError("Canvas expected");

5
src/FontFace.cc

@ -53,6 +53,10 @@ static cairo_user_data_key_t key;
*/ */
NAN_METHOD(FontFace::New) { NAN_METHOD(FontFace::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
if (!info[0]->IsString() if (!info[0]->IsString()
|| !info[1]->IsNumber()) { || !info[1]->IsNumber()) {
return Nan::ThrowError("Wrong argument types passed to FontFace constructor"); return Nan::ThrowError("Wrong argument types passed to FontFace constructor");
@ -107,4 +111,3 @@ NAN_METHOD(FontFace::New) {
face->Wrap(info.This()); face->Wrap(info.This());
info.GetReturnValue().Set(info.This()); info.GetReturnValue().Set(info.This());
} }

4
src/Image.cc

@ -67,6 +67,10 @@ Image::Initialize(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target) {
*/ */
NAN_METHOD(Image::New) { NAN_METHOD(Image::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
Image *img = new Image; Image *img = new Image;
img->data_mode = DATA_IMAGE; img->data_mode = DATA_IMAGE;
img->Wrap(info.This()); img->Wrap(info.This());

4
src/ImageData.cc

@ -35,6 +35,10 @@ ImageData::Initialize(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE target) {
*/ */
NAN_METHOD(ImageData::New) { NAN_METHOD(ImageData::New) {
if (!info.IsConstructCall()) {
return Nan::ThrowTypeError("Class constructors cannot be invoked without 'new'");
}
#if NODE_MAJOR_VERSION == 0 && NODE_MINOR_VERSION <= 10 #if NODE_MAJOR_VERSION == 0 && NODE_MINOR_VERSION <= 10
Local<v8::Object> clampedArray; Local<v8::Object> clampedArray;
Local<Object> global = Context::GetCurrent()->Global(); Local<Object> global = Context::GetCurrent()->Global();

4
test/canvas.test.js

@ -12,6 +12,10 @@ console.log(' canvas: %s', Canvas.version);
console.log(' cairo: %s', Canvas.cairoVersion); console.log(' cairo: %s', Canvas.cairoVersion);
describe('Canvas', function () { describe('Canvas', function () {
it('should require new', function () {
assert.throws(function () { Canvas(); }, TypeError);
});
it('.version', function () { it('.version', function () {
assert.ok(/^\d+\.\d+\.\d+$/.test(Canvas.version)); assert.ok(/^\d+\.\d+\.\d+$/.test(Canvas.version));
}); });

4
test/image.test.js

@ -11,6 +11,10 @@ var png_checkers = __dirname + '/fixtures/checkers.png';
var png_clock = __dirname + '/fixtures/clock.png'; var png_clock = __dirname + '/fixtures/clock.png';
describe('Image', function () { describe('Image', function () {
it('should require new', function () {
assert.throws(function () { Image(); }, TypeError);
});
it('Image', function () { it('Image', function () {
assert.ok(Image instanceof Function); assert.ok(Image instanceof Function);
}); });

4
test/imageData.test.js

@ -5,6 +5,10 @@ var Canvas = require('../')
, assert = require('assert'); , assert = require('assert');
describe('ImageData', function () { describe('ImageData', function () {
it('should require new', function () {
assert.throws(function () { ImageData(); }, TypeError);
});
it('should throw with invalid numeric arguments', function () { it('should throw with invalid numeric arguments', function () {
assert.throws(function () { assert.throws(function () {
new ImageData(0, 0); new ImageData(0, 0);

Loading…
Cancel
Save