X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fsynfigapp%2Faction.h;h=1dec9c57eed879457d73274b00738aeda45870ed;hb=9459638ad6797b8139f1e9f0715c96076dbf0890;hp=d113bc4ea21c7433b390892b2185b3d824333a07;hpb=c34eaa5441242b3e9a7b7645e9ee4983d14eae85;p=synfig.git diff --git a/synfig-studio/trunk/src/synfigapp/action.h b/synfig-studio/trunk/src/synfigapp/action.h index d113bc4..1dec9c5 100644 --- a/synfig-studio/trunk/src/synfigapp/action.h +++ b/synfig-studio/trunk/src/synfigapp/action.h @@ -2,10 +2,11 @@ /*! \file action.h ** \brief Template File ** -** $Id: action.h,v 1.1.1.1 2005/01/07 03:34:37 darco Exp $ +** $Id$ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2008 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -74,10 +75,14 @@ #define ACTION_SET_CVS_ID(class,x) const char class::cvs_id__[]=x -#define ACTION_INIT(class) \ - Action::Base* class::create() { return new class(); } \ - synfig::String class::get_name()const { return name__; } \ - synfig::String class::get_local_name()const { return local_name__; } \ +//! don't define get_local_name() - allow the action code to define its own +#define ACTION_INIT_NO_GET_LOCAL_NAME(class) \ + Action::Base* class::create() { return new class(); } \ + synfig::String class::get_name()const { return name__; } + +#define ACTION_INIT(class) \ + ACTION_INIT_NO_GET_LOCAL_NAME(class) \ + synfig::String class::get_local_name()const { return dgettext("synfigstudio",local_name__); } /* === T Y P E D E F S ===================================================== */ @@ -163,6 +168,7 @@ enum Category CATEGORY_VALUENODE =(1<<5), CATEGORY_KEYFRAME =(1<<6), CATEGORY_GROUP =(1<<7), + CATEGORY_BEZIER =(1<<8), CATEGORY_OTHER =(1<<12), @@ -177,14 +183,14 @@ inline Category operator|(Category lhs, Category rhs) -//! Action Base Class +//! Top-level base class for all actions /*! An action should implement the following functions: -** static bool is_candidate(const ParamList &x); +** - static bool is_candidate(const ParamList &x); ** - Checks the ParamList to see if this action could be performed. -** static ParamVocab get_param_vocab(); +** - static ParamVocab get_param_vocab(); ** - Yields the ParamVocab object which describes what ** this action needs before it can perform the act. -** static Action::Base* create(); +** - static Action::Base* create(); ** - Factory for creating this action from a ParamList ** */ @@ -199,7 +205,7 @@ public: //! This function will throw an Action::Error() on failure virtual void perform()=0; - virtual bool set_param(const synfig::String& name, const Param &) { return false; } + virtual bool set_param(const synfig::String& /*name*/, const Param &) { return false; } virtual bool is_ready()const=0; virtual synfig::String get_name()const =0; @@ -207,6 +213,8 @@ public: void set_param_list(const ParamList &); + static synfig::String get_layer_descriptions(const std::list layers, synfig::String singular_prefix = "", synfig::String plural_prefix = ""); + static synfig::String get_layer_descriptions(const std::list > layers, synfig::String singular_prefix = "", synfig::String plural_prefix = ""); }; // END of class Action::Base typedef Action::Base* (*Factory)(); @@ -322,7 +330,7 @@ public: virtual void prepare() { }; - virtual bool set_param(const synfig::String& name, const Param &)const { return false; } + virtual bool set_param(const synfig::String& /*name*/, const Param &)const { return false; } virtual bool is_ready()const { return ready_; } void set_name(std::string&x) { name_=x; }