/* === S Y N F I G ========================================================= */
-/*! \file value_node.cpp
+/*! \file valuenode.cpp
** \brief Template File
**
-** $Id: valuenode.cpp,v 1.1.1.1 2005/01/04 01:23:15 darco Exp $
+** $Id$
**
** \legal
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
#include "valuenode_composite.h"
#include "valuenode_reference.h"
#include "valuenode_scale.h"
+#include "valuenode_blinecalctangent.h"
+#include "valuenode_blinecalcvertex.h"
#include "valuenode_segcalctangent.h"
#include "valuenode_segcalcvertex.h"
+#include "valuenode_repeat_gradient.h"
#include "valuenode_stripes.h"
+#include "valuenode_add.h"
#include "valuenode_subtract.h"
#include "valuenode_timedswap.h"
#include "valuenode_twotone.h"
#include "valuenode_radialcomposite.h"
#include "valuenode_gradientrotate.h"
#include "valuenode_sine.h"
+#include "valuenode_exp.h"
#include "layer.h"
{
book_=new LinkableValueNode::Book();
-#define ADD_VALUENODE(c,n) (*book_)[n].factory=reinterpret_cast<LinkableValueNode::Factory>(&c::create); (*book_)[n].check_type=&c::check_type;(*book_)[n].local_name=n
-#define ADD_VALUENODE2(c,n) (*book_)[n].factory=reinterpret_cast<LinkableValueNode::Factory>(&c::create_from); (*book_)[n].check_type=&c::check_type;(*book_)[n].local_name=n
-
- ADD_VALUENODE(ValueNode_Linear,"linear");
- ADD_VALUENODE(ValueNode_Composite,"composite");
- ADD_VALUENODE(ValueNode_RadialComposite,"radial_composite");
- ADD_VALUENODE(ValueNode_Reference,"reference");
- ADD_VALUENODE(ValueNode_Scale,"scale");
- ADD_VALUENODE(ValueNode_SegCalcTangent,"segcalctangent");
- ADD_VALUENODE(ValueNode_SegCalcVertex,"segcalcvertex");
- ADD_VALUENODE(ValueNode_Stripes,"stripes");
- ADD_VALUENODE(ValueNode_Subtract,"subtract");
- //ADD_VALUENODE(ValueNode_TimedSwap,"timed_swap");
- ADD_VALUENODE(ValueNode_TwoTone,"twotone");
- ADD_VALUENODE(ValueNode_BLine,"bline");
- ADD_VALUENODE2(ValueNode_DynamicList,"dynamic_list");
- ADD_VALUENODE(ValueNode_GradientRotate,"gradient_rotate");
- ADD_VALUENODE(ValueNode_Sine,"sine");
+#define ADD_VALUENODE(class,name,local) \
+ (*book_)[name].factory=reinterpret_cast<LinkableValueNode::Factory>(&class::create); \
+ (*book_)[name].check_type=&class::check_type; \
+ (*book_)[name].local_name=local
+
+#define ADD_VALUENODE2(class,name,local) \
+ (*book_)[name].factory=reinterpret_cast<LinkableValueNode::Factory>(&class::create_from); \
+ (*book_)[name].check_type=&class::check_type; \
+ (*book_)[name].local_name=local
+
+ ADD_VALUENODE(ValueNode_Linear, "linear", _("Linear") );
+ ADD_VALUENODE(ValueNode_Composite, "composite", _("Composite") );
+ ADD_VALUENODE(ValueNode_RadialComposite,"radial_composite", _("Radial Composite") );
+ ADD_VALUENODE(ValueNode_Reference, "reference", _("Reference") );
+ ADD_VALUENODE(ValueNode_Repeat_Gradient,"repeat_gradient", _("Repeat Gradient") );
+ ADD_VALUENODE(ValueNode_Scale, "scale", _("Scale") );
+ ADD_VALUENODE(ValueNode_BLineCalcTangent,"blinecalctangent",_("BLine Tangent") );
+ ADD_VALUENODE(ValueNode_BLineCalcVertex,"blinecalcvertex", _("BLine Vertex") );
+ ADD_VALUENODE(ValueNode_SegCalcTangent, "segcalctangent", _("Segment Tangent") );
+ ADD_VALUENODE(ValueNode_SegCalcVertex, "segcalcvertex", _("Segment Vertex") );
+ ADD_VALUENODE(ValueNode_Stripes, "stripes", _("Stripes") );
+ ADD_VALUENODE(ValueNode_Add, "add", _("Add") );
+ ADD_VALUENODE(ValueNode_Subtract, "subtract", _("Subtract") );
+ ADD_VALUENODE(ValueNode_TimedSwap, "timed_swap", _("Timed Swap") );
+ ADD_VALUENODE(ValueNode_TwoTone, "twotone", _("Two-Tone") );
+ ADD_VALUENODE(ValueNode_BLine, "bline", _("BLine") );
+ ADD_VALUENODE2(ValueNode_DynamicList, "dynamic_list", _("Dynamic List") );
+ ADD_VALUENODE(ValueNode_GradientRotate, "gradient_rotate", _("Gradient Rotate") );
+ ADD_VALUENODE(ValueNode_Sine, "sine", _("Sine") );
+ ADD_VALUENODE(ValueNode_Exp, "exp", _("Exponential") );
#undef ADD_VALUENODE
+#undef ADD_VALUENODE2
+
return true;
}
void
ValueNode::on_changed()
{
- if(get_parent_canvas())
- get_parent_canvas()->signal_value_node_changed()(this);
- else if(get_root_canvas() && get_parent_canvas())
+ etl::loose_handle<Canvas> parent_canvas = get_parent_canvas();
+ if(parent_canvas)
+ do // signal to all the ancestor canvases
+ parent_canvas->signal_value_node_changed()(this);
+ while (parent_canvas = parent_canvas->parent());
+ else if(get_root_canvas())
get_root_canvas()->signal_value_node_changed()(this);
Node::on_changed();
}
ValueBase
-PlaceholderValueNode::operator()(Time t)const
+PlaceholderValueNode::operator()(Time /*t*/)const
{
assert(0);
return ValueBase();