X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvalue.cpp;h=e5ef475ee77410e27dac984428f63faaa2c6f6e6;hb=4ba22fb51d97f1ecce04dcc5e40569a4354c1bae;hp=900361859c5147abebaccf32bf0c6b600479cae5;hpb=cc54c38609ee9745ad678e5e9b9d7d2912be9c95;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/value.cpp b/synfig-core/trunk/src/synfig/value.cpp index 9003618..e5ef475 100644 --- a/synfig-core/trunk/src/synfig/value.cpp +++ b/synfig-core/trunk/src/synfig/value.cpp @@ -6,6 +6,7 @@ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007, 2008 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -65,50 +66,22 @@ ValueBase::ValueBase(Type x): data(0), loop_(0) { - switch(type) { - case TYPE_BOOL: - data=static_cast(new bool()); - break; - case TYPE_INTEGER: - data=static_cast(new int()); - break; - case TYPE_ANGLE: - data=static_cast(new Angle()); - break; - case TYPE_VECTOR: - data=static_cast(new Vector()); - break; - case TYPE_TIME: - data=static_cast(new Time()); - break; - case TYPE_REAL: - data=static_cast(new Real()); - break; - case TYPE_COLOR: - data=static_cast(new Color()); - break; - case TYPE_SEGMENT: - data=static_cast(new Segment()); - break; - case TYPE_BLINEPOINT: - data=static_cast(new BLinePoint()); - break; - case TYPE_LIST: - data=static_cast(new list_type()); - break; - case TYPE_STRING: - data=static_cast(new String()); - break; - case TYPE_GRADIENT: - data=static_cast(new Gradient()); - break; - case TYPE_CANVAS: - data=static_cast(new etl::handle()); - break; - default: - break; + case TYPE_BOOL: data=static_cast(new bool()); break; + case TYPE_INTEGER: data=static_cast(new int()); break; + case TYPE_ANGLE: data=static_cast(new Angle()); break; + case TYPE_VECTOR: data=static_cast(new Vector()); break; + case TYPE_TIME: data=static_cast(new Time()); break; + case TYPE_REAL: data=static_cast(new Real()); break; + case TYPE_COLOR: data=static_cast(new Color()); break; + case TYPE_SEGMENT: data=static_cast(new Segment()); break; + case TYPE_BLINEPOINT: data=static_cast(new BLinePoint()); break; + case TYPE_LIST: data=static_cast(new list_type()); break; + case TYPE_STRING: data=static_cast(new String()); break; + case TYPE_GRADIENT: data=static_cast(new Gradient()); break; + case TYPE_CANVAS: data=static_cast(new etl::handle()); break; + default: break; } } @@ -123,8 +96,39 @@ ValueBase::get(const char*)const return get(String()).c_str(); } +#ifdef _DEBUG +String +ValueBase::get_string() const +{ + switch(type) + { + case TYPE_NIL: return "Nil"; + case TYPE_BOOL: return strprintf("Bool (%s)", get(bool()) ? "true" : "false"); + case TYPE_INTEGER: return strprintf("Integer (%s)", get(int())); + case TYPE_ANGLE: return strprintf("Angle (%.2f)", Angle::deg(get(Angle())).get()); + // All types after this point are larger than 32 bits + case TYPE_TIME: return strprintf("Time (%s)", get(Time()).get_string().c_str()); + case TYPE_REAL: return strprintf("Real (%f)", get(Real())); + + // All types after this point are larger than 64 bits + + case TYPE_VECTOR: return strprintf("Vector (%f, %f)", get(Vector())[0], get(Vector())[1]); + case TYPE_COLOR: return strprintf("Color (%s)", get(Color()).get_string().c_str()); + case TYPE_SEGMENT: return strprintf("Segment ((%f, %f) to (%f, %f))", get(Segment()).p1[0], get(Segment()).p1[1], get(Segment()).p2[0], get(Segment()).p2[1]); + case TYPE_BLINEPOINT: return strprintf("BLinePoint (%s)", get(BLinePoint()).get_vertex()[0], get(BLinePoint()).get_vertex()[1]); + + // All types after this point require construction/destruction + + case TYPE_LIST: return strprintf("List (%d elements)", get(list_type()).size()); + case TYPE_CANVAS: return strprintf("Canvas (%s)", get(etl::loose_handle())->get_id().c_str()); + case TYPE_STRING: return strprintf("String (%s)", get(String()).c_str()); + case TYPE_GRADIENT: return strprintf("Gradient (%d cpoints)", get(Gradient()).size()); + default: return "Invalid type"; + } +} +#endif // _DEBUG void ValueBase::set(Canvas* x) @@ -146,13 +150,9 @@ ValueBase::set(etl::loose_handle x) { clear(); if(x && x->is_inline()) - { _set(etl::handle(x)); - } else - { _set(etl::loose_handle(x)); - } assert(get(x)==x); } @@ -161,13 +161,9 @@ ValueBase::set(etl::handle x) { clear(); if(x && x->is_inline()) - { _set(etl::handle(x)); - } else - { _set(etl::loose_handle(x)); - } assert(get(x)==x); } @@ -183,6 +179,12 @@ ValueBase::set(const char* x) _set(String(x)); } +void +ValueBase::set(char* x) +{ + _set(String(x)); +} + bool ValueBase::is_valid()const { @@ -224,57 +226,27 @@ ValueBase::clear() { switch(type) { - case TYPE_BOOL: - delete static_cast(data); - break; - case TYPE_INTEGER: - delete static_cast(data); - break; - case TYPE_ANGLE: - delete static_cast(data); - break; - case TYPE_VECTOR: - delete static_cast(data); - break; - case TYPE_TIME: - delete static_cast(data); - break; - case TYPE_REAL: - delete static_cast(data); - break; - case TYPE_COLOR: - delete static_cast(data); - break; - case TYPE_SEGMENT: - delete static_cast(data); - break; - case TYPE_BLINEPOINT: - delete static_cast(data); - break; - case TYPE_LIST: - delete static_cast(data); - break; - case TYPE_STRING: - delete static_cast(data); - break; - case TYPE_GRADIENT: - delete static_cast(data); - break; - - + case TYPE_BOOL: delete static_cast(data); break; + case TYPE_INTEGER: delete static_cast(data); break; + case TYPE_ANGLE: delete static_cast(data); break; + case TYPE_TIME: delete static_cast(data); break; + case TYPE_REAL: delete static_cast(data); break; + case TYPE_VECTOR: delete static_cast(data); break; + case TYPE_COLOR: delete static_cast(data); break; + case TYPE_SEGMENT: delete static_cast(data); break; + case TYPE_BLINEPOINT: delete static_cast(data); break; + case TYPE_LIST: delete static_cast(data); break; case TYPE_CANVAS: { etl::handle canvas(get(etl::loose_handle())); if(canvas && canvas->is_inline()) - { delete static_cast*>(data); - } else - { delete static_cast*>(data); - } break; } + case TYPE_STRING: delete static_cast(data); break; + case TYPE_GRADIENT: delete static_cast(data); break; default: break; } @@ -289,36 +261,37 @@ ValueBase::clear() String ValueBase::type_name(Type id) { + // don't internationalize these type names - they're using in .sif files switch(id) { - case TYPE_REAL: - return "real"; - case TYPE_TIME: - return "time"; - case TYPE_INTEGER: - return "integer"; - case TYPE_BOOL: - return "bool"; - case TYPE_ANGLE: - return "angle"; - case TYPE_VECTOR: - return "vector"; - case TYPE_COLOR: - return "color"; - case TYPE_STRING: - return "string"; - case TYPE_CANVAS: - return "canvas"; - case TYPE_LIST: - return "list"; - case TYPE_SEGMENT: - return "segment"; - case TYPE_GRADIENT: - return "gradient"; - case TYPE_BLINEPOINT: - return "bline_point"; - case TYPE_NIL: - return "nil"; + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_BOOL: return N_("bool"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_INTEGER: return N_("integer"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_ANGLE: return N_("angle"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_TIME: return N_("time"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_REAL: return N_("real"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_VECTOR: return N_("vector"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_COLOR: return N_("color"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_SEGMENT: return N_("segment"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_BLINEPOINT: return N_("bline_point"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_LIST: return N_("list"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_CANVAS: return N_("canvas"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_STRING: return N_("string"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_GRADIENT: return N_("gradient"); + /* TRANSLATORS: this is the name of a type -- see http://synfig.org/Types */ + case TYPE_NIL: return N_("nil"); default: break; } @@ -327,37 +300,41 @@ ValueBase::type_name(Type id) return "UNKNOWN"; } +String +ValueBase::type_local_name(Type id) +{ + return dgettext("synfig",type_name(id).c_str()); +} + ValueBase::Type ValueBase::ident_type(const String &str) { - if(str=="nil" || str=="null") - return TYPE_NIL; - else if(str=="time" || str==_("time")) - return TYPE_TIME; - else if(str=="real" || str=="float" || str==_("real")) - return TYPE_REAL; - else if(str=="integer" || str=="int" || str==_("integer")) - return TYPE_INTEGER; - else if(str=="bool" || str==_("bool")) - return TYPE_BOOL; - else if(str=="angle" || str=="degrees" || str=="radians" || str=="rotations") - return TYPE_ANGLE; - else if(str=="vector" || str=="point") - return TYPE_VECTOR; - else if(str=="color") - return TYPE_COLOR; - else if(str=="string") - return TYPE_STRING; - else if(str=="canvas") - return TYPE_CANVAS; - else if(str=="list") - return TYPE_LIST; - else if(str=="segment") - return TYPE_SEGMENT; - else if(str=="gradient") - return TYPE_GRADIENT; - else if(str=="bline_point" || str=="blinepoint") - return TYPE_BLINEPOINT; + if(str=="nil" || + str=="null") return TYPE_NIL; + else if(str=="time" || + str==_("time")) return TYPE_TIME; + else if(str=="real" || + str=="float" || + str==_("real")) return TYPE_REAL; + else if(str=="integer" || + str=="int" || + str==_("integer")) return TYPE_INTEGER; + else if(str=="bool" || + str==_("bool")) return TYPE_BOOL; + else if(str=="angle" || + str=="degrees" || + str=="radians" || + str=="rotations") return TYPE_ANGLE; + else if(str=="vector" || + str=="point") return TYPE_VECTOR; + else if(str=="color") return TYPE_COLOR; + else if(str=="string") return TYPE_STRING; + else if(str=="canvas") return TYPE_CANVAS; + else if(str=="list") return TYPE_LIST; + else if(str=="segment") return TYPE_SEGMENT; + else if(str=="gradient") return TYPE_GRADIENT; + else if(str=="bline_point" || + str=="blinepoint") return TYPE_BLINEPOINT; return TYPE_NIL; } @@ -372,36 +349,21 @@ ValueBase::operator==(const ValueBase& rhs)const switch(get_type()) { - case TYPE_TIME: - return get(Time()).is_equal(rhs.get(Time())); - case TYPE_REAL: - return abs(get(Real())-rhs.get(Real()))<=0.00000000000001; - case TYPE_INTEGER: - return get(int())==rhs.get(int()); - case TYPE_BOOL: - return get(bool())==rhs.get(bool()); - case TYPE_ANGLE: - return get(Angle())==rhs.get(Angle()); - case TYPE_VECTOR: - return get(Vector()).is_equal_to(rhs.get(Vector())); - case TYPE_COLOR: - return get(Color())==rhs.get(Color()); - case TYPE_STRING: - return get(String())==rhs.get(String()); - case TYPE_CANVAS: - return get(Canvas::LooseHandle())==rhs.get(Canvas::LooseHandle()); - case TYPE_LIST: - return get_list()==rhs.get_list(); - case TYPE_SEGMENT: -// return get(Segment())==rhs.get(Segment()); - case TYPE_GRADIENT: -// return get(Gradient())==rhs.get(Gradient()); - case TYPE_BLINEPOINT: -// return get(BLinePoint())==rhs.get(BLinePoint()); + case TYPE_TIME: return get(Time()).is_equal(rhs.get(Time())); + case TYPE_REAL: return abs(get(Real())-rhs.get(Real()))<=0.00000000000001; + case TYPE_INTEGER: return get(int())==rhs.get(int()); + case TYPE_BOOL: return get(bool())==rhs.get(bool()); + case TYPE_ANGLE: return get(Angle())==rhs.get(Angle()); + case TYPE_VECTOR: return get(Vector()).is_equal_to(rhs.get(Vector())); + case TYPE_COLOR: return get(Color())==rhs.get(Color()); + case TYPE_STRING: return get(String())==rhs.get(String()); + case TYPE_CANVAS: return get(Canvas::LooseHandle())==rhs.get(Canvas::LooseHandle()); + case TYPE_LIST: return get_list()==rhs.get_list(); + case TYPE_SEGMENT: // return get(Segment())==rhs.get(Segment()); + case TYPE_GRADIENT: // return get(Gradient())==rhs.get(Gradient()); + case TYPE_BLINEPOINT: // return get(BLinePoint())==rhs.get(BLinePoint()); case TYPE_NIL: - default: - return false; - break; + default: return false; } return false; }