Use LinkableValueNode members functions when possible in the derived valuenodes.
[synfig.git] / synfig-core / src / synfig / valuenode_timedswap.cpp
index 7e1b56f..ef2298d 100644 (file)
@@ -56,6 +56,8 @@ using namespace synfig;
 ValueNode_TimedSwap::ValueNode_TimedSwap(const ValueBase &value):
        LinkableValueNode(value.get_type())
 {
+       Vocab ret(get_children_vocab());
+       set_children_vocab(ret);
        switch(get_type())
        {
        case ValueBase::TYPE_ANGLE:
@@ -206,53 +208,6 @@ ValueNode_TimedSwap::get_link_vfunc(int i)const
        return 0;
 }
 
-int
-ValueNode_TimedSwap::link_count()const
-{
-       return 4;
-}
-
-String
-ValueNode_TimedSwap::link_local_name(int i)const
-{
-       assert(i>=0 && i<link_count());
-
-       switch(i)
-       {
-       case 0: return _("Before");
-       case 1: return _("After");
-       case 2: return _("Swap Time");
-       case 3: return _("Swap Duration");
-       default:return String();
-       }
-}
-
-String
-ValueNode_TimedSwap::link_name(int i)const
-{
-       assert(i>=0 && i<link_count());
-
-       switch(i)
-       {
-       case 0: return "before";
-       case 1: return "after";
-       case 2: return "time";
-       case 3: return "length";
-       default:return String();
-       }
-}
-
-int
-ValueNode_TimedSwap::get_link_index_from_name(const String &name)const
-{
-       if(name=="before")      return 0;
-       if(name=="after")       return 1;
-       if(name=="time")        return 2;
-       if(name=="length")      return 3;
-
-       throw Exception::BadLinkName(name);
-}
-
 String
 ValueNode_TimedSwap::get_name()const
 {
@@ -280,6 +235,9 @@ ValueNode_TimedSwap::check_type(ValueBase::Type type)
 LinkableValueNode::Vocab
 ValueNode_TimedSwap::get_children_vocab_vfunc()const
 {
+       if(children_vocab.size())
+               return children_vocab;
+
        LinkableValueNode::Vocab ret;
 
        ret.push_back(ParamDesc(ValueBase(),"before")