diff options
| author | Bojidar Marinov | 2016-11-10 23:06:00 +0200 |
|---|---|---|
| committer | Bojidar Marinov | 2016-12-17 11:14:53 +0200 |
| commit | 23381a530bb4a9c8e8c3e883a7d588bf832cd277 (patch) | |
| tree | d05a019bc06ad68c00f4d30cd1c18642b0e74782 /modules/gdscript/gd_functions.cpp | |
| parent | 7d1230a266f4eab3262ebfcbf4a89148dfcb3c48 (diff) | |
| download | godot-23381a530bb4a9c8e8c3e883a7d588bf832cd277.tar.gz godot-23381a530bb4a9c8e8c3e883a7d588bf832cd277.tar.zst godot-23381a530bb4a9c8e8c3e883a7d588bf832cd277.zip | |
Diffstat (limited to 'modules/gdscript/gd_functions.cpp')
| -rw-r--r-- | modules/gdscript/gd_functions.cpp | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/modules/gdscript/gd_functions.cpp b/modules/gdscript/gd_functions.cpp index d3f7dcd35..e4add4e57 100644 --- a/modules/gdscript/gd_functions.cpp +++ b/modules/gdscript/gd_functions.cpp @@ -105,6 +105,7 @@ const char *GDFunctions::get_func_name(Function p_func) { "dict2inst", "hash", "Color8", + "ColorN", "print_stack", "instance_from_id", }; @@ -1061,6 +1062,36 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va r_ret=color; } break; + case COLORN: { + + if (p_arg_count<1) { + r_error.error=Variant::CallError::CALL_ERROR_TOO_FEW_ARGUMENTS; + r_error.argument=1; + r_ret=Variant(); + return; + } + + if (p_arg_count>2) { + r_error.error=Variant::CallError::CALL_ERROR_TOO_MANY_ARGUMENTS; + r_error.argument=2; + r_ret=Variant(); + return; + } + + if (p_args[0]->get_type()!=Variant::STRING) { + r_error.error=Variant::CallError::CALL_ERROR_INVALID_ARGUMENT; + r_error.argument=0; + r_ret=Variant(); + } else { + Color color = Color::named(*p_args[0]); + if (p_arg_count==2) { + VALIDATE_ARG_NUM(1); + color.a=*p_args[1]; + } + r_ret=color; + } + + } break; case PRINT_STACK: { @@ -1522,6 +1553,12 @@ MethodInfo GDFunctions::get_info(Function p_func) { mi.return_val.type=Variant::COLOR; return mi; } break; + case COLORN: { + + MethodInfo mi("ColorN",PropertyInfo(Variant::STRING,"name"),PropertyInfo(Variant::REAL,"alpha")); + mi.return_val.type=Variant::COLOR; + return mi; + } break; case PRINT_STACK: { MethodInfo mi("print_stack"); |
