diff nodejs/shapes.cc @ 574:a2faee809514

Implement stext type for Javascript
author Thinker K.F. Li <thinker@branda.to>
date Wed, 09 Jun 2010 22:06:50 +0800
parents 49e79253b6d3
children 5a68e2bcea17
line wrap: on
line diff
--- a/nodejs/shapes.cc	Wed Jun 09 17:30:09 2010 +0800
+++ b/nodejs/shapes.cc	Wed Jun 09 22:06:50 2010 +0800
@@ -192,17 +192,112 @@
 
 /* @} */
 
+/*! \defgroup stext_path Template for stext objects.
+ *
+ * @{
+ */
+
+/*! \brief Constructor for stext objects.
+ *
+ * 4 arguments
+ * \param rt is a runtime object.
+ * \param data is a text to be showed.
+ * \param x is postion in x-axis.
+ * \param y is position in y-axis.
+ */
+static Handle<Value>
+xnjsmb_shape_stext(const Arguments &args) {
+    int argc = args.Length();
+    Handle<Object> self = args.This();
+    Handle<Object> rt;
+    float x, y;
+    char *data;
+    redraw_man_t *rdman;
+    shape_t *stext;
+    
+    if(argc != 4)
+	THROW("Invalid number of arguments (!= 4)");
+    if(!args[0]->IsObject() || !args[1]->IsString() ||
+       !args[2]->IsNumber() || !args[3]->IsNumber())
+	THROW("Invalid argument type");
+
+    rt = args[0]->ToObject();
+    String::Utf8Value data_utf8(args[1]);
+    data = *data_utf8;
+    x = args[2]->ToNumber()->Value();
+    y = args[3]->ToNumber()->Value();
+
+    rdman = xnjsmb_rt_rdman(rt);
+    ASSERT(rdman != NULL);
+
+    stext = rdman_shape_stext_new(rdman, data, x, y);
+
+    WRAP(self, stext);
+    SET(self, "mbrt", rt);
+
+    return Null();
+}
+
+static Persistent<FunctionTemplate> xnjsmb_shape_stext_temp;
+
+/*! \brief Create a stext and return it.
+ */
+static Handle<Value>
+xnjsmb_shape_stext_new(const Arguments &args) {
+    HandleScope scope;
+    int argc = args.Length();
+    Handle<Object> self = args.This();
+    Handle<Value> stext_args[4];
+    Handle<Object> stext_obj;
+    Handle<Function> func;
+
+    if(argc != 3)
+	THROW("Invalid number of arguments (!= 3)");
+
+    stext_args[0] = self;
+    stext_args[1] = args[0];
+    stext_args[2] = args[1];
+    stext_args[3] = args[2];
+
+    func = xnjsmb_shape_stext_temp->GetFunction();
+    stext_obj = func->NewInstance(4, stext_args);
+    ASSERT(stext_obj != NULL);
+
+    return stext_obj;
+}
+
+/*! \brief Initialize function template for stext objects.
+ */
+void
+xnjsmb_init_stext_temp(void) {
+    Handle<FunctionTemplate> func_temp;
+    Handle<ObjectTemplate> inst_temp;
+    
+    func_temp = FunctionTemplate::New(xnjsmb_shape_stext);
+    func_temp->Inherit(xnjsmb_shape_temp);
+    func_temp->SetClassName(String::New("stext"));
+    
+    inst_temp = func_temp->InstanceTemplate();
+    inst_temp->SetInternalFieldCount(1);
+    
+    xnjsmb_shape_stext_temp = Persistent<FunctionTemplate>::New(func_temp);
+}
+
+/* @} */
+
 /*! \brief Set properties of template of mb_rt.
  */
 void
 xnjsmb_shapes_init_mb_rt_temp(Handle<FunctionTemplate> rt_temp) {
-    Handle<FunctionTemplate> path_new_temp;
+    HandleScope scope;
+    Handle<FunctionTemplate> path_new_temp, stext_new_temp;
     Handle<ObjectTemplate> rt_proto_temp;
     static int temp_init_flag = 0;
 
     if(temp_init_flag == 0) {
 	xnjsmb_init_shape_temp();
 	xnjsmb_init_path_temp();
+	xnjsmb_init_stext_temp();
 	temp_init_flag = 1;
     }
 
@@ -210,4 +305,7 @@
     
     path_new_temp = FunctionTemplate::New(xnjsmb_shape_path_new);
     SET(rt_proto_temp, "path_new", path_new_temp);
+
+    stext_new_temp = FunctionTemplate::New(xnjsmb_shape_stext_new);
+    SET(rt_proto_temp, "stext_new", stext_new_temp);
 }