Fix bugs in previous commit that caused FTBFS in synfig and ETL FTBFS with older...
[synfig.git] / synfig-core / tags / 0.61.09 / src / synfig / valuenode_gradientcolor.cpp
1 /* === S Y N F I G ========================================================= */
2 /*!     \file valuenode_gradientcolor.cpp
3 **      \brief Implementation of the "Gradient Color" valuenode conversion.
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **      Copyright (c) 2007, 2008 Chris Moore
10 **
11 **      This package is free software; you can redistribute it and/or
12 **      modify it under the terms of the GNU General Public License as
13 **      published by the Free Software Foundation; either version 2 of
14 **      the License, or (at your option) any later version.
15 **
16 **      This package is distributed in the hope that it will be useful,
17 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
18 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 **      General Public License for more details.
20 **      \endlegal
21 */
22 /* ========================================================================= */
23
24 /* === H E A D E R S ======================================================= */
25
26 #ifdef USING_PCH
27 #       include "pch.h"
28 #else
29 #ifdef HAVE_CONFIG_H
30 #       include <config.h>
31 #endif
32
33 #include "valuenode_gradientcolor.h"
34 #include "valuenode_const.h"
35 #include "gradient.h"
36 #include "general.h"
37
38 #endif
39
40 /* === U S I N G =========================================================== */
41
42 using namespace std;
43 using namespace etl;
44 using namespace synfig;
45
46 /* === M A C R O S ========================================================= */
47
48 /* === G L O B A L S ======================================================= */
49
50 /* === P R O C E D U R E S ================================================= */
51
52 /* === M E T H O D S ======================================================= */
53
54 ValueNode_GradientColor::ValueNode_GradientColor(const ValueBase &value):
55         LinkableValueNode(value.get_type())
56 {
57         switch(value.get_type())
58         {
59         case ValueBase::TYPE_COLOR:
60                 set_link("gradient", ValueNode_Const::create(Gradient(value.get(Color()),value.get(Color()))));
61                 set_link("index",    ValueNode_Const::create(Real(0.5)));
62                 set_link("loop",    ValueNode_Const::create(bool(false)));
63                 break;
64         default:
65                 throw Exception::BadType(ValueBase::type_local_name(value.get_type()));
66         }
67
68         DCAST_HACK_ENABLE();
69 }
70
71 LinkableValueNode*
72 ValueNode_GradientColor::create_new()const
73 {
74         return new ValueNode_GradientColor(get_type());
75 }
76
77 ValueNode_GradientColor*
78 ValueNode_GradientColor::create(const ValueBase &x)
79 {
80         return new ValueNode_GradientColor(x);
81 }
82
83 ValueNode_GradientColor::~ValueNode_GradientColor()
84 {
85         unlink_all();
86 }
87
88 ValueBase
89 ValueNode_GradientColor::operator()(Time t)const
90 {
91         Real index((*index_)(t).get(Real()));
92         bool loop((*loop_)(t).get(bool()));
93         if (loop) index -= floor(index);
94         return (*gradient_)(t).get(Gradient())(index);
95 }
96
97
98 bool
99 ValueNode_GradientColor::set_link_vfunc(int i,ValueNode::Handle value)
100 {
101         assert(i>=0 && i<link_count());
102
103         switch(i)
104         {
105         case 0: CHECK_TYPE_AND_SET_VALUE(gradient_,     ValueBase::TYPE_GRADIENT);
106         case 1: CHECK_TYPE_AND_SET_VALUE(index_,        ValueBase::TYPE_REAL);
107         case 2: CHECK_TYPE_AND_SET_VALUE(loop_,         ValueBase::TYPE_BOOL);
108         }
109         return false;
110 }
111
112 ValueNode::LooseHandle
113 ValueNode_GradientColor::get_link_vfunc(int i)const
114 {
115         assert(i>=0 && i<link_count());
116
117         switch(i)
118         {
119                 case 0: return gradient_;
120                 case 1: return index_;
121                 case 2: return loop_;
122         }
123
124         return 0;
125 }
126
127 int
128 ValueNode_GradientColor::link_count()const
129 {
130         return 3;
131 }
132
133 String
134 ValueNode_GradientColor::link_local_name(int i)const
135 {
136         assert(i>=0 && i<link_count());
137
138         switch(i)
139         {
140                 case 0: return _("Gradient");
141                 case 1: return _("Index");
142                 case 2: return _("Loop");
143         }
144         return String();
145 }
146
147 String
148 ValueNode_GradientColor::link_name(int i)const
149 {
150         assert(i>=0 && i<link_count());
151
152         switch(i)
153         {
154                 case 0: return "gradient";
155                 case 1: return "index";
156                 case 2: return "loop";
157         }
158         return String();
159 }
160
161 int
162 ValueNode_GradientColor::get_link_index_from_name(const String &name)const
163 {
164         if (name=="gradient") return 0;
165         if (name=="index")        return 1;
166         if (name=="loop")         return 2;
167         throw Exception::BadLinkName(name);
168 }
169
170 String
171 ValueNode_GradientColor::get_name()const
172 {
173         return "gradientcolor";
174 }
175
176 String
177 ValueNode_GradientColor::get_local_name()const
178 {
179         return _("Gradient Color");
180 }
181
182 bool
183 ValueNode_GradientColor::check_type(ValueBase::Type type)
184 {
185         return type==ValueBase::TYPE_COLOR;
186 }