Mercurial > MadButterfly
diff nodejs/coord.cc @ 560:ce7a35abcb0d Android_Skia
Function to instantiate coord for Javascript
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Mon, 07 Jun 2010 11:47:34 +0800 |
parents | 0ca8437a91fa |
children | 1b6402f07cd4 |
line wrap: on
line diff
--- a/nodejs/coord.cc Mon Jun 07 11:42:45 2010 +0800 +++ b/nodejs/coord.cc Mon Jun 07 11:47:34 2010 +0800 @@ -8,6 +8,12 @@ #include "X_supp_njs.h" } +#include "mbfly_njs.h" + +#ifndef ASSERT +#define ASSERT(x) +#endif + using namespace v8; static Handle<Value> @@ -16,15 +22,12 @@ Handle<Object> self; coord_t *coord; co_aix v; - Handle<Value> exc; - if(index < 0 || index >= 6) { - exc = Exception::Error(String::New("Invalid index")); - return ThrowException(exc); - } + if(index < 0 || index >= 6) + THROW("Invalid index"); self = info.This(); - coord = (coord_t *)External::Unwrap(self->Get(String::New("_njs_coord"))); + coord = (coord_t *)UNWRAP(self); v = coord_get_matrix(coord)[index]; return Number::New(v); @@ -36,28 +39,84 @@ HandleScope scope; Handle<Object> self; + Handle<Object> js_rt; redraw_man_t *rdman; coord_t *coord; co_aix v; - Handle<Value> exc; - if(index < 0 || index >= 6) { - exc = Exception::Error(String::New("Invalid index")); - return ThrowException(exc); - } - if(!value->IsNumber()) { - exc = Exception::Error(String::New("Invalid value")); - return ThrowException(exc); - } + if(index < 0 || index >= 6) + THROW("Invalid Index"); + if(!value->IsNumber()) + THROW("Invalid value"); self = info.This(); - coord = (coord_t *)External::Unwrap(self->Get(String::New("_njs_coord"))); + coord = (coord_t *)UNWRAP(self); v = value->NumberValue(); coord_get_matrix(coord)[index] = v; - rdman = (redraw_man_t *) - External::Unwrap(self->Get(String::New("_njs_rdman"))); + js_rt = GET(self, "mbrt")->ToObject(); + rdman = xnjsmb_rt_rdman(js_rt); rdman_coord_changed(rdman, coord); return value; } + +static Persistent<ObjectTemplate> coord_obj_temp; + +static void +xnjsmb_init_temp(void) { + coord_obj_temp = Persistent<ObjectTemplate>(ObjectTemplate::New()); + coord_obj_temp->SetIndexedPropertyHandler(xnjsmb_coord_get_index, + xnjsmb_coord_set_index); + coord_obj_temp->SetInternalFieldCount(1); +} + +/*! \brief Create a coord object associated with the rdman of the runtime. + * + * Two internal fields, coord and rdman. + */ +Handle<Value> +xnjsmb_coord_new(const Arguments &args) { + HandleScope scope; + Handle<Object> js_rt; + Handle<Object> coord_obj, parent_obj; + njs_runtime_t *rt; + redraw_man_t *rdman; + coord_t *coord, *parent = NULL; + int argc; + static int init_temp = 0; + + if(!init_temp) { + xnjsmb_init_temp(); + init_temp = 1; + } + + argc = args.Length(); + if(argc > 1) + THROW("Too many arguments (> 1)"); + + js_rt = args.This(); + rt = (njs_runtime_t *)UNWRAP(js_rt); + rdman = X_njs_MB_rdman(rt); + + if(argc == 1) { + parent_obj = args[0]->ToObject(); + parent = (coord_t *)UNWRAP(parent_obj); + } + + /* + * Set Javascript object + */ + coord = rdman_coord_new(rdman, parent); + ASSERT(coord != NULL); + + coord_obj = coord_obj_temp->NewInstance(); + ASSERT(coord_obj != NULL); + WRAP(coord_obj, coord); + + if(parent != NULL) + SET(coord_obj, "parent", parent_obj); + SET(coord_obj, "mbrt", js_rt); + + return coord_obj; +}