X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=sidebyside;f=synfig-core%2Ftrunk%2Fsrc%2Fsynfig%2Fvaluenode_add.cpp;h=e11fc21e0aeed63f62a6c44070a6ccdecae5732f;hb=515a8fd01a0b1229899edaf13ca2c2de1d1d81cf;hp=3c08cef418338123cd219296650281987526630b;hpb=fc340a19f9ca4ceaa46d60230206ac6ed7c050e3;p=synfig.git diff --git a/synfig-core/trunk/src/synfig/valuenode_add.cpp b/synfig-core/trunk/src/synfig/valuenode_add.cpp index 3c08cef..e11fc21 100644 --- a/synfig-core/trunk/src/synfig/valuenode_add.cpp +++ b/synfig-core/trunk/src/synfig/valuenode_add.cpp @@ -1,11 +1,12 @@ /* === S Y N F I G ========================================================= */ /*! \file valuenode_add.cpp -** \brief Template File +** \brief Implementation of the "Add" valuenode conversion. ** ** $Id$ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007 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 @@ -37,6 +38,7 @@ #include "vector.h" #include "angle.h" #include "real.h" +#include #endif @@ -57,7 +59,7 @@ using namespace synfig; synfig::ValueNode_Add::ValueNode_Add(const ValueBase &value): LinkableValueNode(value.get_type()) { - set_scalar(1.0); + set_link("scalar",ValueNode_Const::create(Real(1.0))); ValueBase::Type id(value.get_type()); switch(id) @@ -90,12 +92,6 @@ synfig::ValueNode_Add::ValueNode_Add(const ValueBase &value): assert(0); throw runtime_error("synfig::ValueNode_Add:Bad type "+ValueBase::type_name(id)); } - - assert(get_lhs()->get_type()==id); - assert(get_rhs()->get_type()==id); - assert(get_type()==id); - - DCAST_HACK_ENABLE(); } LinkableValueNode* @@ -115,51 +111,6 @@ synfig::ValueNode_Add::~ValueNode_Add() unlink_all(); } -void -ValueNode_Add::set_scalar(Real value) -{ - set_link("scalar",ValueNode_Const::create(value)); -} - -bool -synfig::ValueNode_Add::set_scalar(ValueNode::Handle value) -{ - if(value->get_type()!=ValueBase::TYPE_REAL&& !PlaceholderValueNode::Handle::cast_dynamic(value)) - return false; - scalar=value; - return true; -} - -bool -synfig::ValueNode_Add::set_lhs(ValueNode::Handle x) -{ - assert(get_type()); - - if(!x || - (get_type()==ValueBase::TYPE_NIL && !check_type(x->get_type())) || - (get_type()!=ValueBase::TYPE_NIL && x->get_type()!=get_type() && !PlaceholderValueNode::Handle::cast_dynamic(x))) - return false; - - ref_a=x; - - return true; -} - -bool -synfig::ValueNode_Add::set_rhs(ValueNode::Handle x) -{ - assert(get_type()); - - if(!x || - (get_type()==ValueBase::TYPE_NIL && !check_type(x->get_type())) || - (get_type()!=ValueBase::TYPE_NIL && x->get_type()!=get_type() && !PlaceholderValueNode::Handle::cast_dynamic(x))) - return false; - - ref_b=x; - - return true; -} - synfig::ValueBase synfig::ValueNode_Add::operator()(Time t)const { @@ -172,11 +123,7 @@ synfig::ValueNode_Add::operator()(Time t)const case ValueBase::TYPE_COLOR: return ((*ref_a)(t).get(Color())+(*ref_b)(t).get(Color()))*(*scalar)(t).get(Real()); case ValueBase::TYPE_INTEGER: - { - Real ret = ((*ref_a)(t).get(int())+(*ref_b)(t).get(int()))*(*scalar)(t).get(Real()) + 0.5f; - if (ret < 0) return static_cast(ret-1); - return static_cast(ret); - } + return round_to_int(((*ref_a)(t).get(int())+(*ref_b)(t).get(int()))*(*scalar)(t).get(Real())); case ValueBase::TYPE_REAL: return ((*ref_a)(t).get(Vector::value_type())+(*ref_b)(t).get(Vector::value_type()))*(*scalar)(t).get(Real()); case ValueBase::TYPE_TIME: @@ -193,28 +140,20 @@ synfig::ValueNode_Add::operator()(Time t)const bool ValueNode_Add::set_link_vfunc(int i,ValueNode::Handle value) { - assert(i>=0 && i<3); + assert(i>=0 && i=0 && i<3); + assert(i>=0 && i=0 && i<3); + assert(i>=0 && i=0 && i<3); + assert(i>=0 && i