diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2017-03-05 16:44:50 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2017-03-05 16:44:50 +0100 |
commit | 5dbf1809c6e3e905b94b8764e99491e608122261 (patch) | |
tree | 5e5a5360db15d86d59ec8c6e4f7eb511388c5a9a /core/variant.h | |
parent | 45438e9918d421b244bfd7776a30e67dc7f2d3e3 (diff) | |
download | redot-engine-5dbf1809c6e3e905b94b8764e99491e608122261.tar.gz |
A Whole New World (clang-format edition)
I can show you the code
Pretty, with proper whitespace
Tell me, coder, now when did
You last write readable code?
I can open your eyes
Make you see your bad indent
Force you to respect the style
The core devs agreed upon
A whole new world
A new fantastic code format
A de facto standard
With some sugar
Enforced with clang-format
A whole new world
A dazzling style we all dreamed of
And when we read it through
It's crystal clear
That now we're in a whole new world of code
Diffstat (limited to 'core/variant.h')
-rw-r--r-- | core/variant.h | 280 |
1 files changed, 131 insertions, 149 deletions
diff --git a/core/variant.h b/core/variant.h index f0c0d65852..c9f7ada3ac 100644 --- a/core/variant.h +++ b/core/variant.h @@ -33,27 +33,27 @@ @author Juan Linietsky <reduzio@gmail.com> */ -#include "rect3.h" -#include "ustring.h" -#include "vector3.h" -#include "plane.h" -#include "quat.h" -#include "matrix3.h" -#include "transform.h" -#include "image.h" +#include "array.h" +#include "color.h" +#include "dictionary.h" #include "dvector.h" -#include "path_db.h" -#include "simple_type.h" +#include "face3.h" +#include "image.h" +#include "io/ip_address.h" +#include "math_2d.h" +#include "matrix3.h" #include "os/input_event.h" #include "os/power.h" -#include "color.h" -#include "face3.h" +#include "path_db.h" +#include "plane.h" +#include "quat.h" +#include "rect3.h" #include "ref_ptr.h" -#include "math_2d.h" #include "rid.h" -#include "io/ip_address.h" -#include "dictionary.h" -#include "array.h" +#include "simple_type.h" +#include "transform.h" +#include "ustring.h" +#include "vector3.h" class RefPtr; class Object; @@ -63,7 +63,6 @@ class Control; // helper struct PropertyInfo; struct MethodInfo; - typedef PoolVector<uint8_t> PoolByteArray; typedef PoolVector<int> PoolIntArray; typedef PoolVector<real_t> PoolRealArray; @@ -74,7 +73,6 @@ typedef PoolVector<Color> PoolColorArray; class Variant { public: - enum Type { NIL, @@ -87,31 +85,31 @@ public: // math types - VECTOR2, // 5 + VECTOR2, // 5 RECT2, VECTOR3, TRANSFORM2D, PLANE, - QUAT, // 10 + QUAT, // 10 RECT3, //sorry naming convention fail :( not like it's used often BASIS, TRANSFORM, // misc types COLOR, - IMAGE, // 15 + IMAGE, // 15 NODE_PATH, _RID, OBJECT, INPUT_EVENT, - DICTIONARY, // 20 + DICTIONARY, // 20 ARRAY, // arrays POOL_BYTE_ARRAY, POOL_INT_ARRAY, POOL_REAL_ARRAY, - POOL_STRING_ARRAY, // 25 + POOL_STRING_ARRAY, // 25 POOL_VECTOR2_ARRAY, POOL_VECTOR3_ARRAY, POOL_COLOR_ARRAY, @@ -121,8 +119,6 @@ public: }; private: - - friend class _VariantCall; // Variant takes 20 bytes when real_t is float, and 36 if double // it only allocates extra memory for aabb/matrix. @@ -135,9 +131,8 @@ private: RefPtr ref; }; - - _FORCE_INLINE_ ObjData& _get_obj(); - _FORCE_INLINE_ const ObjData& _get_obj() const; + _FORCE_INLINE_ ObjData &_get_obj(); + _FORCE_INLINE_ const ObjData &_get_obj() const; union { @@ -145,29 +140,26 @@ private: int64_t _int; double _real; Transform2D *_transform2d; - Rect3* _rect3; + Rect3 *_rect3; Basis *_basis; Transform *_transform; RefPtr *_resource; InputEvent *_input_event; Image *_image; void *_ptr; //generic pointer - uint8_t _mem[sizeof(ObjData) > (sizeof(real_t)*4) ? sizeof(ObjData) : (sizeof(real_t)*4)]; + uint8_t _mem[sizeof(ObjData) > (sizeof(real_t) * 4) ? sizeof(ObjData) : (sizeof(real_t) * 4)]; } _data; - - void reference(const Variant& p_variant); + void reference(const Variant &p_variant); void clear(); -public: +public: _FORCE_INLINE_ Type get_type() const { return type; } static String get_type_name(Variant::Type p_type); static bool can_convert(Type p_type_from, Type p_type_to); static bool can_convert_strict(Type p_type_from, Type p_type_to); - - - template<class T> + template <class T> static Type get_type_for() { GetSimpleType<T> t; @@ -176,10 +168,9 @@ public: return r; } - bool is_ref() const; - _FORCE_INLINE_ bool is_num() const { return type==INT || type==REAL; }; - _FORCE_INLINE_ bool is_array() const { return type>=ARRAY; }; + _FORCE_INLINE_ bool is_num() const { return type == INT || type == REAL; }; + _FORCE_INLINE_ bool is_array() const { return type >= ARRAY; }; bool is_shared() const; bool is_zero() const; bool is_one() const; @@ -199,7 +190,6 @@ public: operator unsigned long() const; #endif - operator CharType() const; operator float() const; operator double() const; @@ -221,9 +211,9 @@ public: operator RefPtr() const; operator RID() const; operator InputEvent() const; - operator Object*() const; - operator Node*() const; - operator Control*() const; + operator Object *() const; + operator Node *() const; + operator Control *() const; operator Dictionary() const; operator Array() const; @@ -237,7 +227,6 @@ public: operator PoolVector<Plane>() const; operator PoolVector<Face3>() const; - operator Vector<Variant>() const; operator Vector<uint8_t>() const; operator Vector<int>() const; @@ -256,14 +245,13 @@ public: operator IP_Address() const; - Variant(bool p_bool); Variant(signed int p_int); // real one Variant(unsigned int p_int); #ifdef NEED_LONG_INT Variant(signed long p_long); // real one Variant(unsigned long p_long); - //Variant(long unsigned int p_long); +//Variant(long unsigned int p_long); #endif Variant(signed short p_short); // real one Variant(unsigned short p_short); @@ -273,54 +261,51 @@ public: Variant(uint64_t p_char); Variant(float p_float); Variant(double p_double); - Variant(const String& p_string); - Variant(const StringName& p_string); - Variant(const char * const p_cstring); - Variant(const CharType * p_wstring); - Variant(const Vector2& p_vector2); - Variant(const Rect2& p_rect2); - Variant(const Vector3& p_vector3); - Variant(const Plane& p_plane); - Variant(const Rect3& p_aabb); - Variant(const Quat& p_quat); - Variant(const Basis& p_transform); - Variant(const Transform2D& p_transform); - Variant(const Transform& p_transform); - Variant(const Color& p_color); - Variant(const Image& p_image); - Variant(const NodePath& p_path); - Variant(const RefPtr& p_resource); - Variant(const RID& p_rid); - Variant(const Object* p_object); - Variant(const InputEvent& p_input_event); - Variant(const Dictionary& p_dictionary); - - Variant(const Array& p_array); - Variant(const PoolVector<Plane>& p_array); // helper - Variant(const PoolVector<uint8_t>& p_raw_array); - Variant(const PoolVector<int>& p_int_array); - Variant(const PoolVector<real_t>& p_real_array); - Variant(const PoolVector<String>& p_string_array); - Variant(const PoolVector<Vector3>& p_vector3_array); - Variant(const PoolVector<Color>& p_color_array); - Variant(const PoolVector<Face3>& p_face_array); - - - Variant(const Vector<Variant>& p_array); - Variant(const Vector<uint8_t>& p_raw_array); - Variant(const Vector<int>& p_int_array); - Variant(const Vector<real_t>& p_real_array); - Variant(const Vector<String>& p_string_array); - Variant(const Vector<Vector3>& p_vector3_array); - Variant(const Vector<Color>& p_color_array); - Variant(const Vector<Plane>& p_array); // helper - Variant(const Vector<RID>& p_array); // helper - Variant(const Vector<Vector2>& p_array); // helper - Variant(const PoolVector<Vector2>& p_array); // helper - - Variant(const IP_Address& p_address); - - + Variant(const String &p_string); + Variant(const StringName &p_string); + Variant(const char *const p_cstring); + Variant(const CharType *p_wstring); + Variant(const Vector2 &p_vector2); + Variant(const Rect2 &p_rect2); + Variant(const Vector3 &p_vector3); + Variant(const Plane &p_plane); + Variant(const Rect3 &p_aabb); + Variant(const Quat &p_quat); + Variant(const Basis &p_transform); + Variant(const Transform2D &p_transform); + Variant(const Transform &p_transform); + Variant(const Color &p_color); + Variant(const Image &p_image); + Variant(const NodePath &p_path); + Variant(const RefPtr &p_resource); + Variant(const RID &p_rid); + Variant(const Object *p_object); + Variant(const InputEvent &p_input_event); + Variant(const Dictionary &p_dictionary); + + Variant(const Array &p_array); + Variant(const PoolVector<Plane> &p_array); // helper + Variant(const PoolVector<uint8_t> &p_raw_array); + Variant(const PoolVector<int> &p_int_array); + Variant(const PoolVector<real_t> &p_real_array); + Variant(const PoolVector<String> &p_string_array); + Variant(const PoolVector<Vector3> &p_vector3_array); + Variant(const PoolVector<Color> &p_color_array); + Variant(const PoolVector<Face3> &p_face_array); + + Variant(const Vector<Variant> &p_array); + Variant(const Vector<uint8_t> &p_raw_array); + Variant(const Vector<int> &p_int_array); + Variant(const Vector<real_t> &p_real_array); + Variant(const Vector<String> &p_string_array); + Variant(const Vector<Vector3> &p_vector3_array); + Variant(const Vector<Color> &p_color_array); + Variant(const Vector<Plane> &p_array); // helper + Variant(const Vector<RID> &p_array); // helper + Variant(const Vector<Vector2> &p_array); // helper + Variant(const PoolVector<Vector2> &p_array); // helper + + Variant(const IP_Address &p_address); enum Operator { @@ -358,20 +343,19 @@ public: }; - static String get_operator_name(Operator p_op); - static void evaluate(const Operator& p_op,const Variant& p_a, const Variant& p_b,Variant &r_ret,bool &r_valid); - static _FORCE_INLINE_ Variant evaluate(const Operator& p_op,const Variant& p_a, const Variant& p_b) { + static void evaluate(const Operator &p_op, const Variant &p_a, const Variant &p_b, Variant &r_ret, bool &r_valid); + static _FORCE_INLINE_ Variant evaluate(const Operator &p_op, const Variant &p_a, const Variant &p_b) { - bool valid=true; + bool valid = true; Variant res; - evaluate(p_op,p_a,p_b,res,valid); + evaluate(p_op, p_a, p_b, res, valid); return res; } void zero(); - static void blend(const Variant& a, const Variant& b, float c,Variant &r_dst); - static void interpolate(const Variant& a, const Variant& b, float c,Variant &r_dst); + static void blend(const Variant &a, const Variant &b, float c, Variant &r_dst); + static void interpolate(const Variant &a, const Variant &b, float c, Variant &r_dst); struct CallError { enum Error { @@ -387,95 +371,93 @@ public: Type expected; }; - void call_ptr(const StringName& p_method,const Variant** p_args,int p_argcount,Variant* r_ret,CallError &r_error); - Variant call(const StringName& p_method,const Variant** p_args,int p_argcount,CallError &r_error); - Variant call(const StringName& p_method,const Variant& p_arg1=Variant(),const Variant& p_arg2=Variant(),const Variant& p_arg3=Variant(),const Variant& p_arg4=Variant(),const Variant& p_arg5=Variant()); + void call_ptr(const StringName &p_method, const Variant **p_args, int p_argcount, Variant *r_ret, CallError &r_error); + Variant call(const StringName &p_method, const Variant **p_args, int p_argcount, CallError &r_error); + Variant call(const StringName &p_method, const Variant &p_arg1 = Variant(), const Variant &p_arg2 = Variant(), const Variant &p_arg3 = Variant(), const Variant &p_arg4 = Variant(), const Variant &p_arg5 = Variant()); - static String get_call_error_text(Object* p_base, const StringName& p_method,const Variant** p_argptrs,int p_argcount,const Variant::CallError &ce); + static String get_call_error_text(Object *p_base, const StringName &p_method, const Variant **p_argptrs, int p_argcount, const Variant::CallError &ce); - static Variant construct(const Variant::Type,const Variant** p_args,int p_argcount,CallError &r_error,bool p_strict=true); + static Variant construct(const Variant::Type, const Variant **p_args, int p_argcount, CallError &r_error, bool p_strict = true); void get_method_list(List<MethodInfo> *p_list) const; - bool has_method(const StringName& p_method) const; - static Vector<Variant::Type> get_method_argument_types(Variant::Type p_type,const StringName& p_method); - static Vector<Variant> get_method_default_arguments(Variant::Type p_type,const StringName& p_method); - static Variant::Type get_method_return_type(Variant::Type p_type,const StringName& p_method,bool* r_has_return=NULL); - static Vector<StringName> get_method_argument_names(Variant::Type p_type,const StringName& p_method); + bool has_method(const StringName &p_method) const; + static Vector<Variant::Type> get_method_argument_types(Variant::Type p_type, const StringName &p_method); + static Vector<Variant> get_method_default_arguments(Variant::Type p_type, const StringName &p_method); + static Variant::Type get_method_return_type(Variant::Type p_type, const StringName &p_method, bool *r_has_return = NULL); + static Vector<StringName> get_method_argument_names(Variant::Type p_type, const StringName &p_method); - void set_named(const StringName& p_index, const Variant& p_value, bool *r_valid=NULL); - Variant get_named(const StringName& p_index, bool *r_valid=NULL) const; + void set_named(const StringName &p_index, const Variant &p_value, bool *r_valid = NULL); + Variant get_named(const StringName &p_index, bool *r_valid = NULL) const; - void set(const Variant& p_index, const Variant& p_value, bool *r_valid=NULL); - Variant get(const Variant& p_index, bool *r_valid=NULL) const; - bool in(const Variant& p_index, bool *r_valid=NULL) const; + void set(const Variant &p_index, const Variant &p_value, bool *r_valid = NULL); + Variant get(const Variant &p_index, bool *r_valid = NULL) const; + bool in(const Variant &p_index, bool *r_valid = NULL) const; - bool iter_init(Variant& r_iter,bool &r_valid) const; - bool iter_next(Variant& r_iter,bool &r_valid) const; - Variant iter_get(const Variant& r_iter,bool &r_valid) const; + bool iter_init(Variant &r_iter, bool &r_valid) const; + bool iter_next(Variant &r_iter, bool &r_valid) const; + Variant iter_get(const Variant &r_iter, bool &r_valid) const; void get_property_list(List<PropertyInfo> *p_list) const; //argsVariant call() - bool operator==(const Variant& p_variant) const; - bool operator!=(const Variant& p_variant) const; - bool operator<(const Variant& p_variant) const; + bool operator==(const Variant &p_variant) const; + bool operator!=(const Variant &p_variant) const; + bool operator<(const Variant &p_variant) const; uint32_t hash() const; - bool hash_compare(const Variant& p_variant) const; + bool hash_compare(const Variant &p_variant) const; bool booleanize(bool &valid) const; - void static_assign(const Variant& p_variant); + void static_assign(const Variant &p_variant); static void get_constructor_list(Variant::Type p_type, List<MethodInfo> *p_list); static void get_numeric_constants_for_type(Variant::Type p_type, List<StringName> *p_constants); - static bool has_numeric_constant(Variant::Type p_type, const StringName& p_value); - static int get_numeric_constant_value(Variant::Type p_type, const StringName& p_value,bool *r_valid=NULL); + static bool has_numeric_constant(Variant::Type p_type, const StringName &p_value); + static int get_numeric_constant_value(Variant::Type p_type, const StringName &p_value, bool *r_valid = NULL); - typedef String (*ObjectDeConstruct)(const Variant& p_object,void *ud); - typedef void (*ObjectConstruct)(const String& p_text,void *ud,Variant& r_value); + typedef String (*ObjectDeConstruct)(const Variant &p_object, void *ud); + typedef void (*ObjectConstruct)(const String &p_text, void *ud, Variant &r_value); String get_construct_string() const; - static void construct_from_string(const String& p_string,Variant& r_value,ObjectConstruct p_obj_construct=NULL,void *p_construct_ud=NULL); - - void operator=(const Variant& p_variant); // only this is enough for all the other types - Variant(const Variant& p_variant); - _FORCE_INLINE_ Variant() { type=NIL; } - _FORCE_INLINE_ ~Variant() { if (type!=Variant::NIL) clear(); } + static void construct_from_string(const String &p_string, Variant &r_value, ObjectConstruct p_obj_construct = NULL, void *p_construct_ud = NULL); + void operator=(const Variant &p_variant); // only this is enough for all the other types + Variant(const Variant &p_variant); + _FORCE_INLINE_ Variant() { type = NIL; } + _FORCE_INLINE_ ~Variant() { + if (type != Variant::NIL) clear(); + } }; //typedef Dictionary Dictionary; no //typedef Array Array; - - Vector<Variant> varray(); -Vector<Variant> varray(const Variant& p_arg1); -Vector<Variant> varray(const Variant& p_arg1,const Variant& p_arg2); -Vector<Variant> varray(const Variant& p_arg1,const Variant& p_arg2,const Variant& p_arg3); -Vector<Variant> varray(const Variant& p_arg1,const Variant& p_arg2,const Variant& p_arg3,const Variant& p_arg4); -Vector<Variant> varray(const Variant& p_arg1,const Variant& p_arg2,const Variant& p_arg3,const Variant& p_arg4,const Variant& p_arg5); +Vector<Variant> varray(const Variant &p_arg1); +Vector<Variant> varray(const Variant &p_arg1, const Variant &p_arg2); +Vector<Variant> varray(const Variant &p_arg1, const Variant &p_arg2, const Variant &p_arg3); +Vector<Variant> varray(const Variant &p_arg1, const Variant &p_arg2, const Variant &p_arg3, const Variant &p_arg4); +Vector<Variant> varray(const Variant &p_arg1, const Variant &p_arg2, const Variant &p_arg3, const Variant &p_arg4, const Variant &p_arg5); struct VariantHasher { - static _FORCE_INLINE_ uint32_t hash(const Variant &p_variant) { return p_variant.hash(); } + static _FORCE_INLINE_ uint32_t hash(const Variant &p_variant) { return p_variant.hash(); } }; struct VariantComparator { - static _FORCE_INLINE_ bool compare(const Variant &p_lhs, const Variant &p_rhs) { return p_lhs.hash_compare(p_rhs); } + static _FORCE_INLINE_ bool compare(const Variant &p_lhs, const Variant &p_rhs) { return p_lhs.hash_compare(p_rhs); } }; -Variant::ObjData& Variant::_get_obj() { +Variant::ObjData &Variant::_get_obj() { - return *reinterpret_cast<ObjData*>(&_data._mem[0]); + return *reinterpret_cast<ObjData *>(&_data._mem[0]); } -const Variant::ObjData& Variant::_get_obj() const { +const Variant::ObjData &Variant::_get_obj() const { - return *reinterpret_cast<const ObjData*>(&_data._mem[0]); + return *reinterpret_cast<const ObjData *>(&_data._mem[0]); } - -String vformat(const String& p_text, const Variant& p1=Variant(),const Variant& p2=Variant(),const Variant& p3=Variant(),const Variant& p4=Variant(),const Variant& p5=Variant()); +String vformat(const String &p_text, const Variant &p1 = Variant(), const Variant &p2 = Variant(), const Variant &p3 = Variant(), const Variant &p4 = Variant(), const Variant &p5 = Variant()); #endif |