diff nodejs/paints.cc @ 568:d796e6b8b97e Android_Skia

Real initialize a paint_color_t object for paint_color JS obj
author Thinker K.F. Li <thinker@branda.to>
date Wed, 09 Jun 2010 14:10:58 +0800
parents a12c3448afb6
children f87a368e847a
line wrap: on
line diff
--- a/nodejs/paints.cc	Wed Jun 09 12:28:03 2010 +0800
+++ b/nodejs/paints.cc	Wed Jun 09 14:10:58 2010 +0800
@@ -8,21 +8,46 @@
 
 using namespace v8;
 
+#ifndef ASSERT
+#define ASSERT(x)
+#endif
 
-/*! \brief Base type of all types of paints.
- */
-static Handle<Value>
-xnjsmb_paint(const Arguments &args) {
-}
 
 /*! \brief Constructor of color paint_color_t object for Javascript.
  */
 static Handle<Value>
 xnjsmb_paint_color(const Arguments &args) {
+    int argc = args.Length();
+    Handle<Object> self = args.This();
+    Handle<Object> rt;
+    redraw_man_t *rdman;
+    paint_t *paint;
+    float r, g, b, a;
+
+    if(argc != 5)
+	THROW("Invalid number of arguments (!= 5)");
+    if(!args[0]->IsObject() || !args[1]->IsNumber() ||
+       !args[2]->IsNumber() || !args[3]->IsNumber() ||
+       !args[4]->IsNumber())
+	THROW("Invalid argument type");
+
+    rt = args[0]->ToObject();
+    r = args[1]->ToNumber()->Value();
+    g = args[2]->ToNumber()->Value();
+    b = args[3]->ToNumber()->Value();
+    a = args[4]->ToNumber()->Value();
+
+    rdman = xnjsmb_rt_rdman(rt);
+    paint = rdman_paint_color_new(rdman, r, g, b, a);
+    ASSERT(sh != NULL);
+
+    WRAP(self, paint);
+
+    return Null();
 }
 
-static Persistent<FunctionTemplate> paint_temp;
-static Persistent<FunctionTemplate> paint_color_temp;
+static Persistent<FunctionTemplate> xnjsmb_paint_temp;
+static Persistent<FunctionTemplate> xnjsmb_paint_color_temp;
 
 /*! \brief Create and return a paint_color object.
  */
@@ -32,7 +57,7 @@
     Handle<Object> rt = args.This();
     Handle<Object> paint_color_obj;
     Handle<Function> paint_color_func;
-    Handle<Value> pc_args[4];
+    Handle<Value> pc_args[5];
     int argc;
     int i;
 
@@ -48,14 +73,14 @@
     pc_args[2] = args[1];	// g
     pc_args[3] = args[2];	// b
     pc_args[4] = args[3];	// a
-    paint_color_func = paint_color_temp->GetFunction();
-    paint_color_obj = paint_color_func->NewInstance(1, pc_args);
+    paint_color_func = xnjsmb_paint_color_temp->GetFunction();
+    paint_color_obj = paint_color_func->NewInstance(5, pc_args);
 
     scope.Close(paint_color_obj);
     return paint_color_obj;
 }
 
-static Persistent<FunctionTemplate> paint_color_new_temp;
+static Persistent<FunctionTemplate> xnjsmb_paint_color_new_temp;
 
 /*! \brief Create templates for paint types.
  *
@@ -64,18 +89,28 @@
 static void
 xnjsmb_init_paints(void) {
     Handle<FunctionTemplate> temp;
+    Handle<ObjectTemplate> inst_temp;
     
-    temp = FunctionTemplate::New(xnjsmb_paint);
-    paint_temp = Persistent<FunctionTemplate>::New(temp);
-    paint_temp->SetClassName(String::New("paint"));
+    /*
+     * Base type of paint types.
+     */
+    temp = FunctionTemplate::New();
+    xnjsmb_paint_temp = Persistent<FunctionTemplate>::New(temp);
+    xnjsmb_paint_temp->SetClassName(String::New("paint"));
 
+    /*
+     * Paint color
+     */
     temp = FunctionTemplate::New(xnjsmb_paint_color);
-    paint_color_temp = Persistent<FunctionTemplate>::New(temp);
-    paint_color_temp->SetClassName(String::New("paint_color"));
-    paint_color_temp->Inherit(paint_temp);
+    xnjsmb_paint_color_temp = Persistent<FunctionTemplate>::New(temp);
+    xnjsmb_paint_color_temp->SetClassName(String::New("paint_color"));
+    xnjsmb_paint_color_temp->Inherit(xnjsmb_paint_temp);
+    
+    inst_temp = xnjsmb_paint_color_temp->InstanceTemplate();
+    inst_temp->SetInternalFieldCount(1);
 
     temp = FunctionTemplate::New(xnjsmb_paint_color_new);
-    paint_color_new_temp = Persistent<FunctionTemplate>::New(temp);
+    xnjsmb_paint_color_new_temp = Persistent<FunctionTemplate>::New(temp);
 }
 
 void xnjsmb_paints_init_mb_rt_temp(Handle<FunctionTemplate> rt_temp) {
@@ -88,5 +123,5 @@
     }
 
     rt_proto_temp = rt_temp->PrototypeTemplate();
-    SET(rt_proto_temp, "paint_color_new", paint_color_new_temp);
+    SET(rt_proto_temp, "paint_color_new", xnjsmb_paint_color_new_temp);
 }