X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fsynfigapp%2Factions%2Fvaluedescexport.cpp;h=b0fdc6228b8d5decd6b0c5e97ae8de213a629f17;hb=bda3e22bcdbeddee4c63d21e47bb1baeb9ca4d30;hp=64614704ec1751f405554c4e6fc10e6e34c563fa;hpb=6989d1403b14b5b27dbf81b2c1cf6889511adf97;p=synfig.git diff --git a/synfig-studio/trunk/src/synfigapp/actions/valuedescexport.cpp b/synfig-studio/trunk/src/synfigapp/actions/valuedescexport.cpp index 6461470..b0fdc62 100644 --- a/synfig-studio/trunk/src/synfigapp/actions/valuedescexport.cpp +++ b/synfig-studio/trunk/src/synfigapp/actions/valuedescexport.cpp @@ -35,6 +35,7 @@ #include "canvasadd.h" #include "valuedescexport.h" #include "layerparamconnect.h" +#include "layerparamset.h" #include #include @@ -103,8 +104,22 @@ Action::ValueDescExport::is_candidate(const ParamList &x) if(candidate_check(get_param_vocab(),x)) { ValueDesc value_desc=x.find("value_desc")->second.get_value_desc(); - if(!value_desc || value_desc.parent_is_canvas() || (value_desc.is_value_node() && value_desc.get_value_node()->is_exported())) + if(!value_desc || + value_desc.parent_is_canvas() || + (value_desc.is_value_node() && value_desc.get_value_node()->is_exported()) || + (value_desc.get_value_type()==ValueBase::TYPE_CANVAS && !value_desc.get_value().get(Canvas::Handle())->is_inline())) + { +// if (!value_desc) +// synfig::info("%s:%d no export because no value_desc", __FILE__, __LINE__); +// else if (value_desc.parent_is_canvas()) +// synfig::info("%s:%d no export because parent is canvas", __FILE__, __LINE__); +// else if (value_desc.is_value_node() && value_desc.get_value_node()->is_exported()) +// synfig::info("%s:%d no export because exported value node", __FILE__, __LINE__); +// else if (value_desc.get_value_type()==ValueBase::TYPE_CANVAS && !value_desc.get_value().get(Canvas::Handle())->is_inline()) +// synfig::info("%s:%d no export because canvas isn't inline", __FILE__, __LINE__); + return false; + } return true; } return false; @@ -151,6 +166,7 @@ Action::ValueDescExport::prepare() if(!value_desc.is_const()) throw Error(_("Can only export Canvas when used as constant parameter")); Canvas::Handle canvas(value_desc.get_value().get(Canvas::Handle())); + if (canvas) canvas=canvas->clone(); Action::Handle action(CanvasAdd::create()); @@ -165,6 +181,24 @@ Action::ValueDescExport::prepare() add_action_front(action); + if(value_desc.parent_is_layer_param() && !value_desc.is_value_node()) + { + // action: LayerParamSet + Action::Handle action(LayerParamSet::create()); + + action->set_param("canvas",get_canvas()); + action->set_param("canvas_interface",get_canvas_interface()); + action->set_param("layer",value_desc.get_layer()); + action->set_param("param",value_desc.get_param_name()); + action->set_param("new_value",ValueBase(canvas)); + + assert(action->is_ready()); + if(!action->is_ready()) + throw Error(Error::TYPE_NOTREADY); + + add_action_front(action); + } + return; }