Variant INT and REAL are now 64 bits (other types remain at 32)
This commit is contained in:
parent
94ee7798ce
commit
13cdccf23b
9 changed files with 202 additions and 63 deletions
|
@ -31,6 +31,10 @@
|
|||
#include "os/keyboard.h"
|
||||
#include <stdio.h>
|
||||
|
||||
|
||||
#define ENCODE_MASK 0xFF
|
||||
#define ENCODE_FLAG_64 1<<16
|
||||
|
||||
Error decode_variant(Variant& r_variant,const uint8_t *p_buffer, int p_len,int *r_len) {
|
||||
|
||||
const uint8_t * buf=p_buffer;
|
||||
|
@ -44,14 +48,14 @@ Error decode_variant(Variant& r_variant,const uint8_t *p_buffer, int p_len,int *
|
|||
|
||||
uint32_t type=decode_uint32(buf);
|
||||
|
||||
ERR_FAIL_COND_V(type>=Variant::VARIANT_MAX,ERR_INVALID_DATA);
|
||||
ERR_FAIL_COND_V((type&ENCODE_MASK)>=Variant::VARIANT_MAX,ERR_INVALID_DATA);
|
||||
|
||||
buf+=4;
|
||||
len-=4;
|
||||
if (r_len)
|
||||
*r_len=4;
|
||||
|
||||
switch(type) {
|
||||
switch(type&ENCODE_MASK) {
|
||||
|
||||
case Variant::NIL: {
|
||||
|
||||
|
@ -68,19 +72,35 @@ Error decode_variant(Variant& r_variant,const uint8_t *p_buffer, int p_len,int *
|
|||
case Variant::INT: {
|
||||
|
||||
ERR_FAIL_COND_V(len<4,ERR_INVALID_DATA);
|
||||
int val = decode_uint32(buf);
|
||||
if (type&ENCODE_FLAG_64) {
|
||||
int64_t val = decode_uint64(buf);
|
||||
r_variant=val;
|
||||
if (r_len)
|
||||
(*r_len)+=8;
|
||||
|
||||
} else {
|
||||
int32_t val = decode_uint32(buf);
|
||||
r_variant=val;
|
||||
if (r_len)
|
||||
(*r_len)+=4;
|
||||
}
|
||||
|
||||
} break;
|
||||
case Variant::REAL: {
|
||||
|
||||
ERR_FAIL_COND_V(len<(int)4,ERR_INVALID_DATA);
|
||||
|
||||
if (type&ENCODE_FLAG_64) {
|
||||
double val = decode_double(buf);
|
||||
r_variant=val;
|
||||
if (r_len)
|
||||
(*r_len)+=8;
|
||||
} else {
|
||||
float val = decode_float(buf);
|
||||
r_variant=val;
|
||||
if (r_len)
|
||||
(*r_len)+=4;
|
||||
}
|
||||
|
||||
} break;
|
||||
case Variant::STRING: {
|
||||
|
@ -796,8 +816,28 @@ Error encode_variant(const Variant& p_variant, uint8_t *r_buffer, int &r_len) {
|
|||
|
||||
r_len=0;
|
||||
|
||||
uint32_t flags=0;
|
||||
|
||||
switch(p_variant.get_type()) {
|
||||
|
||||
case Variant::INT: {
|
||||
int64_t val = p_variant;
|
||||
if (val>0x7FFFFFFF || val < -0x80000000) {
|
||||
flags|=ENCODE_FLAG_64;
|
||||
}
|
||||
} break;
|
||||
case Variant::REAL: {
|
||||
|
||||
double d = p_variant;
|
||||
float f = d;
|
||||
if (double(f)!=d) {
|
||||
flags|=ENCODE_FLAG_64; //always encode real as double
|
||||
}
|
||||
} break;
|
||||
}
|
||||
|
||||
if (buf) {
|
||||
encode_uint32(p_variant.get_type(),buf);
|
||||
encode_uint32(p_variant.get_type()|flags,buf);
|
||||
buf+=4;
|
||||
}
|
||||
r_len+=4;
|
||||
|
@ -819,20 +859,42 @@ Error encode_variant(const Variant& p_variant, uint8_t *r_buffer, int &r_len) {
|
|||
} break;
|
||||
case Variant::INT: {
|
||||
|
||||
int64_t val = p_variant;
|
||||
if (val>0x7FFFFFFF || val < -0x80000000) {
|
||||
//64 bits
|
||||
if (buf) {
|
||||
encode_uint32(p_variant.operator int(),buf);
|
||||
encode_uint64(val,buf);
|
||||
}
|
||||
|
||||
r_len+=8;
|
||||
} else {
|
||||
if (buf) {
|
||||
encode_uint32(int32_t(val),buf);
|
||||
}
|
||||
|
||||
r_len+=4;
|
||||
|
||||
}
|
||||
} break;
|
||||
case Variant::REAL: {
|
||||
|
||||
double d = p_variant;
|
||||
float f = d;
|
||||
if (double(f)!=d) {
|
||||
if (buf) {
|
||||
encode_float(p_variant.operator float(),buf);
|
||||
encode_double(p_variant.operator double(),buf);
|
||||
}
|
||||
|
||||
r_len+=8;
|
||||
|
||||
} else {
|
||||
|
||||
if (buf) {
|
||||
encode_double(p_variant.operator float(),buf);
|
||||
}
|
||||
|
||||
r_len+=4;
|
||||
}
|
||||
|
||||
|
||||
} break;
|
||||
case Variant::NODE_PATH: {
|
||||
|
|
|
@ -68,6 +68,8 @@ enum {
|
|||
VARIANT_VECTOR3_ARRAY=35,
|
||||
VARIANT_COLOR_ARRAY=36,
|
||||
VARIANT_VECTOR2_ARRAY=37,
|
||||
VARIANT_INT64=40,
|
||||
VARIANT_DOUBLE=41,
|
||||
|
||||
IMAGE_ENCODING_EMPTY=0,
|
||||
IMAGE_ENCODING_RAW=1,
|
||||
|
@ -116,10 +118,18 @@ Error ResourceInteractiveLoaderBinary::parse_variant(Variant& r_v) {
|
|||
|
||||
r_v=int(f->get_32());
|
||||
} break;
|
||||
case VARIANT_INT64: {
|
||||
|
||||
r_v=int64_t(f->get_64());
|
||||
} break;
|
||||
case VARIANT_REAL: {
|
||||
|
||||
r_v=f->get_real();
|
||||
} break;
|
||||
case VARIANT_DOUBLE: {
|
||||
|
||||
r_v=f->get_double();
|
||||
} break;
|
||||
case VARIANT_STRING: {
|
||||
|
||||
r_v=get_unicode_string();
|
||||
|
@ -1416,15 +1426,33 @@ void ResourceFormatSaverBinaryInstance::write_variant(const Variant& p_property,
|
|||
} break;
|
||||
case Variant::INT: {
|
||||
|
||||
int64_t val = p_property;
|
||||
if (val>0x7FFFFFFF || val < -0x80000000) {
|
||||
f->store_32(VARIANT_INT64);
|
||||
f->store_64(val);
|
||||
|
||||
} else {
|
||||
f->store_32(VARIANT_INT);
|
||||
int val=p_property;
|
||||
f->store_32(val);
|
||||
f->store_32(int32_t(val));
|
||||
|
||||
}
|
||||
|
||||
} break;
|
||||
case Variant::REAL: {
|
||||
|
||||
|
||||
double d = p_property;
|
||||
float fl = d;
|
||||
if (double(fl)!=d) {
|
||||
f->store_32(VARIANT_DOUBLE);
|
||||
f->store_double(d);
|
||||
} else {
|
||||
|
||||
f->store_32(VARIANT_REAL);
|
||||
real_t val=p_property;
|
||||
f->store_real(val);
|
||||
f->store_real(fl);
|
||||
|
||||
}
|
||||
|
||||
} break;
|
||||
case Variant::STRING: {
|
||||
|
|
|
@ -1592,6 +1592,54 @@ int String::hex_to_int(bool p_with_prefix) const {
|
|||
|
||||
}
|
||||
|
||||
|
||||
int64_t String::hex_to_int64(bool p_with_prefix) const {
|
||||
|
||||
int l = length();
|
||||
if (p_with_prefix && l<3)
|
||||
return 0;
|
||||
|
||||
const CharType *s=ptr();
|
||||
|
||||
int64_t sign = s[0]=='-' ? -1 : 1;
|
||||
|
||||
if (sign<0) {
|
||||
s++;
|
||||
l--;
|
||||
if (p_with_prefix && l<2)
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (p_with_prefix) {
|
||||
if (s[0]!='0' || s[1]!='x')
|
||||
return 0;
|
||||
s+=2;
|
||||
l-=2;
|
||||
};
|
||||
|
||||
int64_t hex=0;
|
||||
|
||||
while(*s) {
|
||||
|
||||
CharType c = LOWERCASE(*s);
|
||||
int64_t n;
|
||||
if (c>='0' && c<='9') {
|
||||
n=c-'0';
|
||||
} else if (c>='a' && c<='f') {
|
||||
n=(c-'a')+10;
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
|
||||
hex*=16;
|
||||
hex+=n;
|
||||
s++;
|
||||
}
|
||||
|
||||
return hex*sign;
|
||||
|
||||
}
|
||||
|
||||
int String::to_int() const {
|
||||
|
||||
if (length()==0)
|
||||
|
|
|
@ -147,6 +147,7 @@ public:
|
|||
int hex_to_int(bool p_with_prefix = true) const;
|
||||
int to_int() const;
|
||||
|
||||
int64_t hex_to_int64(bool p_with_prefix = true) const;
|
||||
int64_t to_int64() const;
|
||||
static int to_int(const char* p_str, int p_len=-1);
|
||||
static double to_double(const char* p_str);
|
||||
|
|
|
@ -1467,7 +1467,7 @@ Variant::operator double() const {
|
|||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1.0 : 0.0;
|
||||
case INT: return (float)_data._int;
|
||||
case INT: return (double)_data._int;
|
||||
case REAL: return _data._real;
|
||||
case STRING: return operator String().to_double();
|
||||
default: {
|
||||
|
@ -1504,8 +1504,8 @@ Variant::operator String() const {
|
|||
|
||||
case NIL: return "Null";
|
||||
case BOOL: return _data._bool ? "True" : "False";
|
||||
case INT: return String::num(_data._int);
|
||||
case REAL: return String::num(_data._real);
|
||||
case INT: return itos(_data._int);
|
||||
case REAL: return rtos(_data._real);
|
||||
case STRING: return *reinterpret_cast<const String*>(_data._mem);
|
||||
case VECTOR2: return "("+operator Vector2()+")";
|
||||
case RECT2: return "("+operator Rect2()+")";
|
||||
|
|
|
@ -141,7 +141,7 @@ private:
|
|||
union {
|
||||
|
||||
bool _bool;
|
||||
int _int;
|
||||
int64_t _int;
|
||||
double _real;
|
||||
Matrix32 *_matrix32;
|
||||
AABB* _aabb;
|
||||
|
|
|
@ -683,7 +683,7 @@ void Variant::evaluate(const Operator& p_op, const Variant& p_a, const Variant&
|
|||
case INT: {
|
||||
switch(p_b.type) {
|
||||
case BOOL: {
|
||||
int b = p_b._data._bool;
|
||||
int64_t b = p_b._data._bool;
|
||||
if (b==0) {
|
||||
|
||||
r_valid=false;
|
||||
|
@ -693,7 +693,7 @@ void Variant::evaluate(const Operator& p_op, const Variant& p_a, const Variant&
|
|||
|
||||
} break;
|
||||
case INT: {
|
||||
int b = p_b._data._int;
|
||||
int64_t b = p_b._data._int;
|
||||
if (b==0) {
|
||||
|
||||
r_valid=false;
|
||||
|
@ -3358,8 +3358,8 @@ void Variant::blend(const Variant& a, const Variant& b, float c, Variant &r_dst)
|
|||
switch(a.type) {
|
||||
case NIL: { r_dst=Variant(); } return;
|
||||
case INT:{
|
||||
int va=a._data._int;
|
||||
int vb=b._data._int;
|
||||
int64_t va=a._data._int;
|
||||
int64_t vb=b._data._int;
|
||||
r_dst=int(va + vb * c + 0.5);
|
||||
} return;
|
||||
case REAL:{
|
||||
|
@ -3423,8 +3423,8 @@ void Variant::interpolate(const Variant& a, const Variant& b, float c,Variant &r
|
|||
case NIL:{ r_dst=Variant(); } return;
|
||||
case BOOL:{ r_dst=a; } return;
|
||||
case INT:{
|
||||
int va=a._data._int;
|
||||
int vb=b._data._int;
|
||||
int64_t va=a._data._int;
|
||||
int64_t vb=b._data._int;
|
||||
r_dst=int((1.0-c) * va + vb * c);
|
||||
} return;
|
||||
case REAL:{
|
||||
|
|
|
@ -731,14 +731,14 @@ void GDTokenizerText::_advance() {
|
|||
|
||||
INCPOS(str.length());
|
||||
if (hexa_found) {
|
||||
int val = str.hex_to_int();
|
||||
int64_t val = str.hex_to_int64();
|
||||
_make_constant(val);
|
||||
} else if (period_found || exponent_found) {
|
||||
real_t val = str.to_double();
|
||||
double val = str.to_double();
|
||||
//print_line("*%*%*%*% to convert: "+str+" result: "+rtos(val));
|
||||
_make_constant(val);
|
||||
} else {
|
||||
int val = str.to_int();
|
||||
int64_t val = str.to_int64();
|
||||
_make_constant(val);
|
||||
|
||||
}
|
||||
|
|
|
@ -280,7 +280,7 @@ BoxContainer::AlignMode BoxContainer::get_alignment() const {
|
|||
void BoxContainer::add_spacer(bool p_begin) {
|
||||
|
||||
Control *c = memnew( Control );
|
||||
c->set_mouse_filter(MOUSE_FILTER_PASS);
|
||||
c->set_mouse_filter(MOUSE_FILTER_PASS); //allow spacer to pass mouse events
|
||||
|
||||
if (vertical)
|
||||
c->set_v_size_flags(SIZE_EXPAND_FILL);
|
||||
|
|
Loading…
Reference in a new issue