source: synfigstudio/trunk/fuentes/src/synfigapp/actions/valuedescconnect.cpp @ 481

Last change on this file since 481 was 481, checked in by jrpelegrina, 4 years ago

First release to xenial

File size: 7.0 KB
Line 
1/* === S Y N F I G ========================================================= */
2/*!     \file valuedescconnect.cpp
3**      \brief Template File
4**
5**      $Id$
6**
7**      \legal
8**      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9**      Copyright (c) 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 "layerparamconnect.h"
34#include "waypointconnect.h"
35#include "valuenodelinkconnect.h"
36#include "valuenodereplace.h"
37
38#include "valuedescconnect.h"
39#include <synfigapp/canvasinterface.h>
40
41#include <synfigapp/general.h>
42
43#endif
44
45using namespace std;
46using namespace etl;
47using namespace synfig;
48using namespace synfigapp;
49using namespace Action;
50
51/* === M A C R O S ========================================================= */
52
53ACTION_INIT_NO_GET_LOCAL_NAME(Action::ValueDescConnect);
54ACTION_SET_NAME(Action::ValueDescConnect,"ValueDescConnect");
55ACTION_SET_LOCAL_NAME(Action::ValueDescConnect,N_("Connect"));
56ACTION_SET_TASK(Action::ValueDescConnect,"connect");
57ACTION_SET_CATEGORY(Action::ValueDescConnect,Action::CATEGORY_VALUEDESC|Action::CATEGORY_VALUENODE);
58ACTION_SET_PRIORITY(Action::ValueDescConnect,0);
59ACTION_SET_VERSION(Action::ValueDescConnect,"0.0");
60ACTION_SET_CVS_ID(Action::ValueDescConnect,"$Id$");
61
62/* === G L O B A L S ======================================================= */
63
64/* === P R O C E D U R E S ================================================= */
65
66/* === M E T H O D S ======================================================= */
67
68Action::ValueDescConnect::ValueDescConnect()
69{
70}
71
72synfig::String
73Action::ValueDescConnect::get_local_name()const
74{
75        // TRANSLATORS: This is used in the 'history' dialog when a connection is made.
76        return strprintf(_("Connect '%s' to '%s'"),
77                                         value_desc.get_description(false).c_str(),
78                                         value_node->get_id().c_str());
79}
80
81Action::ParamVocab
82Action::ValueDescConnect::get_param_vocab()
83{
84        ParamVocab ret(Action::CanvasSpecific::get_param_vocab());
85
86        ret.push_back(ParamDesc("dest",Param::TYPE_VALUEDESC)
87                .set_local_name(_("Destination ValueDesc"))
88        );
89
90        ret.push_back(ParamDesc("src",Param::TYPE_VALUENODE)
91                .set_local_name(_("Source ValueNode"))
92                .set_mutual_exclusion("src_name")
93        );
94
95        ret.push_back(ParamDesc("src_name",Param::TYPE_STRING)
96                .set_local_name(_("Source ValueNode Name"))
97                .set_mutual_exclusion("src")
98                .set_user_supplied()
99        );
100
101        return ret;
102}
103
104bool
105Action::ValueDescConnect::is_candidate(const ParamList &x)
106{
107        if(candidate_check(get_param_vocab(),x))
108        {
109            ValueDesc value_desc(x.find("dest")->second.get_value_desc());
110            ValueNode::Handle value_node(x.find("src")->second.get_value_node());
111
112            //! forbid recursive linking (fix #48)
113            if (value_desc.parent_is_value_node())
114            {
115                ValueNode* vn = dynamic_cast<ValueNode*>(value_node.get());
116                if (vn && vn->is_descendant(value_desc.get_parent_value_node()))
117                    return false;
118            }
119
120
121                // don't show the option of connecting to an existing Index parameter of the Duplicate layer
122                if(x.count("dest"))
123                {
124                        if (value_desc.parent_is_layer() &&
125                                value_desc.get_layer()->get_name() == "duplicate" &&
126                                value_desc.get_param_name() == "index")
127                                return false;
128                }
129
130                if(x.count("src"))
131                {
132                        if(value_desc.get_value_type()==value_node->get_type())
133                                return true;
134                }
135                return true;
136        }
137        return false;
138}
139
140bool
141Action::ValueDescConnect::set_param(const synfig::String& name, const Action::Param &param)
142{
143        if(name=="dest" && param.get_type()==Param::TYPE_VALUEDESC)
144        {
145                value_desc=param.get_value_desc();
146
147                return true;
148        }
149
150        if(name=="src" && param.get_type()==Param::TYPE_VALUENODE)
151        {
152                value_node=param.get_value_node();
153
154                return true;
155        }
156
157        if(!value_node_name.empty() && !value_node && name=="canvas" && param.get_type()==Param::TYPE_CANVAS)
158        {
159                value_node=param.get_canvas()->find_value_node(value_node_name, false);
160        }
161
162        if(name=="src_name" && param.get_type()==Param::TYPE_STRING)
163        {
164                value_node_name=param.get_string();
165
166                if(get_canvas())
167                {
168                        value_node=get_canvas()->find_value_node(value_node_name, false);
169                        if(!value_node)
170                                return false;
171                }
172
173                return true;
174        }
175
176        return Action::CanvasSpecific::set_param(name,param);
177}
178
179bool
180Action::ValueDescConnect::is_ready()const
181{
182        if(!value_desc || !value_node)
183                return false;
184        return Action::CanvasSpecific::is_ready();
185}
186
187void
188Action::ValueDescConnect::prepare()
189{
190        clear();
191
192        if(value_desc.parent_is_canvas())
193        {
194                ValueNode::Handle dest_value_node;
195                dest_value_node=value_desc.get_value_node();
196
197                Action::Handle action(ValueNodeReplace::create());
198
199                action->set_param("canvas",get_canvas());
200                action->set_param("canvas_interface",get_canvas_interface());
201                action->set_param("src",value_node);
202                action->set_param("dest",value_desc.get_value_node());
203
204                assert(action->is_ready());
205                if(!action->is_ready())
206                        throw Error(Error::TYPE_NOTREADY);
207
208                add_action_front(action);
209                return;
210        }
211        else
212        if(value_desc.parent_is_waypoint())
213        {
214                Action::Handle action(WaypointConnect::create());
215
216                action->set_param("canvas",get_canvas());
217                action->set_param("canvas_interface",get_canvas_interface());
218                action->set_param("parent_value_node",value_desc.get_parent_value_node());
219                action->set_param("value_node", value_node);
220                action->set_param("waypoint_time",value_desc.get_waypoint_time());
221
222                assert(action->is_ready());
223                if(!action->is_ready())
224                        throw Error(Error::TYPE_NOTREADY);
225
226                add_action_front(action);
227                return;
228        }
229        if(value_desc.parent_is_linkable_value_node())
230        {
231                Action::Handle action(ValueNodeLinkConnect::create());
232
233                action->set_param("canvas",get_canvas());
234                action->set_param("canvas_interface",get_canvas_interface());
235                action->set_param("parent_value_node",value_desc.get_parent_value_node());
236                action->set_param("value_node", value_node);
237                action->set_param("index",value_desc.get_index());
238
239                assert(action->is_ready());
240                if(!action->is_ready())
241                        throw Error(Error::TYPE_NOTREADY);
242
243                add_action_front(action);
244                return;
245        }
246        else
247        if(value_desc.parent_is_layer())
248        {
249                Action::Handle action(LayerParamConnect::create());
250
251                action->set_param("canvas",get_canvas());
252                action->set_param("canvas_interface",get_canvas_interface());
253                action->set_param("layer",value_desc.get_layer());
254                action->set_param("param",value_desc.get_param_name());
255                action->set_param("value_node",value_node);
256
257                assert(action->is_ready());
258                if(!action->is_ready())
259                        throw Error(Error::TYPE_NOTREADY);
260
261                add_action_front(action);
262                return;
263        }
264
265        throw Error(_("ValueDesc is not recognized or supported."));
266}
Note: See TracBrowser for help on using the repository browser.