2014-02-10 09:10:30 +08:00
/*************************************************************************/
/* variant_call.cpp */
/*************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
2017-08-27 20:16:55 +08:00
/* https://godotengine.org */
2014-02-10 09:10:30 +08:00
/*************************************************************************/
2020-01-01 18:16:22 +08:00
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
2014-02-10 09:10:30 +08:00
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
/* "Software"), to deal in the Software without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of the Software, and to */
/* permit persons to whom the Software is furnished to do so, subject to */
/* the following conditions: */
/* */
/* The above copyright notice and this permission notice shall be */
/* included in all copies or substantial portions of the Software. */
/* */
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/*************************************************************************/
2018-01-05 07:50:27 +08:00
2014-02-10 09:10:30 +08:00
# include "variant.h"
2017-01-16 15:04:19 +08:00
2017-12-15 23:43:27 +08:00
# include "core/color_names.inc"
2018-09-12 00:13:45 +08:00
# include "core/core_string_names.h"
2019-07-11 21:21:47 +08:00
# include "core/crypto/crypto_core.h"
2018-09-12 00:13:45 +08:00
# include "core/io/compression.h"
# include "core/object.h"
# include "core/os/os.h"
# include "core/script_language.h"
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
typedef void ( * VariantFunc ) ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) ;
typedef void ( * VariantConstructFunc ) ( Variant & r_ret , const Variant * * p_args ) ;
2014-02-10 09:10:30 +08:00
struct _VariantCall {
2017-03-05 23:44:50 +08:00
static void Vector3_dot ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = reinterpret_cast < Vector3 * > ( p_self . _data . _mem ) - > dot ( * reinterpret_cast < const Vector3 * > ( p_args [ 0 ] - > _data . _mem ) ) ;
2014-02-10 09:10:30 +08:00
}
struct FuncData {
int arg_count ;
Vector < Variant > default_args ;
Vector < Variant : : Type > arg_types ;
Vector < StringName > arg_names ;
Variant : : Type return_type ;
2016-09-01 00:19:31 +08:00
2017-09-26 04:08:48 +08:00
bool _const ;
2014-02-10 09:10:30 +08:00
bool returns ;
2017-10-23 01:08:16 +08:00
2014-02-10 09:10:30 +08:00
VariantFunc func ;
2020-02-20 03:27:19 +08:00
_FORCE_INLINE_ bool verify_arguments ( const Variant * * p_args , Callable : : CallError & r_error ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
if ( arg_count = = 0 )
2014-02-10 09:10:30 +08:00
return true ;
2018-07-25 09:11:03 +08:00
const Variant : : Type * tptr = & arg_types [ 0 ] ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
for ( int i = 0 ; i < arg_count ; i + + ) {
2014-02-10 09:10:30 +08:00
2019-07-20 14:09:57 +08:00
if ( tptr [ i ] = = Variant : : NIL | | tptr [ i ] = = p_args [ i ] - > type )
2014-02-10 09:10:30 +08:00
continue ; // all good
2017-03-05 23:44:50 +08:00
if ( ! Variant : : can_convert ( p_args [ i ] - > type , tptr [ i ] ) ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INVALID_ARGUMENT ;
2017-03-05 23:44:50 +08:00
r_error . argument = i ;
r_error . expected = tptr [ i ] ;
2014-02-10 09:10:30 +08:00
return false ;
}
}
return true ;
}
2020-02-20 03:27:19 +08:00
_FORCE_INLINE_ void call ( Variant & r_ret , Variant & p_self , const Variant * * p_args , int p_argcount , Callable : : CallError & r_error ) {
2014-02-10 09:10:30 +08:00
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
if ( p_argcount > arg_count ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_TOO_MANY_ARGUMENTS ;
2017-03-05 23:44:50 +08:00
r_error . argument = arg_count ;
2014-02-10 09:10:30 +08:00
return ;
} else
# endif
2017-03-05 23:44:50 +08:00
if ( p_argcount < arg_count ) {
2014-02-10 09:10:30 +08:00
int def_argcount = default_args . size ( ) ;
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
if ( p_argcount < ( arg_count - def_argcount ) ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_TOO_FEW_ARGUMENTS ;
2017-03-05 23:44:50 +08:00
r_error . argument = arg_count - def_argcount ;
2014-02-10 09:10:30 +08:00
return ;
}
# endif
2017-03-05 23:44:50 +08:00
ERR_FAIL_COND ( p_argcount > VARIANT_ARG_MAX ) ;
2014-02-10 09:10:30 +08:00
const Variant * newargs [ VARIANT_ARG_MAX ] ;
2017-03-05 23:44:50 +08:00
for ( int i = 0 ; i < p_argcount ; i + + )
newargs [ i ] = p_args [ i ] ;
2017-12-31 22:50:37 +08:00
// fill in any remaining parameters with defaults
int first_default_arg = arg_count - def_argcount ;
2017-03-05 23:44:50 +08:00
for ( int i = p_argcount ; i < arg_count ; i + + )
2017-12-31 22:50:37 +08:00
newargs [ i ] = & default_args [ i - first_default_arg ] ;
2014-02-10 09:10:30 +08:00
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
if ( ! verify_arguments ( newargs , r_error ) )
2014-02-10 09:10:30 +08:00
return ;
# endif
2017-03-05 23:44:50 +08:00
func ( r_ret , p_self , newargs ) ;
2014-02-10 09:10:30 +08:00
} else {
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
if ( ! verify_arguments ( p_args , r_error ) )
2014-02-10 09:10:30 +08:00
return ;
# endif
2017-03-05 23:44:50 +08:00
func ( r_ret , p_self , p_args ) ;
2014-02-10 09:10:30 +08:00
}
}
} ;
struct TypeFunc {
2017-03-05 23:44:50 +08:00
Map < StringName , FuncData > functions ;
2014-02-10 09:10:30 +08:00
} ;
2017-03-05 23:44:50 +08:00
static TypeFunc * type_funcs ;
2014-02-10 09:10:30 +08:00
struct Arg {
StringName name ;
Variant : : Type type ;
2017-03-05 23:44:50 +08:00
Arg ( ) { type = Variant : : NIL ; }
2017-12-07 04:36:34 +08:00
Arg ( Variant : : Type p_type , const StringName & p_name ) :
name ( p_name ) ,
type ( p_type ) {
2017-03-05 23:44:50 +08:00
}
2014-02-10 09:10:30 +08:00
} ;
2017-01-14 19:26:56 +08:00
//void addfunc(Variant::Type p_type, const StringName& p_name,VariantFunc p_func);
2017-01-09 09:40:00 +08:00
2017-03-05 23:44:50 +08:00
static void make_func_return_variant ( Variant : : Type p_type , const StringName & p_name ) {
2017-01-09 09:40:00 +08:00
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
type_funcs [ p_type ] . functions [ p_name ] . returns = true ;
2017-01-09 09:40:00 +08:00
# endif
}
2017-10-23 01:08:16 +08:00
static void addfunc ( bool p_const , Variant : : Type p_type , Variant : : Type p_return , bool p_has_return , const StringName & p_name , VariantFunc p_func , const Vector < Variant > & p_defaultarg , const Arg & p_argtype1 = Arg ( ) , const Arg & p_argtype2 = Arg ( ) , const Arg & p_argtype3 = Arg ( ) , const Arg & p_argtype4 = Arg ( ) , const Arg & p_argtype5 = Arg ( ) ) {
2014-02-10 09:10:30 +08:00
FuncData funcdata ;
2017-03-05 23:44:50 +08:00
funcdata . func = p_func ;
funcdata . default_args = p_defaultarg ;
2017-09-26 04:08:48 +08:00
funcdata . _const = p_const ;
2018-02-13 01:06:54 +08:00
funcdata . returns = p_has_return ;
2017-03-05 23:44:50 +08:00
funcdata . return_type = p_return ;
2014-02-10 09:10:30 +08:00
if ( p_argtype1 . name ) {
funcdata . arg_types . push_back ( p_argtype1 . type ) ;
# ifdef DEBUG_ENABLED
funcdata . arg_names . push_back ( p_argtype1 . name ) ;
# endif
} else
goto end ;
if ( p_argtype2 . name ) {
funcdata . arg_types . push_back ( p_argtype2 . type ) ;
# ifdef DEBUG_ENABLED
funcdata . arg_names . push_back ( p_argtype2 . name ) ;
# endif
} else
goto end ;
if ( p_argtype3 . name ) {
funcdata . arg_types . push_back ( p_argtype3 . type ) ;
# ifdef DEBUG_ENABLED
funcdata . arg_names . push_back ( p_argtype3 . name ) ;
# endif
} else
goto end ;
if ( p_argtype4 . name ) {
funcdata . arg_types . push_back ( p_argtype4 . type ) ;
# ifdef DEBUG_ENABLED
funcdata . arg_names . push_back ( p_argtype4 . name ) ;
# endif
} else
goto end ;
if ( p_argtype5 . name ) {
funcdata . arg_types . push_back ( p_argtype5 . type ) ;
# ifdef DEBUG_ENABLED
funcdata . arg_names . push_back ( p_argtype5 . name ) ;
# endif
} else
goto end ;
2017-03-05 23:44:50 +08:00
end :
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
funcdata . arg_count = funcdata . arg_types . size ( ) ;
type_funcs [ p_type ] . functions [ p_name ] = funcdata ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
# define VCALL_LOCALMEM0(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( ) ; }
# define VCALL_LOCALMEM0R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( ) ; }
# define VCALL_LOCALMEM1(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] ) ; }
# define VCALL_LOCALMEM1R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] ) ; }
# define VCALL_LOCALMEM2(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] ) ; }
# define VCALL_LOCALMEM2R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] ) ; }
# define VCALL_LOCALMEM3(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ; }
# define VCALL_LOCALMEM3R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ; }
# define VCALL_LOCALMEM4(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ; }
# define VCALL_LOCALMEM4R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ; }
# define VCALL_LOCALMEM5(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] , * p_args [ 4 ] ) ; }
# define VCALL_LOCALMEM5R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _mem ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] , * p_args [ 4 ] ) ; }
2014-02-10 09:10:30 +08:00
// built-in functions of localmem based types
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( String , casecmp_to ) ;
VCALL_LOCALMEM1R ( String , nocasecmp_to ) ;
VCALL_LOCALMEM0R ( String , length ) ;
2019-01-18 16:29:28 +08:00
VCALL_LOCALMEM3R ( String , count ) ;
VCALL_LOCALMEM3R ( String , countn ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2R ( String , substr ) ;
VCALL_LOCALMEM2R ( String , find ) ;
VCALL_LOCALMEM1R ( String , find_last ) ;
VCALL_LOCALMEM2R ( String , findn ) ;
VCALL_LOCALMEM2R ( String , rfind ) ;
VCALL_LOCALMEM2R ( String , rfindn ) ;
VCALL_LOCALMEM1R ( String , match ) ;
VCALL_LOCALMEM1R ( String , matchn ) ;
VCALL_LOCALMEM1R ( String , begins_with ) ;
VCALL_LOCALMEM1R ( String , ends_with ) ;
VCALL_LOCALMEM1R ( String , is_subsequence_of ) ;
VCALL_LOCALMEM1R ( String , is_subsequence_ofi ) ;
VCALL_LOCALMEM0R ( String , bigrams ) ;
VCALL_LOCALMEM1R ( String , similarity ) ;
VCALL_LOCALMEM2R ( String , format ) ;
VCALL_LOCALMEM2R ( String , replace ) ;
VCALL_LOCALMEM2R ( String , replacen ) ;
2019-09-02 11:49:55 +08:00
VCALL_LOCALMEM1R ( String , repeat ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2R ( String , insert ) ;
VCALL_LOCALMEM0R ( String , capitalize ) ;
2017-12-12 10:14:38 +08:00
VCALL_LOCALMEM3R ( String , split ) ;
2017-12-16 03:23:58 +08:00
VCALL_LOCALMEM3R ( String , rsplit ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2R ( String , split_floats ) ;
VCALL_LOCALMEM0R ( String , to_upper ) ;
VCALL_LOCALMEM0R ( String , to_lower ) ;
VCALL_LOCALMEM1R ( String , left ) ;
VCALL_LOCALMEM1R ( String , right ) ;
2017-10-11 16:27:54 +08:00
VCALL_LOCALMEM0R ( String , dedent ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2R ( String , strip_edges ) ;
2019-05-31 21:27:53 +08:00
VCALL_LOCALMEM0R ( String , strip_escapes ) ;
2018-04-13 22:40:27 +08:00
VCALL_LOCALMEM1R ( String , lstrip ) ;
VCALL_LOCALMEM1R ( String , rstrip ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , get_extension ) ;
VCALL_LOCALMEM0R ( String , get_basename ) ;
VCALL_LOCALMEM1R ( String , plus_file ) ;
VCALL_LOCALMEM1R ( String , ord_at ) ;
VCALL_LOCALMEM2 ( String , erase ) ;
VCALL_LOCALMEM0R ( String , hash ) ;
VCALL_LOCALMEM0R ( String , md5_text ) ;
2019-07-02 22:07:02 +08:00
VCALL_LOCALMEM0R ( String , sha1_text ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , sha256_text ) ;
VCALL_LOCALMEM0R ( String , md5_buffer ) ;
2019-07-02 22:07:02 +08:00
VCALL_LOCALMEM0R ( String , sha1_buffer ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , sha256_buffer ) ;
VCALL_LOCALMEM0R ( String , empty ) ;
2019-10-04 19:35:01 +08:00
VCALL_LOCALMEM1R ( String , humanize_size ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , is_abs_path ) ;
VCALL_LOCALMEM0R ( String , is_rel_path ) ;
VCALL_LOCALMEM0R ( String , get_base_dir ) ;
VCALL_LOCALMEM0R ( String , get_file ) ;
VCALL_LOCALMEM0R ( String , xml_escape ) ;
VCALL_LOCALMEM0R ( String , xml_unescape ) ;
2019-06-08 16:33:12 +08:00
VCALL_LOCALMEM0R ( String , http_escape ) ;
VCALL_LOCALMEM0R ( String , http_unescape ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , c_escape ) ;
VCALL_LOCALMEM0R ( String , c_unescape ) ;
VCALL_LOCALMEM0R ( String , json_escape ) ;
VCALL_LOCALMEM0R ( String , percent_encode ) ;
VCALL_LOCALMEM0R ( String , percent_decode ) ;
VCALL_LOCALMEM0R ( String , is_valid_identifier ) ;
VCALL_LOCALMEM0R ( String , is_valid_integer ) ;
VCALL_LOCALMEM0R ( String , is_valid_float ) ;
2018-12-25 02:54:36 +08:00
VCALL_LOCALMEM1R ( String , is_valid_hex_number ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , is_valid_html_color ) ;
VCALL_LOCALMEM0R ( String , is_valid_ip_address ) ;
2019-04-09 06:18:03 +08:00
VCALL_LOCALMEM0R ( String , is_valid_filename ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( String , to_int ) ;
VCALL_LOCALMEM0R ( String , to_float ) ;
VCALL_LOCALMEM0R ( String , hex_to_int ) ;
VCALL_LOCALMEM1R ( String , pad_decimals ) ;
VCALL_LOCALMEM1R ( String , pad_zeros ) ;
2018-04-13 22:40:27 +08:00
VCALL_LOCALMEM1R ( String , trim_prefix ) ;
VCALL_LOCALMEM1R ( String , trim_suffix ) ;
2017-03-05 23:44:50 +08:00
static void _call_String_to_ascii ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
String * s = reinterpret_cast < String * > ( p_self . _data . _mem ) ;
2019-10-11 15:13:30 +08:00
if ( s - > empty ( ) ) {
2020-02-18 05:06:54 +08:00
r_ret = PackedByteArray ( ) ;
2019-10-11 15:13:30 +08:00
return ;
}
2015-06-04 07:46:14 +08:00
CharString charstr = s - > ascii ( ) ;
2020-02-18 05:06:54 +08:00
PackedByteArray retval ;
2015-06-04 07:46:14 +08:00
size_t len = charstr . length ( ) ;
retval . resize ( len ) ;
2020-02-18 05:06:54 +08:00
uint8_t * w = retval . ptrw ( ) ;
copymem ( w , charstr . ptr ( ) , len ) ;
2015-06-04 07:46:14 +08:00
r_ret = retval ;
}
2017-03-05 23:44:50 +08:00
static void _call_String_to_utf8 ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2015-06-04 07:46:14 +08:00
2017-03-05 23:44:50 +08:00
String * s = reinterpret_cast < String * > ( p_self . _data . _mem ) ;
2019-10-11 15:13:30 +08:00
if ( s - > empty ( ) ) {
2020-02-18 05:06:54 +08:00
r_ret = PackedByteArray ( ) ;
2019-10-11 15:13:30 +08:00
return ;
}
2015-06-04 07:46:14 +08:00
CharString charstr = s - > utf8 ( ) ;
2020-02-18 05:06:54 +08:00
PackedByteArray retval ;
2015-06-04 07:46:14 +08:00
size_t len = charstr . length ( ) ;
retval . resize ( len ) ;
2020-02-18 05:06:54 +08:00
uint8_t * w = retval . ptrw ( ) ;
copymem ( w , charstr . ptr ( ) , len ) ;
2015-06-04 07:46:14 +08:00
r_ret = retval ;
}
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Vector2 , distance_to ) ;
VCALL_LOCALMEM1R ( Vector2 , distance_squared_to ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Vector2 , length ) ;
VCALL_LOCALMEM0R ( Vector2 , length_squared ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM0R ( Vector2 , normalized ) ;
2017-04-06 06:47:13 +08:00
VCALL_LOCALMEM0R ( Vector2 , is_normalized ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Vector2 , is_equal_approx ) ;
2019-08-05 09:50:28 +08:00
VCALL_LOCALMEM1R ( Vector2 , posmod ) ;
VCALL_LOCALMEM1R ( Vector2 , posmodv ) ;
2018-08-16 18:52:38 +08:00
VCALL_LOCALMEM1R ( Vector2 , project ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Vector2 , angle_to ) ;
VCALL_LOCALMEM1R ( Vector2 , angle_to_point ) ;
2019-03-27 18:51:05 +08:00
VCALL_LOCALMEM1R ( Vector2 , direction_to ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2R ( Vector2 , linear_interpolate ) ;
2018-05-12 08:14:39 +08:00
VCALL_LOCALMEM2R ( Vector2 , slerp ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM4R ( Vector2 , cubic_interpolate ) ;
2019-04-08 05:40:56 +08:00
VCALL_LOCALMEM2R ( Vector2 , move_toward ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Vector2 , rotated ) ;
VCALL_LOCALMEM0R ( Vector2 , tangent ) ;
VCALL_LOCALMEM0R ( Vector2 , floor ) ;
2018-05-04 15:24:48 +08:00
VCALL_LOCALMEM0R ( Vector2 , ceil ) ;
VCALL_LOCALMEM0R ( Vector2 , round ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Vector2 , snapped ) ;
VCALL_LOCALMEM0R ( Vector2 , aspect ) ;
VCALL_LOCALMEM1R ( Vector2 , dot ) ;
VCALL_LOCALMEM1R ( Vector2 , slide ) ;
2017-03-31 23:25:09 +08:00
VCALL_LOCALMEM1R ( Vector2 , bounce ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Vector2 , reflect ) ;
VCALL_LOCALMEM0R ( Vector2 , angle ) ;
2018-02-08 15:48:14 +08:00
VCALL_LOCALMEM1R ( Vector2 , cross ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Vector2 , abs ) ;
VCALL_LOCALMEM1R ( Vector2 , clamped ) ;
2019-08-05 09:50:28 +08:00
VCALL_LOCALMEM0R ( Vector2 , sign ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Rect2 , get_area ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM0R ( Rect2 , has_no_area ) ;
VCALL_LOCALMEM1R ( Rect2 , has_point ) ;
VCALL_LOCALMEM1R ( Rect2 , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Rect2 , intersects ) ;
VCALL_LOCALMEM1R ( Rect2 , encloses ) ;
VCALL_LOCALMEM1R ( Rect2 , clip ) ;
VCALL_LOCALMEM1R ( Rect2 , merge ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Rect2 , expand ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Rect2 , grow ) ;
2017-05-29 19:36:14 +08:00
VCALL_LOCALMEM2R ( Rect2 , grow_margin ) ;
VCALL_LOCALMEM4R ( Rect2 , grow_individual ) ;
2017-11-28 01:41:29 +08:00
VCALL_LOCALMEM0R ( Rect2 , abs ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM0R ( Vector3 , min_axis ) ;
VCALL_LOCALMEM0R ( Vector3 , max_axis ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Vector3 , distance_to ) ;
VCALL_LOCALMEM1R ( Vector3 , distance_squared_to ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM0R ( Vector3 , length ) ;
VCALL_LOCALMEM0R ( Vector3 , length_squared ) ;
VCALL_LOCALMEM0R ( Vector3 , normalized ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM0R ( Vector3 , is_normalized ) ;
VCALL_LOCALMEM1R ( Vector3 , is_equal_approx ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM0R ( Vector3 , inverse ) ;
VCALL_LOCALMEM1R ( Vector3 , snapped ) ;
VCALL_LOCALMEM2R ( Vector3 , rotated ) ;
VCALL_LOCALMEM2R ( Vector3 , linear_interpolate ) ;
2018-05-12 08:14:39 +08:00
VCALL_LOCALMEM2R ( Vector3 , slerp ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM4R ( Vector3 , cubic_interpolate ) ;
2019-04-08 05:40:56 +08:00
VCALL_LOCALMEM2R ( Vector3 , move_toward ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM1R ( Vector3 , dot ) ;
VCALL_LOCALMEM1R ( Vector3 , cross ) ;
2016-12-31 22:39:25 +08:00
VCALL_LOCALMEM1R ( Vector3 , outer ) ;
VCALL_LOCALMEM0R ( Vector3 , to_diagonal_matrix ) ;
2014-02-10 09:10:30 +08:00
VCALL_LOCALMEM0R ( Vector3 , abs ) ;
2015-07-15 07:59:35 +08:00
VCALL_LOCALMEM0R ( Vector3 , floor ) ;
VCALL_LOCALMEM0R ( Vector3 , ceil ) ;
2018-05-04 15:24:48 +08:00
VCALL_LOCALMEM0R ( Vector3 , round ) ;
2019-08-05 09:50:28 +08:00
VCALL_LOCALMEM1R ( Vector3 , posmod ) ;
VCALL_LOCALMEM1R ( Vector3 , posmodv ) ;
2018-08-16 18:52:38 +08:00
VCALL_LOCALMEM1R ( Vector3 , project ) ;
2016-10-02 03:20:09 +08:00
VCALL_LOCALMEM1R ( Vector3 , angle_to ) ;
2019-03-27 18:51:05 +08:00
VCALL_LOCALMEM1R ( Vector3 , direction_to ) ;
2014-09-03 10:13:40 +08:00
VCALL_LOCALMEM1R ( Vector3 , slide ) ;
2017-03-31 23:25:09 +08:00
VCALL_LOCALMEM1R ( Vector3 , bounce ) ;
2014-09-03 10:13:40 +08:00
VCALL_LOCALMEM1R ( Vector3 , reflect ) ;
2019-08-05 09:50:28 +08:00
VCALL_LOCALMEM0R ( Vector3 , sign ) ;
2014-09-03 10:13:40 +08:00
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Plane , normalized ) ;
VCALL_LOCALMEM0R ( Plane , center ) ;
VCALL_LOCALMEM0R ( Plane , get_any_point ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Plane , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Plane , is_point_over ) ;
VCALL_LOCALMEM1R ( Plane , distance_to ) ;
VCALL_LOCALMEM2R ( Plane , has_point ) ;
VCALL_LOCALMEM1R ( Plane , project ) ;
2014-02-10 09:10:30 +08:00
//return vector3 if intersected, nil if not
2017-03-05 23:44:50 +08:00
static void _call_Plane_intersect_3 ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
Vector3 result ;
2017-03-05 23:44:50 +08:00
if ( reinterpret_cast < Plane * > ( p_self . _data . _mem ) - > intersect_3 ( * p_args [ 0 ] , * p_args [ 1 ] , & result ) )
r_ret = result ;
2014-02-10 09:10:30 +08:00
else
2017-03-05 23:44:50 +08:00
r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void _call_Plane_intersects_ray ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
Vector3 result ;
2017-03-05 23:44:50 +08:00
if ( reinterpret_cast < Plane * > ( p_self . _data . _mem ) - > intersects_ray ( * p_args [ 0 ] , * p_args [ 1 ] , & result ) )
r_ret = result ;
2014-02-10 09:10:30 +08:00
else
2017-03-05 23:44:50 +08:00
r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void _call_Plane_intersects_segment ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
Vector3 result ;
2017-03-05 23:44:50 +08:00
if ( reinterpret_cast < Plane * > ( p_self . _data . _mem ) - > intersects_segment ( * p_args [ 0 ] , * p_args [ 1 ] , & result ) )
r_ret = result ;
2014-02-10 09:10:30 +08:00
else
2017-03-05 23:44:50 +08:00
r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Quat , length ) ;
VCALL_LOCALMEM0R ( Quat , length_squared ) ;
VCALL_LOCALMEM0R ( Quat , normalized ) ;
2017-04-06 06:47:13 +08:00
VCALL_LOCALMEM0R ( Quat , is_normalized ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Quat , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Quat , inverse ) ;
VCALL_LOCALMEM1R ( Quat , dot ) ;
VCALL_LOCALMEM1R ( Quat , xform ) ;
VCALL_LOCALMEM2R ( Quat , slerp ) ;
VCALL_LOCALMEM2R ( Quat , slerpni ) ;
VCALL_LOCALMEM4R ( Quat , cubic_slerp ) ;
2018-05-12 08:14:39 +08:00
VCALL_LOCALMEM0R ( Quat , get_euler ) ;
VCALL_LOCALMEM1 ( Quat , set_euler ) ;
VCALL_LOCALMEM2 ( Quat , set_axis_angle ) ;
2017-03-05 23:44:50 +08:00
2017-09-08 04:19:44 +08:00
VCALL_LOCALMEM0R ( Color , to_argb32 ) ;
2018-07-26 04:33:42 +08:00
VCALL_LOCALMEM0R ( Color , to_abgr32 ) ;
VCALL_LOCALMEM0R ( Color , to_rgba32 ) ;
VCALL_LOCALMEM0R ( Color , to_argb64 ) ;
VCALL_LOCALMEM0R ( Color , to_abgr64 ) ;
VCALL_LOCALMEM0R ( Color , to_rgba64 ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Color , inverted ) ;
VCALL_LOCALMEM0R ( Color , contrasted ) ;
VCALL_LOCALMEM2R ( Color , linear_interpolate ) ;
VCALL_LOCALMEM1R ( Color , blend ) ;
2017-10-13 12:49:31 +08:00
VCALL_LOCALMEM1R ( Color , lightened ) ;
VCALL_LOCALMEM1R ( Color , darkened ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM1R ( Color , to_html ) ;
2018-01-19 05:03:34 +08:00
VCALL_LOCALMEM4R ( Color , from_hsv ) ;
2019-10-03 04:35:49 +08:00
VCALL_LOCALMEM1R ( Color , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( RID , get_id ) ;
VCALL_LOCALMEM0R ( NodePath , is_absolute ) ;
VCALL_LOCALMEM0R ( NodePath , get_name_count ) ;
VCALL_LOCALMEM1R ( NodePath , get_name ) ;
VCALL_LOCALMEM0R ( NodePath , get_subname_count ) ;
VCALL_LOCALMEM1R ( NodePath , get_subname ) ;
2017-05-31 04:20:15 +08:00
VCALL_LOCALMEM0R ( NodePath , get_concatenated_subnames ) ;
2017-11-22 20:13:56 +08:00
VCALL_LOCALMEM0R ( NodePath , get_as_property_path ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( NodePath , is_empty ) ;
VCALL_LOCALMEM0R ( Dictionary , size ) ;
VCALL_LOCALMEM0R ( Dictionary , empty ) ;
VCALL_LOCALMEM0 ( Dictionary , clear ) ;
VCALL_LOCALMEM1R ( Dictionary , has ) ;
VCALL_LOCALMEM1R ( Dictionary , has_all ) ;
2019-02-21 18:52:29 +08:00
VCALL_LOCALMEM1R ( Dictionary , erase ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0R ( Dictionary , hash ) ;
VCALL_LOCALMEM0R ( Dictionary , keys ) ;
VCALL_LOCALMEM0R ( Dictionary , values ) ;
2018-03-10 03:16:08 +08:00
VCALL_LOCALMEM1R ( Dictionary , duplicate ) ;
2018-07-30 12:04:32 +08:00
VCALL_LOCALMEM2R ( Dictionary , get ) ;
2017-03-05 23:44:50 +08:00
2020-02-20 03:27:19 +08:00
VCALL_LOCALMEM0R ( Callable , is_null ) ;
VCALL_LOCALMEM0R ( Callable , is_custom ) ;
VCALL_LOCALMEM0 ( Callable , is_standard ) ;
VCALL_LOCALMEM0 ( Callable , get_object ) ;
VCALL_LOCALMEM0 ( Callable , get_object_id ) ;
VCALL_LOCALMEM0 ( Callable , get_method ) ;
VCALL_LOCALMEM0 ( Callable , hash ) ;
VCALL_LOCALMEM0R ( Signal , is_null ) ;
VCALL_LOCALMEM0R ( Signal , get_object ) ;
VCALL_LOCALMEM0R ( Signal , get_object_id ) ;
VCALL_LOCALMEM0R ( Signal , get_name ) ;
VCALL_LOCALMEM3R ( Signal , connect ) ;
VCALL_LOCALMEM1 ( Signal , disconnect ) ;
VCALL_LOCALMEM1R ( Signal , is_connected ) ;
VCALL_LOCALMEM0R ( Signal , get_connections ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM2 ( Array , set ) ;
VCALL_LOCALMEM1R ( Array , get ) ;
VCALL_LOCALMEM0R ( Array , size ) ;
VCALL_LOCALMEM0R ( Array , empty ) ;
VCALL_LOCALMEM0 ( Array , clear ) ;
VCALL_LOCALMEM0R ( Array , hash ) ;
VCALL_LOCALMEM1 ( Array , push_back ) ;
VCALL_LOCALMEM1 ( Array , push_front ) ;
VCALL_LOCALMEM0R ( Array , pop_back ) ;
VCALL_LOCALMEM0R ( Array , pop_front ) ;
VCALL_LOCALMEM1 ( Array , append ) ;
VCALL_LOCALMEM1 ( Array , resize ) ;
VCALL_LOCALMEM2 ( Array , insert ) ;
VCALL_LOCALMEM1 ( Array , remove ) ;
VCALL_LOCALMEM0R ( Array , front ) ;
VCALL_LOCALMEM0R ( Array , back ) ;
VCALL_LOCALMEM2R ( Array , find ) ;
VCALL_LOCALMEM2R ( Array , rfind ) ;
VCALL_LOCALMEM1R ( Array , find_last ) ;
VCALL_LOCALMEM1R ( Array , count ) ;
VCALL_LOCALMEM1R ( Array , has ) ;
VCALL_LOCALMEM1 ( Array , erase ) ;
VCALL_LOCALMEM0 ( Array , sort ) ;
VCALL_LOCALMEM2 ( Array , sort_custom ) ;
2018-01-11 02:36:53 +08:00
VCALL_LOCALMEM0 ( Array , shuffle ) ;
2017-11-03 02:04:38 +08:00
VCALL_LOCALMEM2R ( Array , bsearch ) ;
VCALL_LOCALMEM4R ( Array , bsearch_custom ) ;
2018-03-10 03:16:08 +08:00
VCALL_LOCALMEM1R ( Array , duplicate ) ;
2019-07-17 09:31:58 +08:00
VCALL_LOCALMEM4R ( Array , slice ) ;
2017-03-05 23:44:50 +08:00
VCALL_LOCALMEM0 ( Array , invert ) ;
2018-08-24 02:31:02 +08:00
VCALL_LOCALMEM0R ( Array , max ) ;
VCALL_LOCALMEM0R ( Array , min ) ;
2017-03-05 23:44:50 +08:00
2020-02-18 05:06:54 +08:00
static void _call_PackedByteArray_get_string_from_ascii ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2017-03-05 23:44:50 +08:00
2020-02-18 05:06:54 +08:00
PackedByteArray * ba = reinterpret_cast < PackedByteArray * > ( p_self . _data . _mem ) ;
2014-02-10 09:10:30 +08:00
String s ;
2019-10-11 17:39:40 +08:00
if ( ba - > size ( ) > 0 ) {
2020-02-18 05:06:54 +08:00
const uint8_t * r = ba - > ptr ( ) ;
2014-02-10 09:10:30 +08:00
CharString cs ;
2017-03-05 23:44:50 +08:00
cs . resize ( ba - > size ( ) + 1 ) ;
2020-02-18 05:06:54 +08:00
copymem ( cs . ptrw ( ) , r , ba - > size ( ) ) ;
2017-03-05 23:44:50 +08:00
cs [ ba - > size ( ) ] = 0 ;
2014-02-10 09:10:30 +08:00
s = cs . get_data ( ) ;
}
2017-03-05 23:44:50 +08:00
r_ret = s ;
2014-02-10 09:10:30 +08:00
}
2020-02-18 05:06:54 +08:00
static void _call_PackedByteArray_get_string_from_utf8 ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2020-02-18 05:06:54 +08:00
PackedByteArray * ba = reinterpret_cast < PackedByteArray * > ( p_self . _data . _mem ) ;
2014-02-10 09:10:30 +08:00
String s ;
2019-10-11 17:39:40 +08:00
if ( ba - > size ( ) > 0 ) {
2020-02-18 05:06:54 +08:00
const uint8_t * r = ba - > ptr ( ) ;
s . parse_utf8 ( ( const char * ) r , ba - > size ( ) ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
r_ret = s ;
2014-02-10 09:10:30 +08:00
}
2020-02-18 05:06:54 +08:00
static void _call_PackedByteArray_compress ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2017-06-19 13:46:29 +08:00
2020-02-18 05:06:54 +08:00
PackedByteArray * ba = reinterpret_cast < PackedByteArray * > ( p_self . _data . _mem ) ;
PackedByteArray compressed ;
2019-10-11 17:39:40 +08:00
if ( ba - > size ( ) > 0 ) {
Compression : : Mode mode = ( Compression : : Mode ) ( int ) ( * p_args [ 0 ] ) ;
2017-06-19 13:46:29 +08:00
2019-10-11 17:39:40 +08:00
compressed . resize ( Compression : : get_max_compressed_buffer_size ( ba - > size ( ) , mode ) ) ;
2020-02-18 05:06:54 +08:00
int result = Compression : : compress ( compressed . ptrw ( ) , ba - > ptr ( ) , ba - > size ( ) , mode ) ;
2017-06-19 13:46:29 +08:00
2019-10-11 17:39:40 +08:00
result = result > = 0 ? result : 0 ;
compressed . resize ( result ) ;
}
2017-06-19 13:46:29 +08:00
r_ret = compressed ;
}
2020-02-18 05:06:54 +08:00
static void _call_PackedByteArray_decompress ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2017-06-19 13:46:29 +08:00
2020-02-18 05:06:54 +08:00
PackedByteArray * ba = reinterpret_cast < PackedByteArray * > ( p_self . _data . _mem ) ;
PackedByteArray decompressed ;
2017-06-19 13:46:29 +08:00
Compression : : Mode mode = ( Compression : : Mode ) ( int ) ( * p_args [ 1 ] ) ;
int buffer_size = ( int ) ( * p_args [ 0 ] ) ;
2019-10-10 23:15:10 +08:00
if ( buffer_size < = 0 ) {
2017-06-19 13:46:29 +08:00
r_ret = decompressed ;
2019-10-10 23:15:10 +08:00
ERR_FAIL_MSG ( " Decompression buffer size must be greater than zero. " ) ;
2017-06-19 13:46:29 +08:00
}
decompressed . resize ( buffer_size ) ;
2020-02-18 05:06:54 +08:00
int result = Compression : : decompress ( decompressed . ptrw ( ) , buffer_size , ba - > ptr ( ) , ba - > size ( ) , mode ) ;
2017-06-19 13:46:29 +08:00
result = result > = 0 ? result : 0 ;
decompressed . resize ( result ) ;
r_ret = decompressed ;
}
2020-02-18 05:06:54 +08:00
static void _call_PackedByteArray_hex_encode ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
PackedByteArray * ba = reinterpret_cast < PackedByteArray * > ( p_self . _data . _mem ) ;
2019-10-11 17:39:40 +08:00
if ( ba - > size ( ) = = 0 ) {
r_ret = String ( ) ;
return ;
}
2020-02-18 05:06:54 +08:00
const uint8_t * r = ba - > ptr ( ) ;
2019-07-19 16:33:31 +08:00
String s = String : : hex_encode_buffer ( & r [ 0 ] , ba - > size ( ) ) ;
r_ret = s ;
}
2020-02-18 05:06:54 +08:00
VCALL_LOCALMEM0R ( PackedByteArray , size ) ;
VCALL_LOCALMEM0R ( PackedByteArray , empty ) ;
VCALL_LOCALMEM2 ( PackedByteArray , set ) ;
VCALL_LOCALMEM1R ( PackedByteArray , get ) ;
VCALL_LOCALMEM1 ( PackedByteArray , push_back ) ;
VCALL_LOCALMEM1 ( PackedByteArray , resize ) ;
VCALL_LOCALMEM2R ( PackedByteArray , insert ) ;
VCALL_LOCALMEM1 ( PackedByteArray , remove ) ;
VCALL_LOCALMEM1 ( PackedByteArray , append ) ;
VCALL_LOCALMEM1 ( PackedByteArray , append_array ) ;
VCALL_LOCALMEM0 ( PackedByteArray , invert ) ;
VCALL_LOCALMEM2R ( PackedByteArray , subarray ) ;
VCALL_LOCALMEM0R ( PackedIntArray , size ) ;
VCALL_LOCALMEM0R ( PackedIntArray , empty ) ;
VCALL_LOCALMEM2 ( PackedIntArray , set ) ;
VCALL_LOCALMEM1R ( PackedIntArray , get ) ;
VCALL_LOCALMEM1 ( PackedIntArray , push_back ) ;
VCALL_LOCALMEM1 ( PackedIntArray , resize ) ;
VCALL_LOCALMEM2R ( PackedIntArray , insert ) ;
VCALL_LOCALMEM1 ( PackedIntArray , remove ) ;
VCALL_LOCALMEM1 ( PackedIntArray , append ) ;
VCALL_LOCALMEM1 ( PackedIntArray , append_array ) ;
VCALL_LOCALMEM0 ( PackedIntArray , invert ) ;
VCALL_LOCALMEM0R ( PackedRealArray , size ) ;
VCALL_LOCALMEM0R ( PackedRealArray , empty ) ;
VCALL_LOCALMEM2 ( PackedRealArray , set ) ;
VCALL_LOCALMEM1R ( PackedRealArray , get ) ;
VCALL_LOCALMEM1 ( PackedRealArray , push_back ) ;
VCALL_LOCALMEM1 ( PackedRealArray , resize ) ;
VCALL_LOCALMEM2R ( PackedRealArray , insert ) ;
VCALL_LOCALMEM1 ( PackedRealArray , remove ) ;
VCALL_LOCALMEM1 ( PackedRealArray , append ) ;
VCALL_LOCALMEM1 ( PackedRealArray , append_array ) ;
VCALL_LOCALMEM0 ( PackedRealArray , invert ) ;
VCALL_LOCALMEM0R ( PackedStringArray , size ) ;
VCALL_LOCALMEM0R ( PackedStringArray , empty ) ;
VCALL_LOCALMEM2 ( PackedStringArray , set ) ;
VCALL_LOCALMEM1R ( PackedStringArray , get ) ;
VCALL_LOCALMEM1 ( PackedStringArray , push_back ) ;
VCALL_LOCALMEM1 ( PackedStringArray , resize ) ;
VCALL_LOCALMEM2R ( PackedStringArray , insert ) ;
VCALL_LOCALMEM1 ( PackedStringArray , remove ) ;
VCALL_LOCALMEM1 ( PackedStringArray , append ) ;
VCALL_LOCALMEM1 ( PackedStringArray , append_array ) ;
VCALL_LOCALMEM0 ( PackedStringArray , invert ) ;
VCALL_LOCALMEM0R ( PackedVector2Array , size ) ;
VCALL_LOCALMEM0R ( PackedVector2Array , empty ) ;
VCALL_LOCALMEM2 ( PackedVector2Array , set ) ;
VCALL_LOCALMEM1R ( PackedVector2Array , get ) ;
VCALL_LOCALMEM1 ( PackedVector2Array , push_back ) ;
VCALL_LOCALMEM1 ( PackedVector2Array , resize ) ;
VCALL_LOCALMEM2R ( PackedVector2Array , insert ) ;
VCALL_LOCALMEM1 ( PackedVector2Array , remove ) ;
VCALL_LOCALMEM1 ( PackedVector2Array , append ) ;
VCALL_LOCALMEM1 ( PackedVector2Array , append_array ) ;
VCALL_LOCALMEM0 ( PackedVector2Array , invert ) ;
VCALL_LOCALMEM0R ( PackedVector3Array , size ) ;
VCALL_LOCALMEM0R ( PackedVector3Array , empty ) ;
VCALL_LOCALMEM2 ( PackedVector3Array , set ) ;
VCALL_LOCALMEM1R ( PackedVector3Array , get ) ;
VCALL_LOCALMEM1 ( PackedVector3Array , push_back ) ;
VCALL_LOCALMEM1 ( PackedVector3Array , resize ) ;
VCALL_LOCALMEM2R ( PackedVector3Array , insert ) ;
VCALL_LOCALMEM1 ( PackedVector3Array , remove ) ;
VCALL_LOCALMEM1 ( PackedVector3Array , append ) ;
VCALL_LOCALMEM1 ( PackedVector3Array , append_array ) ;
VCALL_LOCALMEM0 ( PackedVector3Array , invert ) ;
VCALL_LOCALMEM0R ( PackedColorArray , size ) ;
VCALL_LOCALMEM0R ( PackedColorArray , empty ) ;
VCALL_LOCALMEM2 ( PackedColorArray , set ) ;
VCALL_LOCALMEM1R ( PackedColorArray , get ) ;
VCALL_LOCALMEM1 ( PackedColorArray , push_back ) ;
VCALL_LOCALMEM1 ( PackedColorArray , resize ) ;
VCALL_LOCALMEM2R ( PackedColorArray , insert ) ;
VCALL_LOCALMEM1 ( PackedColorArray , remove ) ;
VCALL_LOCALMEM1 ( PackedColorArray , append ) ;
VCALL_LOCALMEM1 ( PackedColorArray , append_array ) ;
VCALL_LOCALMEM0 ( PackedColorArray , invert ) ;
2017-03-05 23:44:50 +08:00
# define VCALL_PTR0(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( ) ; }
# define VCALL_PTR0R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( ) ; }
# define VCALL_PTR1(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] ) ; }
# define VCALL_PTR1R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] ) ; }
# define VCALL_PTR2(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] ) ; }
# define VCALL_PTR2R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] ) ; }
# define VCALL_PTR3(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ; }
# define VCALL_PTR3R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ; }
# define VCALL_PTR4(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ; }
# define VCALL_PTR4R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ; }
# define VCALL_PTR5(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] , * p_args [ 4 ] ) ; }
# define VCALL_PTR5R(m_type, m_method) \
static void _call_ # # m_type # # _ # # m_method ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) { r_ret = reinterpret_cast < m_type * > ( p_self . _data . _ptr ) - > m_method ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] , * p_args [ 4 ] ) ; }
2017-11-17 10:09:00 +08:00
VCALL_PTR0R ( AABB , get_area ) ;
VCALL_PTR0R ( AABB , has_no_area ) ;
VCALL_PTR0R ( AABB , has_no_surface ) ;
2019-10-03 04:35:49 +08:00
VCALL_PTR1R ( AABB , has_point ) ;
VCALL_PTR1R ( AABB , is_equal_approx ) ;
2017-11-17 10:09:00 +08:00
VCALL_PTR1R ( AABB , intersects ) ;
VCALL_PTR1R ( AABB , encloses ) ;
VCALL_PTR1R ( AABB , intersects_plane ) ;
VCALL_PTR2R ( AABB , intersects_segment ) ;
2019-10-03 04:35:49 +08:00
VCALL_PTR1R ( AABB , intersection ) ;
VCALL_PTR1R ( AABB , merge ) ;
VCALL_PTR1R ( AABB , expand ) ;
VCALL_PTR1R ( AABB , grow ) ;
2017-11-17 10:09:00 +08:00
VCALL_PTR1R ( AABB , get_support ) ;
VCALL_PTR0R ( AABB , get_longest_axis ) ;
VCALL_PTR0R ( AABB , get_longest_axis_index ) ;
VCALL_PTR0R ( AABB , get_longest_axis_size ) ;
VCALL_PTR0R ( AABB , get_shortest_axis ) ;
VCALL_PTR0R ( AABB , get_shortest_axis_index ) ;
VCALL_PTR0R ( AABB , get_shortest_axis_size ) ;
VCALL_PTR1R ( AABB , get_endpoint ) ;
2017-03-05 23:44:50 +08:00
VCALL_PTR0R ( Transform2D , inverse ) ;
VCALL_PTR0R ( Transform2D , affine_inverse ) ;
VCALL_PTR0R ( Transform2D , get_rotation ) ;
VCALL_PTR0R ( Transform2D , get_origin ) ;
VCALL_PTR0R ( Transform2D , get_scale ) ;
VCALL_PTR0R ( Transform2D , orthonormalized ) ;
VCALL_PTR1R ( Transform2D , rotated ) ;
VCALL_PTR1R ( Transform2D , scaled ) ;
VCALL_PTR1R ( Transform2D , translated ) ;
VCALL_PTR2R ( Transform2D , interpolate_with ) ;
2019-10-03 04:35:49 +08:00
VCALL_PTR1R ( Transform2D , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
static void _call_Transform2D_xform ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
switch ( p_args [ 0 ] - > type ) {
case Variant : : VECTOR2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator Vector2 ( ) ) ; return ;
case Variant : : RECT2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator Rect2 ( ) ) ; return ;
2020-02-18 05:06:54 +08:00
case Variant : : PACKED_VECTOR2_ARRAY : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator PackedVector2Array ( ) ) ; return ;
2017-03-05 23:44:50 +08:00
default : r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
}
2017-03-05 23:44:50 +08:00
static void _call_Transform2D_xform_inv ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
switch ( p_args [ 0 ] - > type ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
case Variant : : VECTOR2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator Vector2 ( ) ) ; return ;
case Variant : : RECT2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator Rect2 ( ) ) ; return ;
2020-02-18 05:06:54 +08:00
case Variant : : PACKED_VECTOR2_ARRAY : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator PackedVector2Array ( ) ) ; return ;
2017-03-05 23:44:50 +08:00
default : r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
}
2017-03-05 23:44:50 +08:00
static void _call_Transform2D_basis_xform ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-10-03 11:10:51 +08:00
2017-03-05 23:44:50 +08:00
switch ( p_args [ 0 ] - > type ) {
2014-10-03 11:10:51 +08:00
2017-03-05 23:44:50 +08:00
case Variant : : VECTOR2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > basis_xform ( p_args [ 0 ] - > operator Vector2 ( ) ) ; return ;
default : r_ret = Variant ( ) ;
2014-10-03 11:10:51 +08:00
}
}
2017-03-05 23:44:50 +08:00
static void _call_Transform2D_basis_xform_inv ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-10-03 11:10:51 +08:00
2017-03-05 23:44:50 +08:00
switch ( p_args [ 0 ] - > type ) {
2014-10-03 11:10:51 +08:00
2017-03-05 23:44:50 +08:00
case Variant : : VECTOR2 : r_ret = reinterpret_cast < Transform2D * > ( p_self . _data . _ptr ) - > basis_xform_inv ( p_args [ 0 ] - > operator Vector2 ( ) ) ; return ;
default : r_ret = Variant ( ) ;
2014-10-03 11:10:51 +08:00
}
}
2017-03-05 23:44:50 +08:00
VCALL_PTR0R ( Basis , inverse ) ;
VCALL_PTR0R ( Basis , transposed ) ;
VCALL_PTR0R ( Basis , determinant ) ;
VCALL_PTR2R ( Basis , rotated ) ;
VCALL_PTR1R ( Basis , scaled ) ;
VCALL_PTR0R ( Basis , get_scale ) ;
VCALL_PTR0R ( Basis , get_euler ) ;
VCALL_PTR1R ( Basis , tdotx ) ;
VCALL_PTR1R ( Basis , tdoty ) ;
VCALL_PTR1R ( Basis , tdotz ) ;
VCALL_PTR1R ( Basis , xform ) ;
VCALL_PTR1R ( Basis , xform_inv ) ;
VCALL_PTR0R ( Basis , get_orthogonal_index ) ;
VCALL_PTR0R ( Basis , orthonormalized ) ;
2018-05-28 20:53:15 +08:00
VCALL_PTR2R ( Basis , slerp ) ;
2019-10-15 04:33:45 +08:00
VCALL_PTR2R ( Basis , is_equal_approx ) ; // TODO: Break compatibility in 4.0 to change this to an instance method (a.is_equal_approx(b) as VCALL_PTR1R) for consistency.
2019-04-01 22:11:02 +08:00
VCALL_PTR0R ( Basis , get_rotation_quat ) ;
2017-03-05 23:44:50 +08:00
VCALL_PTR0R ( Transform , inverse ) ;
VCALL_PTR0R ( Transform , affine_inverse ) ;
VCALL_PTR2R ( Transform , rotated ) ;
VCALL_PTR1R ( Transform , scaled ) ;
VCALL_PTR1R ( Transform , translated ) ;
VCALL_PTR0R ( Transform , orthonormalized ) ;
VCALL_PTR2R ( Transform , looking_at ) ;
2017-08-20 06:09:45 +08:00
VCALL_PTR2R ( Transform , interpolate_with ) ;
2019-10-03 04:35:49 +08:00
VCALL_PTR1R ( Transform , is_equal_approx ) ;
2017-03-05 23:44:50 +08:00
static void _call_Transform_xform ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
switch ( p_args [ 0 ] - > type ) {
case Variant : : VECTOR3 : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator Vector3 ( ) ) ; return ;
case Variant : : PLANE : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator Plane ( ) ) ; return ;
2017-11-17 10:09:00 +08:00
case Variant : : AABB : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator : : AABB ( ) ) ; return ;
2020-02-18 05:06:54 +08:00
case Variant : : PACKED_VECTOR3_ARRAY : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform ( p_args [ 0 ] - > operator : : PackedVector3Array ( ) ) ; return ;
2017-03-05 23:44:50 +08:00
default : r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
}
2017-03-05 23:44:50 +08:00
static void _call_Transform_xform_inv ( Variant & r_ret , Variant & p_self , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
switch ( p_args [ 0 ] - > type ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
case Variant : : VECTOR3 : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator Vector3 ( ) ) ; return ;
case Variant : : PLANE : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator Plane ( ) ) ; return ;
2017-11-17 10:09:00 +08:00
case Variant : : AABB : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator : : AABB ( ) ) ; return ;
2020-02-18 05:06:54 +08:00
case Variant : : PACKED_VECTOR3_ARRAY : r_ret = reinterpret_cast < Transform * > ( p_self . _data . _ptr ) - > xform_inv ( p_args [ 0 ] - > operator : : PackedVector3Array ( ) ) ; return ;
2017-03-05 23:44:50 +08:00
default : r_ret = Variant ( ) ;
2014-02-10 09:10:30 +08:00
}
}
2017-03-05 23:44:50 +08:00
/*
2014-02-10 09:10:30 +08:00
VCALL_PTR0 ( Transform , invert ) ;
VCALL_PTR0 ( Transform , affine_invert ) ;
VCALL_PTR2 ( Transform , rotate ) ;
VCALL_PTR1 ( Transform , scale ) ;
VCALL_PTR1 ( Transform , translate ) ;
VCALL_PTR0 ( Transform , orthonormalize ) ; */
struct ConstructData {
int arg_count ;
Vector < Variant : : Type > arg_types ;
Vector < String > arg_names ;
VariantConstructFunc func ;
} ;
struct ConstructFunc {
List < ConstructData > constructors ;
} ;
2017-03-05 23:44:50 +08:00
static ConstructFunc * construct_funcs ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
static void Vector2_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Vector2 ( * p_args [ 0 ] , * p_args [ 1 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Rect2_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Rect2 ( * p_args [ 0 ] , * p_args [ 1 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Rect2_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Rect2 ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Transform2D_init2 ( Variant & r_ret , const Variant * * p_args ) {
2015-07-15 07:59:35 +08:00
2017-01-11 11:52:51 +08:00
Transform2D m ( * p_args [ 0 ] , * p_args [ 1 ] ) ;
2017-03-05 23:44:50 +08:00
r_ret = m ;
2015-06-09 22:55:23 +08:00
}
2017-03-05 23:44:50 +08:00
static void Transform2D_init3 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-01-11 11:52:51 +08:00
Transform2D m ;
2017-03-05 23:44:50 +08:00
m [ 0 ] = * p_args [ 0 ] ;
m [ 1 ] = * p_args [ 1 ] ;
m [ 2 ] = * p_args [ 2 ] ;
r_ret = m ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Vector3_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Vector3 ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Plane_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Plane ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Plane_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Plane ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Plane_init3 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Plane ( p_args [ 0 ] - > operator Vector3 ( ) , p_args [ 1 ] - > operator real_t ( ) ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Plane_init4 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Plane ( p_args [ 0 ] - > operator Vector3 ( ) , p_args [ 1 ] - > operator Vector3 ( ) ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Quat_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Quat ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Quat_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-12-21 02:30:06 +08:00
2019-07-29 05:43:40 +08:00
r_ret = Quat ( ( ( Vector3 ) ( * p_args [ 0 ] ) ) , ( ( real_t ) ( * p_args [ 1 ] ) ) ) ;
2017-03-05 23:44:50 +08:00
}
2014-12-21 02:30:06 +08:00
2018-05-12 08:14:39 +08:00
static void Quat_init3 ( Variant & r_ret , const Variant * * p_args ) {
r_ret = Quat ( ( ( Vector3 ) ( * p_args [ 0 ] ) ) ) ;
}
2017-03-05 23:44:50 +08:00
static void Color_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Color ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] , * p_args [ 3 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Color_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Color ( * p_args [ 0 ] , * p_args [ 1 ] , * p_args [ 2 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Color_init3 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Color : : html ( * p_args [ 0 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Color_init4 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Color : : hex ( * p_args [ 0 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-11-17 10:09:00 +08:00
static void AABB_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-11-17 10:09:00 +08:00
r_ret = : : AABB ( * p_args [ 0 ] , * p_args [ 1 ] ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Basis_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-01-11 11:52:51 +08:00
Basis m ;
2017-03-05 23:44:50 +08:00
m . set_axis ( 0 , * p_args [ 0 ] ) ;
m . set_axis ( 1 , * p_args [ 1 ] ) ;
m . set_axis ( 2 , * p_args [ 2 ] ) ;
r_ret = m ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Basis_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Basis ( p_args [ 0 ] - > operator Vector3 ( ) , p_args [ 1 ] - > operator real_t ( ) ) ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Transform_init1 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
Transform t ;
2017-03-05 23:44:50 +08:00
t . basis . set_axis ( 0 , * p_args [ 0 ] ) ;
t . basis . set_axis ( 1 , * p_args [ 1 ] ) ;
t . basis . set_axis ( 2 , * p_args [ 2 ] ) ;
t . origin = * p_args [ 3 ] ;
r_ret = t ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
static void Transform_init2 ( Variant & r_ret , const Variant * * p_args ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
r_ret = Transform ( p_args [ 0 ] - > operator Basis ( ) , p_args [ 1 ] - > operator Vector3 ( ) ) ;
2014-02-10 09:10:30 +08:00
}
2020-02-20 03:27:19 +08:00
static void Callable_init2 ( Variant & r_ret , const Variant * * p_args ) {
r_ret = Callable ( p_args [ 0 ] - > operator ObjectID ( ) , p_args [ 1 ] - > operator String ( ) ) ;
}
static void Signal_init2 ( Variant & r_ret , const Variant * * p_args ) {
r_ret = Signal ( p_args [ 0 ] - > operator ObjectID ( ) , p_args [ 1 ] - > operator String ( ) ) ;
}
2017-03-05 23:44:50 +08:00
static void add_constructor ( VariantConstructFunc p_func , const Variant : : Type p_type ,
const String & p_name1 = " " , const Variant : : Type p_type1 = Variant : : NIL ,
const String & p_name2 = " " , const Variant : : Type p_type2 = Variant : : NIL ,
const String & p_name3 = " " , const Variant : : Type p_type3 = Variant : : NIL ,
const String & p_name4 = " " , const Variant : : Type p_type4 = Variant : : NIL ) {
2014-02-10 09:10:30 +08:00
ConstructData cd ;
2017-03-05 23:44:50 +08:00
cd . func = p_func ;
cd . arg_count = 0 ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
if ( p_name1 = = " " )
2014-02-10 09:10:30 +08:00
goto end ;
cd . arg_count + + ;
cd . arg_names . push_back ( p_name1 ) ;
cd . arg_types . push_back ( p_type1 ) ;
2017-03-05 23:44:50 +08:00
if ( p_name2 = = " " )
2014-02-10 09:10:30 +08:00
goto end ;
cd . arg_count + + ;
cd . arg_names . push_back ( p_name2 ) ;
cd . arg_types . push_back ( p_type2 ) ;
2017-03-05 23:44:50 +08:00
if ( p_name3 = = " " )
2014-02-10 09:10:30 +08:00
goto end ;
cd . arg_count + + ;
cd . arg_names . push_back ( p_name3 ) ;
cd . arg_types . push_back ( p_type3 ) ;
2017-03-05 23:44:50 +08:00
if ( p_name4 = = " " )
2014-02-10 09:10:30 +08:00
goto end ;
cd . arg_count + + ;
cd . arg_names . push_back ( p_name4 ) ;
cd . arg_types . push_back ( p_type4 ) ;
2017-03-05 23:44:50 +08:00
end :
2014-02-10 09:10:30 +08:00
construct_funcs [ p_type ] . constructors . push_back ( cd ) ;
}
struct ConstantData {
2017-03-05 23:44:50 +08:00
Map < StringName , int > value ;
2016-07-06 03:57:17 +08:00
# ifdef DEBUG_ENABLED
List < StringName > value_ordered ;
# endif
2017-12-15 23:43:27 +08:00
Map < StringName , Variant > variant_value ;
2014-02-10 09:10:30 +08:00
} ;
2017-03-05 23:44:50 +08:00
static ConstantData * constant_data ;
2014-02-10 09:10:30 +08:00
2016-07-06 03:57:17 +08:00
static void add_constant ( int p_type , StringName p_constant_name , int p_constant_value ) {
constant_data [ p_type ] . value [ p_constant_name ] = p_constant_value ;
# ifdef DEBUG_ENABLED
constant_data [ p_type ] . value_ordered . push_back ( p_constant_name ) ;
# endif
}
2017-12-15 23:43:27 +08:00
static void add_variant_constant ( int p_type , StringName p_constant_name , const Variant & p_constant_value ) {
constant_data [ p_type ] . variant_value [ p_constant_name ] = p_constant_value ;
}
2014-02-10 09:10:30 +08:00
} ;
2017-03-05 23:44:50 +08:00
_VariantCall : : TypeFunc * _VariantCall : : type_funcs = NULL ;
_VariantCall : : ConstructFunc * _VariantCall : : construct_funcs = NULL ;
_VariantCall : : ConstantData * _VariantCall : : constant_data = NULL ;
2014-02-10 09:10:30 +08:00
2020-02-20 03:27:19 +08:00
Variant Variant : : call ( const StringName & p_method , const Variant * * p_args , int p_argcount , Callable : : CallError & r_error ) {
2014-02-10 09:10:30 +08:00
Variant ret ;
2017-03-05 23:44:50 +08:00
call_ptr ( p_method , p_args , p_argcount , & ret , r_error ) ;
2016-06-20 12:15:02 +08:00
return ret ;
}
2020-02-20 03:27:19 +08:00
void Variant : : call_ptr ( const StringName & p_method , const Variant * * p_args , int p_argcount , Variant * r_ret , Callable : : CallError & r_error ) {
2016-06-20 12:15:02 +08:00
Variant ret ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
if ( type = = Variant : : OBJECT ) {
2014-02-10 09:10:30 +08:00
//call object
Object * obj = _get_obj ( ) . obj ;
if ( ! obj ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INSTANCE_IS_NULL ;
2016-06-20 12:15:02 +08:00
return ;
2014-02-10 09:10:30 +08:00
}
# ifdef DEBUG_ENABLED
2020-02-14 03:03:10 +08:00
if ( ScriptDebugger : : get_singleton ( ) & & ! _get_obj ( ) . id . is_reference ( ) & & ObjectDB : : get_instance ( _get_obj ( ) . id ) = = nullptr ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INSTANCE_IS_NULL ;
2020-02-14 03:03:10 +08:00
return ;
2014-02-10 09:10:30 +08:00
}
# endif
2017-03-05 23:44:50 +08:00
ret = _get_obj ( ) . obj - > call ( p_method , p_args , p_argcount , r_error ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
//else if (type==Variant::METHOD) {
2014-02-10 09:10:30 +08:00
} else {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_OK ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
Map < StringName , _VariantCall : : FuncData > : : Element * E = _VariantCall : : type_funcs [ type ] . functions . find ( p_method ) ;
2020-02-20 03:27:19 +08:00
if ( E ) {
_VariantCall : : FuncData & funcdata = E - > get ( ) ;
funcdata . call ( ret , * this , p_args , p_argcount , r_error ) ;
} else {
//handle vararg functions manually
bool valid = false ;
if ( type = = CALLABLE ) {
if ( p_method = = CoreStringNames : : get_singleton ( ) - > call ) {
reinterpret_cast < const Callable * > ( _data . _mem ) - > call ( p_args , p_argcount , ret , r_error ) ;
valid = true ;
}
if ( p_method = = CoreStringNames : : get_singleton ( ) - > call_deferred ) {
reinterpret_cast < const Callable * > ( _data . _mem ) - > call_deferred ( p_args , p_argcount ) ;
valid = true ;
}
} else if ( type = = SIGNAL ) {
if ( p_method = = CoreStringNames : : get_singleton ( ) - > emit ) {
if ( r_ret ) {
* r_ret = Variant ( ) ;
}
reinterpret_cast < const Signal * > ( _data . _mem ) - > emit ( p_args , p_argcount ) ;
valid = true ;
}
}
if ( ! valid ) {
//ok fail because not found
r_error . error = Callable : : CallError : : CALL_ERROR_INVALID_METHOD ;
return ;
}
2014-02-10 09:10:30 +08:00
}
}
2020-02-20 03:27:19 +08:00
if ( r_error . error = = Callable : : CallError : : CALL_OK & & r_ret )
2017-03-05 23:44:50 +08:00
* r_ret = ret ;
2014-02-10 09:10:30 +08:00
}
2017-03-05 23:44:50 +08:00
# define VCALL(m_type, m_method) _VariantCall::_call_##m_type##_##m_method
2014-02-10 09:10:30 +08:00
2020-02-20 03:27:19 +08:00
Variant Variant : : construct ( const Variant : : Type p_type , const Variant * * p_args , int p_argcount , Callable : : CallError & r_error , bool p_strict ) {
2014-02-10 09:10:30 +08:00
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INVALID_METHOD ;
2017-03-05 23:44:50 +08:00
ERR_FAIL_INDEX_V ( p_type , VARIANT_MAX , Variant ( ) ) ;
2014-02-10 09:10:30 +08:00
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_OK ;
2017-03-05 23:44:50 +08:00
if ( p_argcount = = 0 ) { //generic construct
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
switch ( p_type ) {
case NIL :
return Variant ( ) ;
2014-02-10 09:10:30 +08:00
// atomic types
2017-03-05 23:44:50 +08:00
case BOOL : return Variant ( false ) ;
2014-02-10 09:10:30 +08:00
case INT : return 0 ;
case REAL : return 0.0f ;
2017-03-05 23:44:50 +08:00
case STRING :
return String ( ) ;
2014-02-10 09:10:30 +08:00
// math types
2017-03-05 23:44:50 +08:00
case VECTOR2 :
return Vector2 ( ) ; // 5
2014-02-10 09:10:30 +08:00
case RECT2 : return Rect2 ( ) ;
case VECTOR3 : return Vector3 ( ) ;
2017-01-11 11:52:51 +08:00
case TRANSFORM2D : return Transform2D ( ) ;
2014-02-10 09:10:30 +08:00
case PLANE : return Plane ( ) ;
case QUAT : return Quat ( ) ;
2017-11-17 10:09:00 +08:00
case AABB :
return : : AABB ( ) ; // 10
2017-01-11 11:52:51 +08:00
case BASIS : return Basis ( ) ;
2017-03-05 23:44:50 +08:00
case TRANSFORM :
return Transform ( ) ;
2014-02-10 09:10:30 +08:00
// misc types
case COLOR : return Color ( ) ;
2017-03-05 23:44:50 +08:00
case NODE_PATH :
return NodePath ( ) ; // 15
2017-01-15 01:03:38 +08:00
case _RID : return RID ( ) ;
2017-03-05 23:44:50 +08:00
case OBJECT : return ( Object * ) NULL ;
2020-02-20 03:27:19 +08:00
case CALLABLE : return Callable ( ) ;
case SIGNAL : return Signal ( ) ;
2017-01-15 01:03:38 +08:00
case DICTIONARY : return Dictionary ( ) ;
2017-03-05 23:44:50 +08:00
case ARRAY :
return Array ( ) ; // 20
2020-02-18 05:06:54 +08:00
case PACKED_BYTE_ARRAY : return PackedByteArray ( ) ;
case PACKED_INT_ARRAY : return PackedIntArray ( ) ;
case PACKED_REAL_ARRAY : return PackedRealArray ( ) ;
case PACKED_STRING_ARRAY : return PackedStringArray ( ) ;
case PACKED_VECTOR2_ARRAY :
return PackedVector2Array ( ) ; // 25
case PACKED_VECTOR3_ARRAY : return PackedVector3Array ( ) ;
case PACKED_COLOR_ARRAY : return PackedColorArray ( ) ;
2014-02-10 09:10:30 +08:00
default : return Variant ( ) ;
}
2017-03-05 23:44:50 +08:00
} else if ( p_argcount = = 1 & & p_args [ 0 ] - > type = = p_type ) {
2014-02-10 09:10:30 +08:00
return * p_args [ 0 ] ; //copy construct
2017-03-05 23:44:50 +08:00
} else if ( p_argcount = = 1 & & ( ! p_strict | | Variant : : can_convert ( p_args [ 0 ] - > type , p_type ) ) ) {
2014-02-10 09:10:30 +08:00
//near match construct
2017-03-05 23:44:50 +08:00
switch ( p_type ) {
2014-02-10 09:10:30 +08:00
case NIL : {
return Variant ( ) ;
} break ;
2017-03-05 23:44:50 +08:00
case BOOL : {
return Variant ( bool ( * p_args [ 0 ] ) ) ;
}
case INT : {
2018-08-14 15:56:10 +08:00
return ( int64_t ( * p_args [ 0 ] ) ) ;
2017-03-05 23:44:50 +08:00
}
case REAL : {
return real_t ( * p_args [ 0 ] ) ;
}
case STRING : {
return String ( * p_args [ 0 ] ) ;
}
case VECTOR2 : {
return Vector2 ( * p_args [ 0 ] ) ;
}
2014-02-10 09:10:30 +08:00
case RECT2 : return ( Rect2 ( * p_args [ 0 ] ) ) ;
case VECTOR3 : return ( Vector3 ( * p_args [ 0 ] ) ) ;
case PLANE : return ( Plane ( * p_args [ 0 ] ) ) ;
2018-05-12 08:14:39 +08:00
case QUAT : return ( p_args [ 0 ] - > operator Quat ( ) ) ;
2017-11-17 10:09:00 +08:00
case AABB :
return ( : : AABB ( * p_args [ 0 ] ) ) ; // 10
2017-01-11 11:52:51 +08:00
case BASIS : return ( Basis ( p_args [ 0 ] - > operator Basis ( ) ) ) ;
2017-03-05 23:44:50 +08:00
case TRANSFORM :
return ( Transform ( p_args [ 0 ] - > operator Transform ( ) ) ) ;
2014-02-10 09:10:30 +08:00
// misc types
2014-04-10 11:18:27 +08:00
case COLOR : return p_args [ 0 ] - > type = = Variant : : STRING ? Color : : html ( * p_args [ 0 ] ) : Color : : hex ( * p_args [ 0 ] ) ;
2017-03-05 23:44:50 +08:00
case NODE_PATH :
return ( NodePath ( p_args [ 0 ] - > operator NodePath ( ) ) ) ; // 15
2014-02-10 09:10:30 +08:00
case _RID : return ( RID ( * p_args [ 0 ] ) ) ;
2017-03-05 23:44:50 +08:00
case OBJECT : return ( ( Object * ) ( p_args [ 0 ] - > operator Object * ( ) ) ) ;
2014-02-10 09:10:30 +08:00
case DICTIONARY : return p_args [ 0 ] - > operator Dictionary ( ) ;
2017-03-05 23:44:50 +08:00
case ARRAY :
return p_args [ 0 ] - > operator Array ( ) ; // 20
2014-02-10 09:10:30 +08:00
// arrays
2020-02-18 05:06:54 +08:00
case PACKED_BYTE_ARRAY : return ( PackedByteArray ( * p_args [ 0 ] ) ) ;
case PACKED_INT_ARRAY : return ( PackedIntArray ( * p_args [ 0 ] ) ) ;
case PACKED_REAL_ARRAY : return ( PackedRealArray ( * p_args [ 0 ] ) ) ;
case PACKED_STRING_ARRAY : return ( PackedStringArray ( * p_args [ 0 ] ) ) ;
case PACKED_VECTOR2_ARRAY :
return ( PackedVector2Array ( * p_args [ 0 ] ) ) ; // 25
case PACKED_VECTOR3_ARRAY : return ( PackedVector3Array ( * p_args [ 0 ] ) ) ;
case PACKED_COLOR_ARRAY : return ( PackedColorArray ( * p_args [ 0 ] ) ) ;
2014-02-10 09:10:30 +08:00
default : return Variant ( ) ;
}
2019-04-08 09:52:21 +08:00
} else if ( p_argcount > = 1 ) {
_VariantCall : : ConstructFunc & c = _VariantCall : : construct_funcs [ p_type ] ;
for ( List < _VariantCall : : ConstructData > : : Element * E = c . constructors . front ( ) ; E ; E = E - > next ( ) ) {
const _VariantCall : : ConstructData & cd = E - > get ( ) ;
if ( cd . arg_count ! = p_argcount )
continue ;
//validate parameters
for ( int i = 0 ; i < cd . arg_count ; i + + ) {
if ( ! Variant : : can_convert ( p_args [ i ] - > type , cd . arg_types [ i ] ) ) {
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INVALID_ARGUMENT ; //no such constructor
2019-04-08 09:52:21 +08:00
r_error . argument = i ;
r_error . expected = cd . arg_types [ i ] ;
return Variant ( ) ;
}
}
Variant v ;
cd . func ( v , p_args ) ;
return v ;
}
2014-02-10 09:10:30 +08:00
}
2020-02-20 03:27:19 +08:00
r_error . error = Callable : : CallError : : CALL_ERROR_INVALID_METHOD ; //no such constructor
2014-02-10 09:10:30 +08:00
return Variant ( ) ;
}
2017-03-05 23:44:50 +08:00
bool Variant : : has_method ( const StringName & p_method ) const {
2014-09-20 08:01:41 +08:00
2017-03-05 23:44:50 +08:00
if ( type = = OBJECT ) {
2020-02-14 03:03:10 +08:00
Object * obj = get_validated_object ( ) ;
2014-09-20 08:01:41 +08:00
if ( ! obj )
return false ;
2020-02-14 03:03:10 +08:00
return obj - > has_method ( p_method ) ;
2014-09-20 08:01:41 +08:00
}
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ type ] ;
return tf . functions . has ( p_method ) ;
2014-09-20 08:01:41 +08:00
}
2017-03-05 23:44:50 +08:00
Vector < Variant : : Type > Variant : : get_method_argument_types ( Variant : : Type p_type , const StringName & p_method ) {
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ p_type ] ;
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . find ( p_method ) ;
2016-08-03 22:28:20 +08:00
if ( ! E )
return Vector < Variant : : Type > ( ) ;
return E - > get ( ) . arg_types ;
}
2017-09-26 04:08:48 +08:00
bool Variant : : is_method_const ( Variant : : Type p_type , const StringName & p_method ) {
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ p_type ] ;
2017-09-26 04:08:48 +08:00
2019-02-13 04:10:08 +08:00
const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . find ( p_method ) ;
2017-09-26 04:08:48 +08:00
if ( ! E )
return false ;
return E - > get ( ) . _const ;
}
2017-03-05 23:44:50 +08:00
Vector < StringName > Variant : : get_method_argument_names ( Variant : : Type p_type , const StringName & p_method ) {
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ p_type ] ;
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . find ( p_method ) ;
2016-08-03 22:28:20 +08:00
if ( ! E )
return Vector < StringName > ( ) ;
return E - > get ( ) . arg_names ;
}
2017-03-05 23:44:50 +08:00
Variant : : Type Variant : : get_method_return_type ( Variant : : Type p_type , const StringName & p_method , bool * r_has_return ) {
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ p_type ] ;
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . find ( p_method ) ;
2016-08-03 22:28:20 +08:00
if ( ! E )
return Variant : : NIL ;
if ( r_has_return )
2017-10-23 01:08:16 +08:00
* r_has_return = E - > get ( ) . returns ;
2016-08-03 22:28:20 +08:00
return E - > get ( ) . return_type ;
}
2017-03-05 23:44:50 +08:00
Vector < Variant > Variant : : get_method_default_arguments ( Variant : : Type p_type , const StringName & p_method ) {
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ p_type ] ;
2016-08-03 22:28:20 +08:00
2019-02-13 04:10:08 +08:00
const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . find ( p_method ) ;
2016-08-03 22:28:20 +08:00
if ( ! E )
return Vector < Variant > ( ) ;
return E - > get ( ) . default_args ;
}
2014-02-10 09:10:30 +08:00
void Variant : : get_method_list ( List < MethodInfo > * p_list ) const {
2019-02-13 04:10:08 +08:00
const _VariantCall : : TypeFunc & tf = _VariantCall : : type_funcs [ type ] ;
2014-02-10 09:10:30 +08:00
2019-02-13 04:10:08 +08:00
for ( const Map < StringName , _VariantCall : : FuncData > : : Element * E = tf . functions . front ( ) ; E ; E = E - > next ( ) ) {
2014-02-10 09:10:30 +08:00
const _VariantCall : : FuncData & fd = E - > get ( ) ;
MethodInfo mi ;
2017-03-05 23:44:50 +08:00
mi . name = E - > key ( ) ;
2014-02-10 09:10:30 +08:00
2017-09-26 04:08:48 +08:00
if ( fd . _const ) {
mi . flags | = METHOD_FLAG_CONST ;
}
2017-03-05 23:44:50 +08:00
for ( int i = 0 ; i < fd . arg_types . size ( ) ; i + + ) {
2014-02-10 09:10:30 +08:00
PropertyInfo pi ;
2017-03-05 23:44:50 +08:00
pi . type = fd . arg_types [ i ] ;
2014-02-10 09:10:30 +08:00
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
pi . name = fd . arg_names [ i ] ;
2014-02-10 09:10:30 +08:00
# endif
mi . arguments . push_back ( pi ) ;
}
2017-03-05 23:44:50 +08:00
mi . default_arguments = fd . default_args ;
2014-02-10 09:10:30 +08:00
PropertyInfo ret ;
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
ret . type = fd . return_type ;
2014-02-10 09:10:30 +08:00
if ( fd . returns )
2017-03-05 23:44:50 +08:00
ret . name = " ret " ;
mi . return_val = ret ;
2015-07-15 07:59:35 +08:00
# endif
2014-02-10 09:10:30 +08:00
p_list - > push_back ( mi ) ;
}
2020-02-20 03:27:19 +08:00
if ( type = = CALLABLE ) {
MethodInfo mi ;
mi . name = " call " ;
mi . return_val . usage = PROPERTY_USAGE_NIL_IS_VARIANT ;
mi . flags | = METHOD_FLAG_VARARG ;
p_list - > push_back ( mi ) ;
mi . name = " call_deferred " ;
mi . return_val . usage = 0 ;
p_list - > push_back ( mi ) ;
}
if ( type = = SIGNAL ) {
MethodInfo mi ;
mi . name = " emit " ;
mi . flags | = METHOD_FLAG_VARARG ;
p_list - > push_back ( mi ) ;
}
2014-02-10 09:10:30 +08:00
}
void Variant : : get_constructor_list ( Variant : : Type p_type , List < MethodInfo > * p_list ) {
2017-03-05 23:44:50 +08:00
ERR_FAIL_INDEX ( p_type , VARIANT_MAX ) ;
2014-02-10 09:10:30 +08:00
//custom constructors
2017-03-05 23:44:50 +08:00
for ( const List < _VariantCall : : ConstructData > : : Element * E = _VariantCall : : construct_funcs [ p_type ] . constructors . front ( ) ; E ; E = E - > next ( ) ) {
2014-02-10 09:10:30 +08:00
const _VariantCall : : ConstructData & cd = E - > get ( ) ;
MethodInfo mi ;
2017-03-05 23:44:50 +08:00
mi . name = Variant : : get_type_name ( p_type ) ;
mi . return_val . type = p_type ;
for ( int i = 0 ; i < cd . arg_count ; i + + ) {
2014-02-10 09:10:30 +08:00
PropertyInfo pi ;
2017-03-05 23:44:50 +08:00
pi . name = cd . arg_names [ i ] ;
pi . type = cd . arg_types [ i ] ;
2014-02-10 09:10:30 +08:00
mi . arguments . push_back ( pi ) ;
}
p_list - > push_back ( mi ) ;
}
//default constructors
2017-03-05 23:44:50 +08:00
for ( int i = 0 ; i < VARIANT_MAX ; i + + ) {
if ( i = = p_type )
2014-02-10 09:10:30 +08:00
continue ;
2017-03-05 23:44:50 +08:00
if ( ! Variant : : can_convert ( Variant : : Type ( i ) , p_type ) )
2014-02-10 09:10:30 +08:00
continue ;
MethodInfo mi ;
2017-03-05 23:44:50 +08:00
mi . name = Variant : : get_type_name ( p_type ) ;
2014-02-10 09:10:30 +08:00
PropertyInfo pi ;
2017-03-05 23:44:50 +08:00
pi . name = " from " ;
pi . type = Variant : : Type ( i ) ;
2014-02-10 09:10:30 +08:00
mi . arguments . push_back ( pi ) ;
2017-03-05 23:44:50 +08:00
mi . return_val . type = p_type ;
2014-02-10 09:10:30 +08:00
p_list - > push_back ( mi ) ;
}
}
2017-12-15 23:43:27 +08:00
void Variant : : get_constants_for_type ( Variant : : Type p_type , List < StringName > * p_constants ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
ERR_FAIL_INDEX ( p_type , Variant : : VARIANT_MAX ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : ConstantData & cd = _VariantCall : : constant_data [ p_type ] ;
2014-02-10 09:10:30 +08:00
2016-07-06 03:57:17 +08:00
# ifdef DEBUG_ENABLED
2017-03-05 23:44:50 +08:00
for ( List < StringName > : : Element * E = cd . value_ordered . front ( ) ; E ; E = E - > next ( ) ) {
2016-07-06 03:57:17 +08:00
p_constants - > push_back ( E - > get ( ) ) ;
# else
2017-03-05 23:44:50 +08:00
for ( Map < StringName , int > : : Element * E = cd . value . front ( ) ; E ; E = E - > next ( ) ) {
2014-02-10 09:10:30 +08:00
p_constants - > push_back ( E - > key ( ) ) ;
2016-07-06 03:57:17 +08:00
# endif
2014-02-10 09:10:30 +08:00
}
2017-12-15 23:43:27 +08:00
for ( Map < StringName , Variant > : : Element * E = cd . variant_value . front ( ) ; E ; E = E - > next ( ) ) {
p_constants - > push_back ( E - > key ( ) ) ;
}
2014-02-10 09:10:30 +08:00
}
2017-12-15 23:43:27 +08:00
bool Variant : : has_constant ( Variant : : Type p_type , const StringName & p_value ) {
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
ERR_FAIL_INDEX_V ( p_type , Variant : : VARIANT_MAX , false ) ;
_VariantCall : : ConstantData & cd = _VariantCall : : constant_data [ p_type ] ;
2017-12-15 23:43:27 +08:00
return cd . value . has ( p_value ) | | cd . variant_value . has ( p_value ) ;
2014-02-10 09:10:30 +08:00
}
2017-12-15 23:43:27 +08:00
Variant Variant : : get_constant_value ( Variant : : Type p_type , const StringName & p_value , bool * r_valid ) {
2016-09-02 13:13:12 +08:00
if ( r_valid )
2017-03-05 23:44:50 +08:00
* r_valid = false ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
ERR_FAIL_INDEX_V ( p_type , Variant : : VARIANT_MAX , 0 ) ;
_VariantCall : : ConstantData & cd = _VariantCall : : constant_data [ p_type ] ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
Map < StringName , int > : : Element * E = cd . value . find ( p_value ) ;
2016-09-02 13:13:12 +08:00
if ( ! E ) {
2019-02-13 04:10:08 +08:00
Map < StringName , Variant > : : Element * F = cd . variant_value . find ( p_value ) ;
if ( F ) {
2017-12-15 23:43:27 +08:00
if ( r_valid )
* r_valid = true ;
2019-02-13 04:10:08 +08:00
return F - > get ( ) ;
2017-12-15 23:43:27 +08:00
} else {
return - 1 ;
}
2016-09-02 13:13:12 +08:00
}
if ( r_valid )
2017-03-05 23:44:50 +08:00
* r_valid = true ;
2016-09-02 13:13:12 +08:00
2014-02-10 09:10:30 +08:00
return E - > get ( ) ;
}
void register_variant_methods ( ) {
2017-03-05 23:44:50 +08:00
_VariantCall : : type_funcs = memnew_arr ( _VariantCall : : TypeFunc , Variant : : VARIANT_MAX ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : construct_funcs = memnew_arr ( _VariantCall : : ConstructFunc , Variant : : VARIANT_MAX ) ;
2014-02-10 09:10:30 +08:00
_VariantCall : : constant_data = memnew_arr ( _VariantCall : : ConstantData , Variant : : VARIANT_MAX ) ;
2017-10-23 01:08:16 +08:00
# define ADDFUNC0R(m_vtype, m_ret, m_class, m_method, m_defarg) \
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg ) ;
# define ADDFUNC1R(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_defarg) \
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) ) ;
# define ADDFUNC2R(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_defarg) \
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) ) ;
# define ADDFUNC3R(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_defarg) \
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) ) ;
# define ADDFUNC4R(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_arg4, m_argname4, m_defarg) \
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) , _VariantCall : : Arg ( Variant : : m_arg4 , _scs_create ( m_argname4 ) ) ) ;
# define ADDFUNC0RNC(m_vtype, m_ret, m_class, m_method, m_defarg) \
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg ) ;
# define ADDFUNC1RNC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_defarg) \
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) ) ;
# define ADDFUNC2RNC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_defarg) \
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) ) ;
# define ADDFUNC3RNC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_defarg) \
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) ) ;
# define ADDFUNC4RNC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_arg4, m_argname4, m_defarg) \
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , true , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) , _VariantCall : : Arg ( Variant : : m_arg4 , _scs_create ( m_argname4 ) ) ) ;
2017-03-05 23:44:50 +08:00
# define ADDFUNC0(m_vtype, m_ret, m_class, m_method, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg ) ;
2017-03-05 23:44:50 +08:00
# define ADDFUNC1(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) ) ;
2017-03-05 23:44:50 +08:00
# define ADDFUNC2(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) ) ;
2017-03-05 23:44:50 +08:00
# define ADDFUNC3(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) ) ;
2017-03-05 23:44:50 +08:00
# define ADDFUNC4(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_arg4, m_argname4, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( true , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) , _VariantCall : : Arg ( Variant : : m_arg4 , _scs_create ( m_argname4 ) ) ) ;
2017-09-26 04:08:48 +08:00
# define ADDFUNC0NC(m_vtype, m_ret, m_class, m_method, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg ) ;
2017-09-26 04:08:48 +08:00
# define ADDFUNC1NC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) ) ;
2017-09-26 04:08:48 +08:00
# define ADDFUNC2NC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) ) ;
2017-09-26 04:08:48 +08:00
# define ADDFUNC3NC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) ) ;
2017-09-26 04:08:48 +08:00
# define ADDFUNC4NC(m_vtype, m_ret, m_class, m_method, m_arg1, m_argname1, m_arg2, m_argname2, m_arg3, m_argname3, m_arg4, m_argname4, m_defarg) \
2017-10-23 01:08:16 +08:00
_VariantCall : : addfunc ( false , Variant : : m_vtype , Variant : : m_ret , false , _scs_create ( # m_method ) , VCALL ( m_class , m_method ) , m_defarg , _VariantCall : : Arg ( Variant : : m_arg1 , _scs_create ( m_argname1 ) ) , _VariantCall : : Arg ( Variant : : m_arg2 , _scs_create ( m_argname2 ) ) , _VariantCall : : Arg ( Variant : : m_arg3 , _scs_create ( m_argname3 ) ) , _VariantCall : : Arg ( Variant : : m_arg4 , _scs_create ( m_argname4 ) ) ) ;
2014-02-10 09:10:30 +08:00
/* STRING */
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( STRING , INT , String , casecmp_to , STRING , " to " , varray ( ) ) ;
ADDFUNC1R ( STRING , INT , String , nocasecmp_to , STRING , " to " , varray ( ) ) ;
ADDFUNC0R ( STRING , INT , String , length , varray ( ) ) ;
2019-05-03 20:21:04 +08:00
ADDFUNC2R ( STRING , STRING , String , substr , INT , " from " , INT , " len " , varray ( - 1 ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( STRING , INT , String , find , STRING , " what " , INT , " from " , varray ( 0 ) ) ;
2019-01-18 16:29:28 +08:00
ADDFUNC3R ( STRING , INT , String , count , STRING , " what " , INT , " from " , INT , " to " , varray ( 0 , 0 ) ) ;
ADDFUNC3R ( STRING , INT , String , countn , STRING , " what " , INT , " from " , INT , " to " , varray ( 0 , 0 ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( STRING , INT , String , find_last , STRING , " what " , varray ( ) ) ;
ADDFUNC2R ( STRING , INT , String , findn , STRING , " what " , INT , " from " , varray ( 0 ) ) ;
ADDFUNC2R ( STRING , INT , String , rfind , STRING , " what " , INT , " from " , varray ( - 1 ) ) ;
ADDFUNC2R ( STRING , INT , String , rfindn , STRING , " what " , INT , " from " , varray ( - 1 ) ) ;
ADDFUNC1R ( STRING , BOOL , String , match , STRING , " expr " , varray ( ) ) ;
ADDFUNC1R ( STRING , BOOL , String , matchn , STRING , " expr " , varray ( ) ) ;
ADDFUNC1R ( STRING , BOOL , String , begins_with , STRING , " text " , varray ( ) ) ;
ADDFUNC1R ( STRING , BOOL , String , ends_with , STRING , " text " , varray ( ) ) ;
ADDFUNC1R ( STRING , BOOL , String , is_subsequence_of , STRING , " text " , varray ( ) ) ;
ADDFUNC1R ( STRING , BOOL , String , is_subsequence_ofi , STRING , " text " , varray ( ) ) ;
2020-02-18 05:06:54 +08:00
ADDFUNC0R ( STRING , PACKED_STRING_ARRAY , String , bigrams , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( STRING , REAL , String , similarity , STRING , " text " , varray ( ) ) ;
ADDFUNC2R ( STRING , STRING , String , format , NIL , " values " , STRING , " placeholder " , varray ( " {_} " ) ) ;
ADDFUNC2R ( STRING , STRING , String , replace , STRING , " what " , STRING , " forwhat " , varray ( ) ) ;
ADDFUNC2R ( STRING , STRING , String , replacen , STRING , " what " , STRING , " forwhat " , varray ( ) ) ;
2019-09-02 11:49:55 +08:00
ADDFUNC1R ( STRING , STRING , String , repeat , INT , " count " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( STRING , STRING , String , insert , INT , " position " , STRING , " what " , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , capitalize , varray ( ) ) ;
2020-02-18 05:06:54 +08:00
ADDFUNC3R ( STRING , PACKED_STRING_ARRAY , String , split , STRING , " delimiter " , BOOL , " allow_empty " , INT , " maxsplit " , varray ( true , 0 ) ) ;
ADDFUNC3R ( STRING , PACKED_STRING_ARRAY , String , rsplit , STRING , " delimiter " , BOOL , " allow_empty " , INT , " maxsplit " , varray ( true , 0 ) ) ;
ADDFUNC2R ( STRING , PACKED_REAL_ARRAY , String , split_floats , STRING , " delimiter " , BOOL , " allow_empty " , varray ( true ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , STRING , String , to_upper , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , to_lower , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , left , INT , " position " , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , right , INT , " position " , varray ( ) ) ;
ADDFUNC2R ( STRING , STRING , String , strip_edges , BOOL , " left " , BOOL , " right " , varray ( true , true ) ) ;
2019-05-31 21:27:53 +08:00
ADDFUNC0R ( STRING , STRING , String , strip_escapes , varray ( ) ) ;
2018-04-13 22:40:27 +08:00
ADDFUNC1R ( STRING , STRING , String , lstrip , STRING , " chars " , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , rstrip , STRING , " chars " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , STRING , String , get_extension , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , get_basename , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , plus_file , STRING , " file " , varray ( ) ) ;
ADDFUNC1R ( STRING , INT , String , ord_at , INT , " at " , varray ( ) ) ;
2017-11-05 09:07:06 +08:00
ADDFUNC0R ( STRING , STRING , String , dedent , varray ( ) ) ;
2017-09-10 21:37:49 +08:00
ADDFUNC2 ( STRING , NIL , String , erase , INT , " position " , INT , " chars " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , INT , String , hash , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , md5_text , varray ( ) ) ;
2019-07-02 22:07:02 +08:00
ADDFUNC0R ( STRING , STRING , String , sha1_text , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , STRING , String , sha256_text , varray ( ) ) ;
2020-02-18 05:06:54 +08:00
ADDFUNC0R ( STRING , PACKED_BYTE_ARRAY , String , md5_buffer , varray ( ) ) ;
ADDFUNC0R ( STRING , PACKED_BYTE_ARRAY , String , sha1_buffer , varray ( ) ) ;
ADDFUNC0R ( STRING , PACKED_BYTE_ARRAY , String , sha256_buffer , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , BOOL , String , empty , varray ( ) ) ;
2019-10-04 19:35:01 +08:00
ADDFUNC1R ( STRING , STRING , String , humanize_size , INT , " size " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , BOOL , String , is_abs_path , varray ( ) ) ;
ADDFUNC0R ( STRING , BOOL , String , is_rel_path , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , get_base_dir , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , get_file , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , xml_escape , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , xml_unescape , varray ( ) ) ;
2019-06-08 16:33:12 +08:00
ADDFUNC0R ( STRING , STRING , String , http_escape , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , http_unescape , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , STRING , String , c_escape , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , c_unescape , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , json_escape , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , percent_encode , varray ( ) ) ;
ADDFUNC0R ( STRING , STRING , String , percent_decode , varray ( ) ) ;
ADDFUNC0R ( STRING , BOOL , String , is_valid_identifier , varray ( ) ) ;
ADDFUNC0R ( STRING , BOOL , String , is_valid_integer , varray ( ) ) ;
ADDFUNC0R ( STRING , BOOL , String , is_valid_float , varray ( ) ) ;
2018-12-25 02:54:36 +08:00
ADDFUNC1R ( STRING , BOOL , String , is_valid_hex_number , BOOL , " with_prefix " , varray ( false ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , BOOL , String , is_valid_html_color , varray ( ) ) ;
ADDFUNC0R ( STRING , BOOL , String , is_valid_ip_address , varray ( ) ) ;
2019-04-09 06:18:03 +08:00
ADDFUNC0R ( STRING , BOOL , String , is_valid_filename , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( STRING , INT , String , to_int , varray ( ) ) ;
ADDFUNC0R ( STRING , REAL , String , to_float , varray ( ) ) ;
ADDFUNC0R ( STRING , INT , String , hex_to_int , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , pad_decimals , INT , " digits " , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , pad_zeros , INT , " digits " , varray ( ) ) ;
2018-04-13 22:40:27 +08:00
ADDFUNC1R ( STRING , STRING , String , trim_prefix , STRING , " prefix " , varray ( ) ) ;
ADDFUNC1R ( STRING , STRING , String , trim_suffix , STRING , " suffix " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
2020-02-18 05:06:54 +08:00
ADDFUNC0R ( STRING , PACKED_BYTE_ARRAY , String , to_ascii , varray ( ) ) ;
ADDFUNC0R ( STRING , PACKED_BYTE_ARRAY , String , to_utf8 , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( VECTOR2 , REAL , Vector2 , angle , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , angle_to , VECTOR2 , " to " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , angle_to_point , VECTOR2 , " to " , varray ( ) ) ;
2019-03-27 18:51:05 +08:00
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , direction_to , VECTOR2 , " b " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , distance_to , VECTOR2 , " to " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , distance_squared_to , VECTOR2 , " to " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC0R ( VECTOR2 , REAL , Vector2 , length , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , REAL , Vector2 , length_squared , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , normalized , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , BOOL , Vector2 , is_normalized , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , BOOL , Vector2 , is_equal_approx , VECTOR2 , " v " , varray ( ) ) ;
2019-08-05 09:50:28 +08:00
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , posmod , REAL , " mod " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , posmodv , VECTOR2 , " modv " , varray ( ) ) ;
2018-08-16 18:52:38 +08:00
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , project , VECTOR2 , " b " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( VECTOR2 , VECTOR2 , Vector2 , linear_interpolate , VECTOR2 , " b " , REAL , " t " , varray ( ) ) ;
2018-05-12 08:14:39 +08:00
ADDFUNC2R ( VECTOR2 , VECTOR2 , Vector2 , slerp , VECTOR2 , " b " , REAL , " t " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC4R ( VECTOR2 , VECTOR2 , Vector2 , cubic_interpolate , VECTOR2 , " b " , VECTOR2 , " pre_a " , VECTOR2 , " post_b " , REAL , " t " , varray ( ) ) ;
2019-04-08 05:40:56 +08:00
ADDFUNC2R ( VECTOR2 , VECTOR2 , Vector2 , move_toward , VECTOR2 , " to " , REAL , " delta " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , rotated , REAL , " phi " , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , tangent , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , floor , varray ( ) ) ;
2018-05-04 15:24:48 +08:00
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , ceil , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , round , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , snapped , VECTOR2 , " by " , varray ( ) ) ;
ADDFUNC0R ( VECTOR2 , REAL , Vector2 , aspect , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , dot , VECTOR2 , " with " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , slide , VECTOR2 , " n " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , bounce , VECTOR2 , " n " , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , reflect , VECTOR2 , " n " , varray ( ) ) ;
2018-02-08 15:48:14 +08:00
ADDFUNC1R ( VECTOR2 , REAL , Vector2 , cross , VECTOR2 , " with " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , abs , varray ( ) ) ;
ADDFUNC1R ( VECTOR2 , VECTOR2 , Vector2 , clamped , REAL , " length " , varray ( ) ) ;
2019-08-05 09:50:28 +08:00
ADDFUNC0R ( VECTOR2 , VECTOR2 , Vector2 , sign , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( RECT2 , REAL , Rect2 , get_area , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC0R ( RECT2 , BOOL , Rect2 , has_no_area , varray ( ) ) ;
ADDFUNC1R ( RECT2 , BOOL , Rect2 , has_point , VECTOR2 , " point " , varray ( ) ) ;
ADDFUNC1R ( RECT2 , BOOL , Rect2 , is_equal_approx , RECT2 , " rect " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( RECT2 , BOOL , Rect2 , intersects , RECT2 , " b " , varray ( ) ) ;
ADDFUNC1R ( RECT2 , BOOL , Rect2 , encloses , RECT2 , " b " , varray ( ) ) ;
ADDFUNC1R ( RECT2 , RECT2 , Rect2 , clip , RECT2 , " b " , varray ( ) ) ;
ADDFUNC1R ( RECT2 , RECT2 , Rect2 , merge , RECT2 , " b " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( RECT2 , RECT2 , Rect2 , expand , VECTOR2 , " to " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( RECT2 , RECT2 , Rect2 , grow , REAL , " by " , varray ( ) ) ;
ADDFUNC2R ( RECT2 , RECT2 , Rect2 , grow_margin , INT , " margin " , REAL , " by " , varray ( ) ) ;
ADDFUNC4R ( RECT2 , RECT2 , Rect2 , grow_individual , REAL , " left " , REAL , " top " , REAL , " right " , REAL , " bottom " , varray ( ) ) ;
2017-11-28 01:41:29 +08:00
ADDFUNC0R ( RECT2 , RECT2 , Rect2 , abs , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( VECTOR3 , INT , Vector3 , min_axis , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , INT , Vector3 , max_axis , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( VECTOR3 , REAL , Vector3 , angle_to , VECTOR3 , " to " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , direction_to , VECTOR3 , " b " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , REAL , Vector3 , distance_to , VECTOR3 , " b " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , REAL , Vector3 , distance_squared_to , VECTOR3 , " b " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( VECTOR3 , REAL , Vector3 , length , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , REAL , Vector3 , length_squared , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , normalized , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC0R ( VECTOR3 , BOOL , Vector3 , is_normalized , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , BOOL , Vector3 , is_equal_approx , VECTOR3 , " v " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , inverse , varray ( ) ) ;
2018-02-04 02:09:16 +08:00
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , snapped , VECTOR3 , " by " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( VECTOR3 , VECTOR3 , Vector3 , rotated , VECTOR3 , " axis " , REAL , " phi " , varray ( ) ) ;
ADDFUNC2R ( VECTOR3 , VECTOR3 , Vector3 , linear_interpolate , VECTOR3 , " b " , REAL , " t " , varray ( ) ) ;
2018-05-12 08:14:39 +08:00
ADDFUNC2R ( VECTOR3 , VECTOR3 , Vector3 , slerp , VECTOR3 , " b " , REAL , " t " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC4R ( VECTOR3 , VECTOR3 , Vector3 , cubic_interpolate , VECTOR3 , " b " , VECTOR3 , " pre_a " , VECTOR3 , " post_b " , REAL , " t " , varray ( ) ) ;
2019-04-08 05:40:56 +08:00
ADDFUNC2R ( VECTOR3 , VECTOR3 , Vector3 , move_toward , VECTOR3 , " to " , REAL , " delta " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( VECTOR3 , REAL , Vector3 , dot , VECTOR3 , " b " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , cross , VECTOR3 , " b " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , BASIS , Vector3 , outer , VECTOR3 , " b " , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , BASIS , Vector3 , to_diagonal_matrix , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , abs , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , floor , varray ( ) ) ;
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , ceil , varray ( ) ) ;
2018-05-04 15:24:48 +08:00
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , round , varray ( ) ) ;
2019-08-05 09:50:28 +08:00
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , posmod , REAL , " mod " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , posmodv , VECTOR3 , " modv " , varray ( ) ) ;
2018-08-16 18:52:38 +08:00
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , project , VECTOR3 , " b " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , slide , VECTOR3 , " n " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , bounce , VECTOR3 , " n " , varray ( ) ) ;
ADDFUNC1R ( VECTOR3 , VECTOR3 , Vector3 , reflect , VECTOR3 , " n " , varray ( ) ) ;
2019-08-05 09:50:28 +08:00
ADDFUNC0R ( VECTOR3 , VECTOR3 , Vector3 , sign , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( PLANE , PLANE , Plane , normalized , varray ( ) ) ;
ADDFUNC0R ( PLANE , VECTOR3 , Plane , center , varray ( ) ) ;
ADDFUNC0R ( PLANE , VECTOR3 , Plane , get_any_point , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( PLANE , BOOL , Plane , is_equal_approx , PLANE , " plane " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( PLANE , BOOL , Plane , is_point_over , VECTOR3 , " point " , varray ( ) ) ;
ADDFUNC1R ( PLANE , REAL , Plane , distance_to , VECTOR3 , " point " , varray ( ) ) ;
ADDFUNC2R ( PLANE , BOOL , Plane , has_point , VECTOR3 , " point " , REAL , " epsilon " , varray ( CMP_EPSILON ) ) ;
ADDFUNC1R ( PLANE , VECTOR3 , Plane , project , VECTOR3 , " point " , varray ( ) ) ;
ADDFUNC2R ( PLANE , VECTOR3 , Plane , intersect_3 , PLANE , " b " , PLANE , " c " , varray ( ) ) ;
ADDFUNC2R ( PLANE , VECTOR3 , Plane , intersects_ray , VECTOR3 , " from " , VECTOR3 , " dir " , varray ( ) ) ;
ADDFUNC2R ( PLANE , VECTOR3 , Plane , intersects_segment , VECTOR3 , " begin " , VECTOR3 , " end " , varray ( ) ) ;
ADDFUNC0R ( QUAT , REAL , Quat , length , varray ( ) ) ;
ADDFUNC0R ( QUAT , REAL , Quat , length_squared , varray ( ) ) ;
ADDFUNC0R ( QUAT , QUAT , Quat , normalized , varray ( ) ) ;
ADDFUNC0R ( QUAT , BOOL , Quat , is_normalized , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( QUAT , BOOL , Quat , is_equal_approx , QUAT , " quat " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( QUAT , QUAT , Quat , inverse , varray ( ) ) ;
ADDFUNC1R ( QUAT , REAL , Quat , dot , QUAT , " b " , varray ( ) ) ;
ADDFUNC1R ( QUAT , VECTOR3 , Quat , xform , VECTOR3 , " v " , varray ( ) ) ;
ADDFUNC2R ( QUAT , QUAT , Quat , slerp , QUAT , " b " , REAL , " t " , varray ( ) ) ;
ADDFUNC2R ( QUAT , QUAT , Quat , slerpni , QUAT , " b " , REAL , " t " , varray ( ) ) ;
ADDFUNC4R ( QUAT , QUAT , Quat , cubic_slerp , QUAT , " b " , QUAT , " pre_a " , QUAT , " post_b " , REAL , " t " , varray ( ) ) ;
2018-05-12 08:14:39 +08:00
ADDFUNC0R ( QUAT , VECTOR3 , Quat , get_euler , varray ( ) ) ;
ADDFUNC1 ( QUAT , NIL , Quat , set_euler , VECTOR3 , " euler " , varray ( ) ) ;
ADDFUNC2 ( QUAT , NIL , Quat , set_axis_angle , VECTOR3 , " axis " , REAL , " angle " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( COLOR , INT , Color , to_argb32 , varray ( ) ) ;
2018-07-26 04:33:42 +08:00
ADDFUNC0R ( COLOR , INT , Color , to_abgr32 , varray ( ) ) ;
ADDFUNC0R ( COLOR , INT , Color , to_rgba32 , varray ( ) ) ;
ADDFUNC0R ( COLOR , INT , Color , to_argb64 , varray ( ) ) ;
ADDFUNC0R ( COLOR , INT , Color , to_abgr64 , varray ( ) ) ;
ADDFUNC0R ( COLOR , INT , Color , to_rgba64 , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( COLOR , COLOR , Color , inverted , varray ( ) ) ;
ADDFUNC0R ( COLOR , COLOR , Color , contrasted , varray ( ) ) ;
ADDFUNC2R ( COLOR , COLOR , Color , linear_interpolate , COLOR , " b " , REAL , " t " , varray ( ) ) ;
ADDFUNC1R ( COLOR , COLOR , Color , blend , COLOR , " over " , varray ( ) ) ;
2017-10-13 12:49:31 +08:00
ADDFUNC1R ( COLOR , COLOR , Color , lightened , REAL , " amount " , varray ( ) ) ;
ADDFUNC1R ( COLOR , COLOR , Color , darkened , REAL , " amount " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( COLOR , STRING , Color , to_html , BOOL , " with_alpha " , varray ( true ) ) ;
2018-01-19 05:03:34 +08:00
ADDFUNC4R ( COLOR , COLOR , Color , from_hsv , REAL , " h " , REAL , " s " , REAL , " v " , REAL , " a " , varray ( 1.0 ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( COLOR , BOOL , Color , is_equal_approx , COLOR , " color " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( _RID , INT , RID , get_id , varray ( ) ) ;
ADDFUNC0R ( NODE_PATH , BOOL , NodePath , is_absolute , varray ( ) ) ;
ADDFUNC0R ( NODE_PATH , INT , NodePath , get_name_count , varray ( ) ) ;
ADDFUNC1R ( NODE_PATH , STRING , NodePath , get_name , INT , " idx " , varray ( ) ) ;
ADDFUNC0R ( NODE_PATH , INT , NodePath , get_subname_count , varray ( ) ) ;
ADDFUNC1R ( NODE_PATH , STRING , NodePath , get_subname , INT , " idx " , varray ( ) ) ;
2017-05-31 04:20:15 +08:00
ADDFUNC0R ( NODE_PATH , STRING , NodePath , get_concatenated_subnames , varray ( ) ) ;
2017-11-22 20:13:56 +08:00
ADDFUNC0R ( NODE_PATH , NODE_PATH , NodePath , get_as_property_path , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( NODE_PATH , BOOL , NodePath , is_empty , varray ( ) ) ;
ADDFUNC0R ( DICTIONARY , INT , Dictionary , size , varray ( ) ) ;
ADDFUNC0R ( DICTIONARY , BOOL , Dictionary , empty , varray ( ) ) ;
2017-09-26 04:08:48 +08:00
ADDFUNC0NC ( DICTIONARY , NIL , Dictionary , clear , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( DICTIONARY , BOOL , Dictionary , has , NIL , " key " , varray ( ) ) ;
ADDFUNC1R ( DICTIONARY , BOOL , Dictionary , has_all , ARRAY , " keys " , varray ( ) ) ;
2018-08-15 01:19:05 +08:00
ADDFUNC1R ( DICTIONARY , BOOL , Dictionary , erase , NIL , " key " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( DICTIONARY , INT , Dictionary , hash , varray ( ) ) ;
ADDFUNC0R ( DICTIONARY , ARRAY , Dictionary , keys , varray ( ) ) ;
ADDFUNC0R ( DICTIONARY , ARRAY , Dictionary , values , varray ( ) ) ;
2018-03-10 03:16:08 +08:00
ADDFUNC1R ( DICTIONARY , DICTIONARY , Dictionary , duplicate , BOOL , " deep " , varray ( false ) ) ;
2018-07-30 12:04:32 +08:00
ADDFUNC2R ( DICTIONARY , NIL , Dictionary , get , NIL , " key " , NIL , " default " , varray ( Variant ( ) ) ) ;
2017-03-05 23:44:50 +08:00
2020-02-20 03:27:19 +08:00
ADDFUNC0R ( CALLABLE , BOOL , Callable , is_null , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , BOOL , Callable , is_custom , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , BOOL , Callable , is_standard , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , OBJECT , Callable , get_object , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , INT , Callable , get_object_id , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , STRING , Callable , get_method , varray ( ) ) ;
ADDFUNC0R ( CALLABLE , INT , Callable , hash , varray ( ) ) ;
ADDFUNC0R ( SIGNAL , BOOL , Signal , is_null , varray ( ) ) ;
ADDFUNC0R ( SIGNAL , OBJECT , Signal , get_object , varray ( ) ) ;
ADDFUNC0R ( SIGNAL , INT , Signal , get_object_id , varray ( ) ) ;
ADDFUNC0R ( SIGNAL , STRING , Signal , get_name , varray ( ) ) ;
ADDFUNC3R ( SIGNAL , INT , Signal , connect , CALLABLE , " callable " , ARRAY , " binds " , INT , " flags " , varray ( Array ( ) , 0 ) ) ;
ADDFUNC1R ( SIGNAL , NIL , Signal , disconnect , CALLABLE , " callable " , varray ( ) ) ;
ADDFUNC1R ( SIGNAL , BOOL , Signal , is_connected , CALLABLE , " callable " , varray ( ) ) ;
ADDFUNC0R ( SIGNAL , ARRAY , Signal , get_connections , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( ARRAY , INT , Array , size , varray ( ) ) ;
ADDFUNC0R ( ARRAY , BOOL , Array , empty , varray ( ) ) ;
2017-09-26 04:08:48 +08:00
ADDFUNC0NC ( ARRAY , NIL , Array , clear , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( ARRAY , INT , Array , hash , varray ( ) ) ;
2017-09-26 04:08:48 +08:00
ADDFUNC1NC ( ARRAY , NIL , Array , push_back , NIL , " value " , varray ( ) ) ;
ADDFUNC1NC ( ARRAY , NIL , Array , push_front , NIL , " value " , varray ( ) ) ;
ADDFUNC1NC ( ARRAY , NIL , Array , append , NIL , " value " , varray ( ) ) ;
ADDFUNC1NC ( ARRAY , NIL , Array , resize , INT , " size " , varray ( ) ) ;
ADDFUNC2NC ( ARRAY , NIL , Array , insert , INT , " position " , NIL , " value " , varray ( ) ) ;
ADDFUNC1NC ( ARRAY , NIL , Array , remove , INT , " position " , varray ( ) ) ;
ADDFUNC1NC ( ARRAY , NIL , Array , erase , NIL , " value " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( ARRAY , NIL , Array , front , varray ( ) ) ;
ADDFUNC0R ( ARRAY , NIL , Array , back , varray ( ) ) ;
ADDFUNC2R ( ARRAY , INT , Array , find , NIL , " what " , INT , " from " , varray ( 0 ) ) ;
ADDFUNC2R ( ARRAY , INT , Array , rfind , NIL , " what " , INT , " from " , varray ( - 1 ) ) ;
ADDFUNC1R ( ARRAY , INT , Array , find_last , NIL , " value " , varray ( ) ) ;
ADDFUNC1R ( ARRAY , INT , Array , count , NIL , " value " , varray ( ) ) ;
ADDFUNC1R ( ARRAY , BOOL , Array , has , NIL , " value " , varray ( ) ) ;
ADDFUNC0RNC ( ARRAY , NIL , Array , pop_back , varray ( ) ) ;
ADDFUNC0RNC ( ARRAY , NIL , Array , pop_front , varray ( ) ) ;
2017-09-26 04:08:48 +08:00
ADDFUNC0NC ( ARRAY , NIL , Array , sort , varray ( ) ) ;
ADDFUNC2NC ( ARRAY , NIL , Array , sort_custom , OBJECT , " obj " , STRING , " func " , varray ( ) ) ;
2018-01-11 02:36:53 +08:00
ADDFUNC0NC ( ARRAY , NIL , Array , shuffle , varray ( ) ) ;
2017-11-03 02:04:38 +08:00
ADDFUNC2R ( ARRAY , INT , Array , bsearch , NIL , " value " , BOOL , " before " , varray ( true ) ) ;
ADDFUNC4R ( ARRAY , INT , Array , bsearch_custom , NIL , " value " , OBJECT , " obj " , STRING , " func " , BOOL , " before " , varray ( true ) ) ;
2017-09-26 04:08:48 +08:00
ADDFUNC0NC ( ARRAY , NIL , Array , invert , varray ( ) ) ;
2018-03-10 03:16:08 +08:00
ADDFUNC1R ( ARRAY , ARRAY , Array , duplicate , BOOL , " deep " , varray ( false ) ) ;
2019-07-17 09:31:58 +08:00
ADDFUNC4R ( ARRAY , ARRAY , Array , slice , INT , " begin " , INT , " end " , INT , " step " , BOOL , " deep " , varray ( 1 , false ) ) ;
2018-08-24 02:31:02 +08:00
ADDFUNC0R ( ARRAY , NIL , Array , max , varray ( ) ) ;
ADDFUNC0R ( ARRAY , NIL , Array , min , varray ( ) ) ;
2017-03-05 23:44:50 +08:00
2020-02-18 05:06:54 +08:00
ADDFUNC0R ( PACKED_BYTE_ARRAY , INT , PackedByteArray , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_BYTE_ARRAY , BOOL , PackedByteArray , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , set , INT , " idx " , INT , " byte " , varray ( ) ) ;
ADDFUNC1 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , push_back , INT , " byte " , varray ( ) ) ;
ADDFUNC1 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , append , INT , " byte " , varray ( ) ) ;
ADDFUNC1 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , append_array , PACKED_BYTE_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_BYTE_ARRAY , INT , PackedByteArray , insert , INT , " idx " , INT , " byte " , varray ( ) ) ;
ADDFUNC1 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_BYTE_ARRAY , NIL , PackedByteArray , invert , varray ( ) ) ;
ADDFUNC2R ( PACKED_BYTE_ARRAY , PACKED_BYTE_ARRAY , PackedByteArray , subarray , INT , " from " , INT , " to " , varray ( ) ) ;
ADDFUNC0R ( PACKED_BYTE_ARRAY , STRING , PackedByteArray , get_string_from_ascii , varray ( ) ) ;
ADDFUNC0R ( PACKED_BYTE_ARRAY , STRING , PackedByteArray , get_string_from_utf8 , varray ( ) ) ;
ADDFUNC0R ( PACKED_BYTE_ARRAY , STRING , PackedByteArray , hex_encode , varray ( ) ) ;
ADDFUNC1R ( PACKED_BYTE_ARRAY , PACKED_BYTE_ARRAY , PackedByteArray , compress , INT , " compression_mode " , varray ( 0 ) ) ;
ADDFUNC2R ( PACKED_BYTE_ARRAY , PACKED_BYTE_ARRAY , PackedByteArray , decompress , INT , " buffer_size " , INT , " compression_mode " , varray ( 0 ) ) ;
ADDFUNC0R ( PACKED_INT_ARRAY , INT , PackedIntArray , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_INT_ARRAY , BOOL , PackedIntArray , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_INT_ARRAY , NIL , PackedIntArray , set , INT , " idx " , INT , " integer " , varray ( ) ) ;
ADDFUNC1 ( PACKED_INT_ARRAY , NIL , PackedIntArray , push_back , INT , " integer " , varray ( ) ) ;
ADDFUNC1 ( PACKED_INT_ARRAY , NIL , PackedIntArray , append , INT , " integer " , varray ( ) ) ;
ADDFUNC1 ( PACKED_INT_ARRAY , NIL , PackedIntArray , append_array , PACKED_INT_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_INT_ARRAY , NIL , PackedIntArray , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_INT_ARRAY , INT , PackedIntArray , insert , INT , " idx " , INT , " integer " , varray ( ) ) ;
ADDFUNC1 ( PACKED_INT_ARRAY , NIL , PackedIntArray , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_INT_ARRAY , NIL , PackedIntArray , invert , varray ( ) ) ;
ADDFUNC0R ( PACKED_REAL_ARRAY , INT , PackedRealArray , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_REAL_ARRAY , BOOL , PackedRealArray , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , set , INT , " idx " , REAL , " value " , varray ( ) ) ;
ADDFUNC1 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , push_back , REAL , " value " , varray ( ) ) ;
ADDFUNC1 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , append , REAL , " value " , varray ( ) ) ;
ADDFUNC1 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , append_array , PACKED_REAL_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_REAL_ARRAY , INT , PackedRealArray , insert , INT , " idx " , REAL , " value " , varray ( ) ) ;
ADDFUNC1 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_REAL_ARRAY , NIL , PackedRealArray , invert , varray ( ) ) ;
ADDFUNC0R ( PACKED_STRING_ARRAY , INT , PackedStringArray , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_STRING_ARRAY , BOOL , PackedStringArray , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , set , INT , " idx " , STRING , " string " , varray ( ) ) ;
ADDFUNC1 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , push_back , STRING , " string " , varray ( ) ) ;
ADDFUNC1 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , append , STRING , " string " , varray ( ) ) ;
ADDFUNC1 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , append_array , PACKED_STRING_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_STRING_ARRAY , INT , PackedStringArray , insert , INT , " idx " , STRING , " string " , varray ( ) ) ;
ADDFUNC1 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_STRING_ARRAY , NIL , PackedStringArray , invert , varray ( ) ) ;
ADDFUNC0R ( PACKED_VECTOR2_ARRAY , INT , PackedVector2Array , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_VECTOR2_ARRAY , BOOL , PackedVector2Array , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , set , INT , " idx " , VECTOR2 , " vector2 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , push_back , VECTOR2 , " vector2 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , append , VECTOR2 , " vector2 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , append_array , PACKED_VECTOR2_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_VECTOR2_ARRAY , INT , PackedVector2Array , insert , INT , " idx " , VECTOR2 , " vector2 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_VECTOR2_ARRAY , NIL , PackedVector2Array , invert , varray ( ) ) ;
ADDFUNC0R ( PACKED_VECTOR3_ARRAY , INT , PackedVector3Array , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_VECTOR3_ARRAY , BOOL , PackedVector3Array , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , set , INT , " idx " , VECTOR3 , " vector3 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , push_back , VECTOR3 , " vector3 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , append , VECTOR3 , " vector3 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , append_array , PACKED_VECTOR3_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_VECTOR3_ARRAY , INT , PackedVector3Array , insert , INT , " idx " , VECTOR3 , " vector3 " , varray ( ) ) ;
ADDFUNC1 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_VECTOR3_ARRAY , NIL , PackedVector3Array , invert , varray ( ) ) ;
ADDFUNC0R ( PACKED_COLOR_ARRAY , INT , PackedColorArray , size , varray ( ) ) ;
ADDFUNC0R ( PACKED_COLOR_ARRAY , BOOL , PackedColorArray , empty , varray ( ) ) ;
ADDFUNC2 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , set , INT , " idx " , COLOR , " color " , varray ( ) ) ;
ADDFUNC1 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , push_back , COLOR , " color " , varray ( ) ) ;
ADDFUNC1 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , append , COLOR , " color " , varray ( ) ) ;
ADDFUNC1 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , append_array , PACKED_COLOR_ARRAY , " array " , varray ( ) ) ;
ADDFUNC1 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , remove , INT , " idx " , varray ( ) ) ;
ADDFUNC2R ( PACKED_COLOR_ARRAY , INT , PackedColorArray , insert , INT , " idx " , COLOR , " color " , varray ( ) ) ;
ADDFUNC1 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , resize , INT , " idx " , varray ( ) ) ;
ADDFUNC0 ( PACKED_COLOR_ARRAY , NIL , PackedColorArray , invert , varray ( ) ) ;
2014-02-10 09:10:30 +08:00
//pointerbased
2017-11-17 10:09:00 +08:00
ADDFUNC0R ( AABB , REAL , AABB , get_area , varray ( ) ) ;
ADDFUNC0R ( AABB , BOOL , AABB , has_no_area , varray ( ) ) ;
ADDFUNC0R ( AABB , BOOL , AABB , has_no_surface , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( AABB , BOOL , AABB , has_point , VECTOR3 , " point " , varray ( ) ) ;
ADDFUNC1R ( AABB , BOOL , AABB , is_equal_approx , AABB , " aabb " , varray ( ) ) ;
2017-11-17 10:09:00 +08:00
ADDFUNC1R ( AABB , BOOL , AABB , intersects , AABB , " with " , varray ( ) ) ;
ADDFUNC1R ( AABB , BOOL , AABB , encloses , AABB , " with " , varray ( ) ) ;
ADDFUNC1R ( AABB , BOOL , AABB , intersects_plane , PLANE , " plane " , varray ( ) ) ;
ADDFUNC2R ( AABB , BOOL , AABB , intersects_segment , VECTOR3 , " from " , VECTOR3 , " to " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( AABB , AABB , AABB , intersection , AABB , " with " , varray ( ) ) ;
ADDFUNC1R ( AABB , AABB , AABB , merge , AABB , " with " , varray ( ) ) ;
ADDFUNC1R ( AABB , AABB , AABB , expand , VECTOR3 , " to_point " , varray ( ) ) ;
ADDFUNC1R ( AABB , AABB , AABB , grow , REAL , " by " , varray ( ) ) ;
2017-11-17 10:09:00 +08:00
ADDFUNC1R ( AABB , VECTOR3 , AABB , get_support , VECTOR3 , " dir " , varray ( ) ) ;
ADDFUNC0R ( AABB , VECTOR3 , AABB , get_longest_axis , varray ( ) ) ;
ADDFUNC0R ( AABB , INT , AABB , get_longest_axis_index , varray ( ) ) ;
ADDFUNC0R ( AABB , REAL , AABB , get_longest_axis_size , varray ( ) ) ;
ADDFUNC0R ( AABB , VECTOR3 , AABB , get_shortest_axis , varray ( ) ) ;
ADDFUNC0R ( AABB , INT , AABB , get_shortest_axis_index , varray ( ) ) ;
ADDFUNC0R ( AABB , REAL , AABB , get_shortest_axis_size , varray ( ) ) ;
ADDFUNC1R ( AABB , VECTOR3 , AABB , get_endpoint , INT , " idx " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( TRANSFORM2D , TRANSFORM2D , Transform2D , inverse , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM2D , TRANSFORM2D , Transform2D , affine_inverse , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM2D , REAL , Transform2D , get_rotation , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM2D , VECTOR2 , Transform2D , get_origin , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM2D , VECTOR2 , Transform2D , get_scale , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM2D , TRANSFORM2D , Transform2D , orthonormalized , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , TRANSFORM2D , Transform2D , rotated , REAL , " phi " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , TRANSFORM2D , Transform2D , scaled , VECTOR2 , " scale " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , TRANSFORM2D , Transform2D , translated , VECTOR2 , " offset " , varray ( ) ) ;
2018-01-30 19:45:54 +08:00
ADDFUNC1R ( TRANSFORM2D , NIL , Transform2D , xform , NIL , " v " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , NIL , Transform2D , xform_inv , NIL , " v " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , VECTOR2 , Transform2D , basis_xform , VECTOR2 , " v " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM2D , VECTOR2 , Transform2D , basis_xform_inv , VECTOR2 , " v " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( TRANSFORM2D , TRANSFORM2D , Transform2D , interpolate_with , TRANSFORM2D , " transform " , REAL , " weight " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( TRANSFORM2D , BOOL , Transform2D , is_equal_approx , TRANSFORM2D , " transform " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( BASIS , BASIS , Basis , inverse , varray ( ) ) ;
ADDFUNC0R ( BASIS , BASIS , Basis , transposed , varray ( ) ) ;
ADDFUNC0R ( BASIS , BASIS , Basis , orthonormalized , varray ( ) ) ;
ADDFUNC0R ( BASIS , REAL , Basis , determinant , varray ( ) ) ;
ADDFUNC2R ( BASIS , BASIS , Basis , rotated , VECTOR3 , " axis " , REAL , " phi " , varray ( ) ) ;
ADDFUNC1R ( BASIS , BASIS , Basis , scaled , VECTOR3 , " scale " , varray ( ) ) ;
ADDFUNC0R ( BASIS , VECTOR3 , Basis , get_scale , varray ( ) ) ;
ADDFUNC0R ( BASIS , VECTOR3 , Basis , get_euler , varray ( ) ) ;
ADDFUNC1R ( BASIS , REAL , Basis , tdotx , VECTOR3 , " with " , varray ( ) ) ;
ADDFUNC1R ( BASIS , REAL , Basis , tdoty , VECTOR3 , " with " , varray ( ) ) ;
ADDFUNC1R ( BASIS , REAL , Basis , tdotz , VECTOR3 , " with " , varray ( ) ) ;
ADDFUNC1R ( BASIS , VECTOR3 , Basis , xform , VECTOR3 , " v " , varray ( ) ) ;
ADDFUNC1R ( BASIS , VECTOR3 , Basis , xform_inv , VECTOR3 , " v " , varray ( ) ) ;
ADDFUNC0R ( BASIS , INT , Basis , get_orthogonal_index , varray ( ) ) ;
2018-05-28 20:53:15 +08:00
ADDFUNC2R ( BASIS , BASIS , Basis , slerp , BASIS , " b " , REAL , " t " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC2R ( BASIS , BOOL , Basis , is_equal_approx , BASIS , " b " , REAL , " epsilon " , varray ( CMP_EPSILON ) ) ; // TODO: Replace in 4.0, see other TODO.
2019-04-01 22:11:02 +08:00
ADDFUNC0R ( BASIS , QUAT , Basis , get_rotation_quat , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC0R ( TRANSFORM , TRANSFORM , Transform , inverse , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM , TRANSFORM , Transform , affine_inverse , varray ( ) ) ;
ADDFUNC0R ( TRANSFORM , TRANSFORM , Transform , orthonormalized , varray ( ) ) ;
ADDFUNC2R ( TRANSFORM , TRANSFORM , Transform , rotated , VECTOR3 , " axis " , REAL , " phi " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM , TRANSFORM , Transform , scaled , VECTOR3 , " scale " , varray ( ) ) ;
2019-12-14 04:23:26 +08:00
ADDFUNC1R ( TRANSFORM , TRANSFORM , Transform , translated , VECTOR3 , " offset " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC2R ( TRANSFORM , TRANSFORM , Transform , looking_at , VECTOR3 , " target " , VECTOR3 , " up " , varray ( ) ) ;
ADDFUNC2R ( TRANSFORM , TRANSFORM , Transform , interpolate_with , TRANSFORM , " transform " , REAL , " weight " , varray ( ) ) ;
2019-10-03 04:35:49 +08:00
ADDFUNC1R ( TRANSFORM , BOOL , Transform , is_equal_approx , TRANSFORM , " transform " , varray ( ) ) ;
2017-10-23 01:08:16 +08:00
ADDFUNC1R ( TRANSFORM , NIL , Transform , xform , NIL , " v " , varray ( ) ) ;
ADDFUNC1R ( TRANSFORM , NIL , Transform , xform_inv , NIL , " v " , varray ( ) ) ;
2014-02-10 09:10:30 +08:00
/* REGISTER CONSTRUCTORS */
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Vector2_init1 , Variant : : VECTOR2 , " x " , Variant : : REAL , " y " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-09-10 21:37:49 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Rect2_init1 , Variant : : RECT2 , " position " , Variant : : VECTOR2 , " size " , Variant : : VECTOR2 ) ;
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Rect2_init2 , Variant : : RECT2 , " x " , Variant : : REAL , " y " , Variant : : REAL , " width " , Variant : : REAL , " height " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-09-10 21:37:49 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Transform2D_init2 , Variant : : TRANSFORM2D , " rotation " , Variant : : REAL , " position " , Variant : : VECTOR2 ) ;
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Transform2D_init3 , Variant : : TRANSFORM2D , " x_axis " , Variant : : VECTOR2 , " y_axis " , Variant : : VECTOR2 , " origin " , Variant : : VECTOR2 ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Vector3_init1 , Variant : : VECTOR3 , " x " , Variant : : REAL , " y " , Variant : : REAL , " z " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Plane_init1 , Variant : : PLANE , " a " , Variant : : REAL , " b " , Variant : : REAL , " c " , Variant : : REAL , " d " , Variant : : REAL ) ;
_VariantCall : : add_constructor ( _VariantCall : : Plane_init2 , Variant : : PLANE , " v1 " , Variant : : VECTOR3 , " v2 " , Variant : : VECTOR3 , " v3 " , Variant : : VECTOR3 ) ;
_VariantCall : : add_constructor ( _VariantCall : : Plane_init3 , Variant : : PLANE , " normal " , Variant : : VECTOR3 , " d " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Quat_init1 , Variant : : QUAT , " x " , Variant : : REAL , " y " , Variant : : REAL , " z " , Variant : : REAL , " w " , Variant : : REAL ) ;
_VariantCall : : add_constructor ( _VariantCall : : Quat_init2 , Variant : : QUAT , " axis " , Variant : : VECTOR3 , " angle " , Variant : : REAL ) ;
2018-05-12 08:14:39 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Quat_init3 , Variant : : QUAT , " euler " , Variant : : VECTOR3 ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Color_init1 , Variant : : COLOR , " r " , Variant : : REAL , " g " , Variant : : REAL , " b " , Variant : : REAL , " a " , Variant : : REAL ) ;
_VariantCall : : add_constructor ( _VariantCall : : Color_init2 , Variant : : COLOR , " r " , Variant : : REAL , " g " , Variant : : REAL , " b " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-11-17 10:09:00 +08:00
_VariantCall : : add_constructor ( _VariantCall : : AABB_init1 , Variant : : AABB , " position " , Variant : : VECTOR3 , " size " , Variant : : VECTOR3 ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Basis_init1 , Variant : : BASIS , " x_axis " , Variant : : VECTOR3 , " y_axis " , Variant : : VECTOR3 , " z_axis " , Variant : : VECTOR3 ) ;
_VariantCall : : add_constructor ( _VariantCall : : Basis_init2 , Variant : : BASIS , " axis " , Variant : : VECTOR3 , " phi " , Variant : : REAL ) ;
2014-02-10 09:10:30 +08:00
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Transform_init1 , Variant : : TRANSFORM , " x_axis " , Variant : : VECTOR3 , " y_axis " , Variant : : VECTOR3 , " z_axis " , Variant : : VECTOR3 , " origin " , Variant : : VECTOR3 ) ;
_VariantCall : : add_constructor ( _VariantCall : : Transform_init2 , Variant : : TRANSFORM , " basis " , Variant : : BASIS , " origin " , Variant : : VECTOR3 ) ;
2014-02-10 09:10:30 +08:00
2020-02-20 03:27:19 +08:00
_VariantCall : : add_constructor ( _VariantCall : : Callable_init2 , Variant : : CALLABLE , " object " , Variant : : OBJECT , " method_name " , Variant : : STRING ) ;
_VariantCall : : add_constructor ( _VariantCall : : Signal_init2 , Variant : : SIGNAL , " object " , Variant : : OBJECT , " signal_name " , Variant : : STRING ) ;
2014-02-10 09:10:30 +08:00
/* REGISTER CONSTANTS */
2017-12-15 23:43:27 +08:00
_populate_named_colors ( ) ;
for ( Map < String , Color > : : Element * color = _named_colors . front ( ) ; color ; color = color - > next ( ) ) {
_VariantCall : : add_variant_constant ( Variant : : COLOR , color - > key ( ) , color - > value ( ) ) ;
}
2017-03-05 23:44:50 +08:00
_VariantCall : : add_constant ( Variant : : VECTOR3 , " AXIS_X " , Vector3 : : AXIS_X ) ;
_VariantCall : : add_constant ( Variant : : VECTOR3 , " AXIS_Y " , Vector3 : : AXIS_Y ) ;
_VariantCall : : add_constant ( Variant : : VECTOR3 , " AXIS_Z " , Vector3 : : AXIS_Z ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " ZERO " , Vector3 ( 0 , 0 , 0 ) ) ;
2018-10-07 02:13:41 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " ONE " , Vector3 ( 1 , 1 , 1 ) ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " INF " , Vector3 ( Math_INF , Math_INF , Math_INF ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " LEFT " , Vector3 ( - 1 , 0 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " RIGHT " , Vector3 ( 1 , 0 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " UP " , Vector3 ( 0 , 1 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " DOWN " , Vector3 ( 0 , - 1 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " FORWARD " , Vector3 ( 0 , 0 , - 1 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR3 , " BACK " , Vector3 ( 0 , 0 , 1 ) ) ;
2019-08-05 09:50:28 +08:00
_VariantCall : : add_constant ( Variant : : VECTOR2 , " AXIS_X " , Vector2 : : AXIS_X ) ;
_VariantCall : : add_constant ( Variant : : VECTOR2 , " AXIS_Y " , Vector2 : : AXIS_Y ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " ZERO " , Vector2 ( 0 , 0 ) ) ;
2018-10-07 02:13:41 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " ONE " , Vector2 ( 1 , 1 ) ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " INF " , Vector2 ( Math_INF , Math_INF ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " LEFT " , Vector2 ( - 1 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " RIGHT " , Vector2 ( 1 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " UP " , Vector2 ( 0 , - 1 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : VECTOR2 , " DOWN " , Vector2 ( 0 , 1 ) ) ;
2019-08-09 11:29:45 +08:00
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM2D , " IDENTITY " , Transform2D ( ) ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM2D , " FLIP_X " , Transform2D ( - 1 , 0 , 0 , 1 , 0 , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM2D , " FLIP_Y " , Transform2D ( 1 , 0 , 0 , - 1 , 0 , 0 ) ) ;
2019-08-09 11:29:45 +08:00
Transform identity_transform = Transform ( ) ;
Transform flip_x_transform = Transform ( - 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 ) ;
Transform flip_y_transform = Transform ( 1 , 0 , 0 , 0 , - 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 ) ;
Transform flip_z_transform = Transform ( 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , - 1 , 0 , 0 , 0 ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM , " IDENTITY " , identity_transform ) ;
2019-08-09 11:29:45 +08:00
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM , " FLIP_X " , flip_x_transform ) ;
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM , " FLIP_Y " , flip_y_transform ) ;
_VariantCall : : add_variant_constant ( Variant : : TRANSFORM , " FLIP_Z " , flip_z_transform ) ;
Basis identity_basis = Basis ( ) ;
Basis flip_x_basis = Basis ( - 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , 1 ) ;
Basis flip_y_basis = Basis ( 1 , 0 , 0 , 0 , - 1 , 0 , 0 , 0 , 1 ) ;
Basis flip_z_basis = Basis ( 1 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , - 1 ) ;
_VariantCall : : add_variant_constant ( Variant : : BASIS , " IDENTITY " , identity_basis ) ;
_VariantCall : : add_variant_constant ( Variant : : BASIS , " FLIP_X " , flip_x_basis ) ;
_VariantCall : : add_variant_constant ( Variant : : BASIS , " FLIP_Y " , flip_y_basis ) ;
_VariantCall : : add_variant_constant ( Variant : : BASIS , " FLIP_Z " , flip_z_basis ) ;
2017-12-15 23:43:27 +08:00
2018-08-21 13:34:34 +08:00
_VariantCall : : add_variant_constant ( Variant : : PLANE , " PLANE_YZ " , Plane ( Vector3 ( 1 , 0 , 0 ) , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : PLANE , " PLANE_XZ " , Plane ( Vector3 ( 0 , 1 , 0 ) , 0 ) ) ;
_VariantCall : : add_variant_constant ( Variant : : PLANE , " PLANE_XY " , Plane ( Vector3 ( 0 , 0 , 1 ) , 0 ) ) ;
2017-12-15 23:43:27 +08:00
_VariantCall : : add_variant_constant ( Variant : : QUAT , " IDENTITY " , Quat ( 0 , 0 , 0 , 1 ) ) ;
2014-02-10 09:10:30 +08:00
}
void unregister_variant_methods ( ) {
memdelete_arr ( _VariantCall : : type_funcs ) ;
memdelete_arr ( _VariantCall : : construct_funcs ) ;
2017-03-05 23:44:50 +08:00
memdelete_arr ( _VariantCall : : constant_data ) ;
2014-02-10 09:10:30 +08:00
}