Use LinkableValueNode members functions when possible in the derived valuenodes.
[synfig.git] / synfig-core / src / synfig / valuenode_segcalctangent.cpp
index 5dd3150..9a00d11 100644 (file)
@@ -58,6 +58,8 @@ using namespace synfig;
 ValueNode_SegCalcTangent::ValueNode_SegCalcTangent(const ValueBase::Type &x):
        LinkableValueNode(x)
 {
+       Vocab ret(get_children_vocab());
+       set_children_vocab(ret);
        if(x!=ValueBase::TYPE_VECTOR)
                throw Exception::BadType(ValueBase::type_local_name(x));
 
@@ -135,47 +137,6 @@ ValueNode_SegCalcTangent::get_link_vfunc(int i)const
        return 0;
 }
 
-int
-ValueNode_SegCalcTangent::link_count()const
-{
-       return 2;
-}
-
-String
-ValueNode_SegCalcTangent::link_name(int i)const
-{
-       assert(i>=0 && i<link_count());
-
-       if(i==0)
-               return "segment";
-       if(i==1)
-               return "amount";
-       return String();
-}
-
-String
-ValueNode_SegCalcTangent::link_local_name(int i)const
-{
-       assert(i>=0 && i<link_count());
-
-       if(i==0)
-               return _("Segment");
-       if(i==1)
-               return _("Amount");
-       return String();
-}
-
-int
-ValueNode_SegCalcTangent::get_link_index_from_name(const String &name)const
-{
-       if(name=="segment")
-               return 0;
-       if(name=="amount")
-               return 1;
-
-       throw Exception::BadLinkName(name);
-}
-
 LinkableValueNode*
 ValueNode_SegCalcTangent::create_new()const
 {
@@ -185,6 +146,9 @@ ValueNode_SegCalcTangent::create_new()const
 LinkableValueNode::Vocab
 ValueNode_SegCalcTangent::get_children_vocab_vfunc()const
 {
+       if(children_vocab.size())
+               return children_vocab;
+
        LinkableValueNode::Vocab ret;
 
        ret.push_back(ParamDesc(ValueBase(),"segment")