Mercurial > MadButterfly
diff tools/gen_v8_binding.m4 @ 740:00a8c8a9e157
Check if an object valid in gen_v8_binding.m4
author | Thinker K.F. Li <thinker@codemud.net> |
---|---|
date | Wed, 25 Aug 2010 10:07:33 +0800 |
parents | 4a38e571cfce |
children | e21ccbc4afb1 |
line wrap: on
line diff
--- a/tools/gen_v8_binding.m4 Mon Aug 23 10:23:30 2010 +0800 +++ b/tools/gen_v8_binding.m4 Wed Aug 25 10:07:33 2010 +0800 @@ -41,6 +41,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); return Integer::New(data->$][1); } @@ -52,6 +54,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); data->$][1 = value->Int32Value(); } ]) @@ -62,6 +66,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); return Number::New(data->$][1); } @@ -73,6 +79,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); data->$][1 = value->NumberValue(); } ]) @@ -83,6 +91,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); return ]PROJ_PREFIX[$][2_new(($][3 *)data->$][1); } @@ -96,8 +106,12 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); obj = value->ToObject(); v = ($][3 *)UNWRAP(obj); + if(v == NULL) + THROW_noret("Invalid object"); data->$][1 = v; } ]) @@ -108,6 +122,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); return data->$][1; } @@ -120,6 +136,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); data->$][1 = value; } ]) @@ -130,6 +148,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); return String::New(data->$][1); } @@ -141,6 +161,8 @@ STRUCT_TYPE *data; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); String::Utf8Value utf8(value->ToString()); free(data->$][1); data->$][1 = strdup(*utf8); @@ -158,6 +180,8 @@ const char *err = NULL; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW("Invalid object"); _ret = $][2(self, data, &err); if(err) THROW(err); @@ -173,6 +197,8 @@ const char *err = NULL; data = (STRUCT_TYPE *)UNWRAP(self); + if(data == NULL) + THROW_noret("Invalid object"); $][3(self, data, value, &err); if(err) THROW_noret(err); @@ -263,6 +289,8 @@ ])dnl fdefine([OBJ], [dnl arg_$][1 = ($][3 *)UNWRAP(args[[i++]]->ToObject()); + if(arg_$][1 == NULL) + THROW("Invalid argument"); ])dnl fdefine([ARRAY], [dnl arg_$][1 = args[[i++]]; @@ -287,6 +315,8 @@ ])dnl fdefine([OBJ], [dnl $1 = ($][2 *)UNWRAP($2->ToObject()); + if($1 == NULL) + THROW("Invalid argument"); ])dnl fdefine([ARRAY], [dnl $1 = $2; @@ -422,6 +452,8 @@ START_METHOD_RET_VAL[]$][5[]STOP_METHOD_ARG Handle<Value> _ret_val; + if(_self == NULL) + THROW("Invalid object"); if(argc != $][4) THROW("Invalid number of arguments (!=$][4)"); i = 0; @@ -473,6 +505,8 @@ START_METHOD_RET_VAL[]$2[]STOP_METHOD_ARG[]dnl Handle<Value> _ret_val; + if(obj == NULL) + THROW("Invalid object"); _ret = $1(obj, self, index, &_err); if(_err) THROW(_err); @@ -492,6 +526,8 @@ START_METHOD_RET_VAL[]$2[]STOP_METHOD_ARG[]dnl Handle<Value> _ret_val; + if(obj == NULL) + THROW("Invalid object"); if(START_TYPE_CHK(value)[]![]$2[]STOP_METHOD_ARG) THROW("Invalid value type");