Mercurial > MadButterfly
diff nodejs/shapes.cc @ 683:7685c57e29d0
Migrate JS shapes binding to gen_v8_binding.m4
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Sat, 07 Aug 2010 18:27:53 +0800 |
parents | c643af2095c5 |
children | b346e4699e55 |
line wrap: on
line diff
--- a/nodejs/shapes.cc Sat Aug 07 18:26:19 2010 +0800 +++ b/nodejs/shapes.cc Sat Aug 07 18:27:53 2010 +0800 @@ -1,6 +1,8 @@ #include <v8.h> #include "mbfly_njs.h" +#include <string.h> + extern "C" { #include <mb.h> } @@ -11,72 +13,58 @@ using namespace v8; -/*! \defgroup shape_temp Templates for shape and derivations. +/*! \defgroup xnjsmb_shapes Implement binding of shapes. + * \ingroup xnjsmb * * @{ */ -static Persistent<FunctionTemplate> xnjsmb_shape_temp; - -static Handle<Value> -xnjsmb_shape_show(const Arguments &args) { - shape_t *sh; - Handle<Object> self; - - self = args.This(); - sh = (shape_t *)UNWRAP(self); - sh_show(sh); +static void +xnjsmb_sh_stext_set_style(shape_t *sh, Handle<Value> blks, const char **err) { + Array *blksobj; + Array *blkobj; + mb_style_blk_t *mb_blks; + int nblks; + int r; + int i; - return Null(); + blksobj = Array::Cast(*blks); + nblks = blksobj->Length(); + mb_blks = new mb_style_blk_t[nblks]; + for(i = 0; i < nblks; i++) { + blkobj = Array::Cast(*blksobj->Get(i)); + mb_blks[i].n_chars = blkobj->Get(0)->ToInt32()->Value(); + mb_blks[i].face = (mb_font_face_t *)UNWRAP(blkobj->Get(1)->ToObject()); + mb_blks[i].font_sz = blkobj->Get(2)->ToNumber()->Value(); + } + + r = sh_stext_set_style(sh, mb_blks, nblks); + if(r != 0) { + *err = "Unknown error"; + return; + } + + delete mb_blks; } static Handle<Value> -xnjsmb_shape_hide(const Arguments &args) { - shape_t *sh; - Handle<Object> self; +xnjsmb_shape_stroke_width_get(Handle<Object> self, shape_t *sh, + const char **err) { + float stroke_width; - self = args.This(); - sh = (shape_t *)UNWRAP(self); - sh_hide(sh); - - return Null(); + stroke_width = sh_get_stroke_width(sh); + return Number::New(stroke_width); } -/*! \brief Get stroke width of a shape. - */ -static Handle<Value> -xnjsmb_shape_stroke_width_getter(Local<String> property, - const AccessorInfo &info) { - Handle<Object> self = info.This(); - shape_t *sh; - float w; - Handle<Value> w_val; - - sh = (shape_t *)UNWRAP(self); - w = sh_get_stroke_width(sh); - w_val = Number::New(w); +static void +xnjsmb_shape_stroke_width_set(Handle<Object> self, shape_t *sh, + Handle<Value> value, const char **err) { + float stroke_width; + Handle<Object> rt; + redraw_man_t *rdman; - return w_val; -} - -/*! \brief Set stroke width of a shape. - */ -static void -xnjsmb_shape_stroke_width_setter(Local<String> property, - Local<Value> value, - const AccessorInfo &info) { - Handle<Object> self = info.This(); - Handle<Object> rt; - shape_t *sh; - redraw_man_t *rdman; - float w; - Handle<Number> w_num; + stroke_width = value->Int32Value(); + sh_set_stroke_width(sh, stroke_width); - sh = (shape_t *)UNWRAP(self); - w_num = value->ToNumber(); - w = w_num->Value(); - - sh_set_stroke_width(sh, w); - /* * Mark changed. */ @@ -88,358 +76,77 @@ rdman_shape_changed(rdman, sh); } -static void -xnjsmb_init_shape_temp(void) { - Handle<FunctionTemplate> temp; - Handle<ObjectTemplate> proto_temp; - Handle<FunctionTemplate> method_temp; - - temp = FunctionTemplate::New(); - temp->SetClassName(String::New("shape")); - xnjsmb_shape_temp = Persistent<FunctionTemplate>::New(temp); - proto_temp = temp->PrototypeTemplate(); - - method_temp = FunctionTemplate::New(xnjsmb_shape_show); - SET(proto_temp, "show", method_temp); - method_temp = FunctionTemplate::New(xnjsmb_shape_hide); - SET(proto_temp, "hide", method_temp); - - proto_temp->SetAccessor(String::New("stroke_width"), - xnjsmb_shape_stroke_width_getter, - xnjsmb_shape_stroke_width_setter); -} - /* @} */ -/*! \defgroup path_temp Templates for path objects. +#include "shapes-inc.h" + +/*! \defgroup xnjsmb_shapes_export Export functions of creating objects. + * \ingroup xnjsmb_shapes * * @{ */ -static Persistent<FunctionTemplate> xnjsmb_path_temp; - -/*! \brief Callback of constructor of path objects for Javascript. - */ -static Handle<Value> -xnjsmb_shape_path(const Arguments &args) { - shape_t *sh; - redraw_man_t *rdman; - Handle<Object> self = args.This(); // path object - Handle<Object> rt; - Persistent<Object> *self_hdl; - char *dstr; - int argc; - - argc = args.Length(); - if(argc != 2) - THROW("Invalid number of arugments (!= 1)"); - if(!args[0]->IsString()) - THROW("Invalid argument type (should be a string)"); - if(!args[1]->IsObject()) - THROW("Invalid argument type (should be an object)"); - - String::Utf8Value dutf8(args[0]->ToString()); - dstr = *dutf8; - - rt = args[1]->ToObject(); - rdman = xnjsmb_rt_rdman(rt); - sh = rdman_shape_path_new(rdman, dstr); - - WRAP(self, sh); - SET(self, "mbrt", rt); - /* Keep associated js object in property store for retrieving, - * later, without create new js object. - */ - self_hdl = new Persistent<Object>(self); - mb_prop_set(&sh->obj.props, PROP_JSOBJ, self_hdl); - - return Null(); +Handle<Value> +export_xnjsmb_auto_path_new(shape_t *sh) { + return xnjsmb_auto_path_new(sh); } -/*! \brief Initial function template for constructor of path objects. - */ -static void -xnjsmb_init_path_temp(void) { - Handle<FunctionTemplate> temp; - Handle<ObjectTemplate> inst_temp; - - temp = FunctionTemplate::New(xnjsmb_shape_path); - temp->Inherit(xnjsmb_shape_temp); - temp->SetClassName(String::New("path")); - - inst_temp = temp->InstanceTemplate(); - inst_temp->SetInternalFieldCount(1); - - xnjsmb_path_temp = Persistent<FunctionTemplate>::New(temp); +Handle<Value> +export_xnjsmb_auto_stext_new(shape_t *sh) { + return xnjsmb_auto_stext_new(sh); } -/*! \brief Callback function of mb_rt.path_new(). - */ -static Handle<Value> -xnjsmb_shape_path_new(const Arguments &args) { - HandleScope scope; - Handle<Object> self = args.This(); // runtime object - Handle<Object> path_obj; - Handle<Value> path_args[2]; - int argc; - - argc = args.Length(); - if(argc != 1) - THROW("Invalid number of arugments (!= 1)"); - if(!args[0]->IsString()) - THROW("Invalid argument type (shoud be a string)"); - - path_args[0] = args[0]; - path_args[1] = self; - - path_obj = xnjsmb_path_temp->GetFunction()->NewInstance(2, path_args); - - scope.Close(path_obj); - return path_obj; +Handle<Value> +export_xnjsmb_auto_image_new(shape_t *sh) { + return xnjsmb_auto_image_new(sh); } /* @} */ -/*! \defgroup stext_path Template for stext objects. +/*! \defgroup xnjsmb_shapes_wraps Wrap functions for shape objects. + * \ingroup xnjsmb_shapes + * + * These functions are used by methods of mb_rt to wrap shape objects + * as Javascript 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; - Persistent<Object> *self_hdl; - float x, y; - char *data; +shape_t * +xnjsmb_path_new(njs_runtime_t *rt, const char *d) { redraw_man_t *rdman; - shape_t *stext; + shape_t *sh; - 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); - /* Keep associated js object in property store for retrieving, - * later, without create new js object. - */ - self_hdl = new Persistent<Object>(self); - mb_prop_set(&stext->obj.props, PROP_JSOBJ, self_hdl); - - 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); - - scope.Close(stext_obj); - return stext_obj; + rdman = X_njs_MB_rdman(rt); + sh = rdman_shape_path_new(rdman, d); + + return sh; } -/*! \brief Setup style blocks for a stext. - * - * It defines font style and size for blocks of text message. - * - * \param blks is a list (n_char, face, font size) tuples. - */ -static Handle<Value> -xnjsmb_shape_stext_set_style(const Arguments &args) { - HandleScope scope; - int argc = args.Length(); - Handle<Object> self = args.This(); +shape_t * +xnjsmb_stext_new(njs_runtime_t *rt, const char *txt, float x, float y) { + redraw_man_t *rdman; shape_t *sh; - Array *blksobj; - Array *blkobj; - mb_style_blk_t *blks; - int nblks; - int i; - int r; - - if(argc != 1) - THROW("Invalid number of arguments (!= 1)"); - if(!args[0]->IsArray()) - THROW("Invalid type of the argument"); - blksobj = Array::Cast(*args[0]); - nblks = blksobj->Length(); - blks = new mb_style_blk_t[nblks]; - for(i = 0; i < nblks; i++) { - blkobj = Array::Cast(*blksobj->Get(i)); - blks[i].n_chars = blkobj->Get(0)->ToInt32()->Value(); - blks[i].face = (mb_font_face_t *)UNWRAP(blkobj->Get(1)->ToObject()); - blks[i].font_sz = blkobj->Get(2)->ToNumber()->Value(); - } - - sh = (shape_t *)UNWRAP(self); - r = sh_stext_set_style(sh, blks, nblks); - if(r != 0) - THROW("Unknown error"); - - delete blks; - - return Null(); -} + rdman = X_njs_MB_rdman(rt); + sh = rdman_shape_stext_new(rdman, txt, x, y); -/*! \brief Initialize function template for stext objects. - */ -static void -xnjsmb_init_stext_temp(void) { - Handle<FunctionTemplate> func_temp; - Handle<FunctionTemplate> meth_temp; - Handle<ObjectTemplate> inst_temp; - Handle<ObjectTemplate> proto_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); - - proto_temp = func_temp->PrototypeTemplate(); - meth_temp = FunctionTemplate::New(xnjsmb_shape_stext_set_style); - SET(proto_temp, "set_style", meth_temp); - - xnjsmb_shape_stext_temp = Persistent<FunctionTemplate>::New(func_temp); + return sh; } -/* @} */ - -/*! \defgroup image_temp Templates for image objects. - * - * @{ - */ - -static Handle<Value> -xnjsmb_shape_image(const Arguments &args) { - int argc = args.Length(); - Handle<Object> self = args.This(); - Handle<Object> rt; - Persistent<Object> *self_hdl; - float x, y; - float w, h; +shape_t * +xnjsmb_image_new(njs_runtime_t *rt, float x, float y, float w, float h) { redraw_man_t *rdman; - shape_t *img; - - 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(); - x = args[1]->ToNumber()->Value(); - y = args[2]->ToNumber()->Value(); - w = args[3]->ToNumber()->Value(); - h = args[4]->ToNumber()->Value(); - - rdman = xnjsmb_rt_rdman(rt); - img = rdman_shape_image_new(rdman, x, y, w, h); - - WRAP(self, img); - SET(self, "mbrt", rt); - /* Keep associated js object in property store for retrieving, - * later, without create new js object. - */ - self_hdl = new Persistent<Object>(self); - mb_prop_set(&img->obj.props, PROP_JSOBJ, self_hdl); + shape_t *sh; - return Null(); -} - -static Persistent<FunctionTemplate> xnjsmb_shape_image_temp; - -static Handle<Value> -xnjsmb_shape_image_new(const Arguments &args) { - HandleScope scope; - int argc = args.Length(); - Handle<Object> self = args.This(); - Handle<Value> img_args[5]; - Handle<Object> img_obj; - Handle<Function> func; - - if(argc != 4) - THROW("Invalid number of arguments (!= 3)"); - - img_args[0] = self; - img_args[1] = args[0]; - img_args[2] = args[1]; - img_args[3] = args[2]; - img_args[4] = args[3]; + rdman = X_njs_MB_rdman(rt); + sh = rdman_shape_image_new(rdman, x, y, w, h); - func = xnjsmb_shape_image_temp->GetFunction(); - img_obj = func->NewInstance(5, img_args); - ASSERT(img_obj != NULL); - - scope.Close(img_obj); - return img_obj; -} - -static void -xnjsmb_init_image_temp() { - Handle<FunctionTemplate> func_temp; - Handle<FunctionTemplate> meth_temp; - Handle<ObjectTemplate> inst_temp; - Handle<ObjectTemplate> proto_temp; - - func_temp = FunctionTemplate::New(xnjsmb_shape_image); - func_temp->Inherit(xnjsmb_shape_temp); - func_temp->SetClassName(String::New("image")); - - inst_temp = func_temp->InstanceTemplate(); - inst_temp->SetInternalFieldCount(1); - - xnjsmb_shape_image_temp = Persistent<FunctionTemplate>::New(func_temp); + return sh; } /* @} */ /*! \brief Set properties of template of mb_rt. + * \ingroup xnjsmb_shapes */ void xnjsmb_shapes_init_mb_rt_temp(Handle<FunctionTemplate> rt_temp) { @@ -450,21 +157,11 @@ static int temp_init_flag = 0; if(temp_init_flag == 0) { - xnjsmb_init_shape_temp(); - xnjsmb_init_path_temp(); - xnjsmb_init_stext_temp(); - xnjsmb_init_image_temp(); + xnjsmb_auto_shape_init(); + xnjsmb_auto_path_init(); + xnjsmb_auto_stext_init(); + xnjsmb_auto_image_init(); temp_init_flag = 1; } - - rt_proto_temp = rt_temp->PrototypeTemplate(); - - 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); - - image_new_temp = FunctionTemplate::New(xnjsmb_shape_image_new); - SET(rt_proto_temp, "image_new", image_new_temp); + return; }