diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2017-01-11 10:36:15 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-11 10:36:15 +0100 |
commit | 57166cd2923cc6d32b37c34f6ca2f32f6941e4a8 (patch) | |
tree | 6ac41f0f717267a0164a869be76e941a3caeb9e9 /modules/gdscript/gd_functions.cpp | |
parent | bc26f905817945300d397696330d1ab04a1af33c (diff) | |
parent | 23381a530bb4a9c8e8c3e883a7d588bf832cd277 (diff) | |
download | redot-engine-57166cd2923cc6d32b37c34f6ca2f32f6941e4a8.tar.gz |
Merge pull request #7093 from bojidar-bg/named-colors
Add named colors to GDScript/Visual Script/core.
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 bf73b14066..35ceeeb1aa 100644 --- a/modules/gdscript/gd_functions.cpp +++ b/modules/gdscript/gd_functions.cpp @@ -109,6 +109,7 @@ const char *GDFunctions::get_func_name(Function p_func) { "to_json", "hash", "Color8", + "ColorN", "print_stack", "instance_from_id", }; @@ -1117,6 +1118,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: { @@ -1596,6 +1627,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"); |