// -*- c++ -*- // Generated by gmmproc 2.46.3 -- DO NOT MODIFY! #ifndef _GIOMM_ACTIONMAP_H #define _GIOMM_ACTIONMAP_H #include #include /* Copyright (C) 2012 The giomm Development Team * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GActionMapInterface GActionMapInterface; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GActionMap GActionMap; typedef struct _GActionMapClass GActionMapClass; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ #ifndef DOXYGEN_SHOULD_SKIP_THIS namespace Gio { class ActionMap_Class; } // namespace Gio #endif // DOXYGEN_SHOULD_SKIP_THIS namespace Gio { class Action; //TODO: Instead derive from ActionGroup, when we can break ABI, //because the GActionMap interface requires the GActionGroup interface. //LoadableIcon does a similar thing correctly, for instance. /** ActionMap - Interface for action containers. * The ActionMap interface is implemented by ActionGroup implementations that * operate by containing a number of named Action instances, such as * SimpleActionGroup. * * One useful application of this interface is to map the names of actions from * various action groups to unique, prefixed names (e.g. by prepending "app." * or "win."). This is the motivation for the 'Map' part of the interface name. * @newin{2,32} */ class ActionMap : public Glib::Interface { #ifndef DOXYGEN_SHOULD_SKIP_THIS public: typedef ActionMap CppObjectType; typedef ActionMap_Class CppClassType; typedef GActionMap BaseObjectType; typedef GActionMapInterface BaseClassType; // noncopyable ActionMap(const ActionMap&) = delete; ActionMap& operator=(const ActionMap&) = delete; private: friend class ActionMap_Class; static CppClassType actionmap_class_; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ protected: /** * You should derive from this class to use it. */ ActionMap(); #ifndef DOXYGEN_SHOULD_SKIP_THIS /** Called by constructors of derived classes. Provide the result of * the Class init() function to ensure that it is properly * initialized. * * @param interface_class The Class object for the derived type. */ explicit ActionMap(const Glib::Interface_Class& interface_class); public: // This is public so that C++ wrapper instances can be // created for C instances of unwrapped types. // For instance, if an unexpected C type implements the C interface. explicit ActionMap(GActionMap* castitem); protected: #endif /* DOXYGEN_SHOULD_SKIP_THIS */ public: ActionMap(ActionMap&& src) noexcept; ActionMap& operator=(ActionMap&& src) noexcept; virtual ~ActionMap() noexcept; static void add_interface(GType gtype_implementer); /** Get the GType for this class, for use with the underlying GObject type system. */ static GType get_type() G_GNUC_CONST; #ifndef DOXYGEN_SHOULD_SKIP_THIS static GType get_base_type() G_GNUC_CONST; #endif ///Provides access to the underlying C GObject. GActionMap* gobj() { return reinterpret_cast(gobject_); } ///Provides access to the underlying C GObject. const GActionMap* gobj() const { return reinterpret_cast(gobject_); } private: public: /** Looks up the action with the name @a action_name in @a action_map. * * If no such action exists, returns 0. * * @newin{2,32} * * @param action_name The name of an action. * @return A Action, or 0. */ Glib::RefPtr lookup_action(const Glib::ustring& action_name); /** Looks up the action with the name @a action_name in @a action_map. * * If no such action exists, returns 0. * * @newin{2,32} * * @param action_name The name of an action. * @return A Action, or 0. */ Glib::RefPtr lookup_action(const Glib::ustring& action_name) const; /** A Slot to be called when an action has been activated. * See add_action_with_parameter(). * * For instance, * void on_slot_activated(const Glib::VariantBase& parameter); */ typedef sigc::slot< void, const Glib::VariantBase& > ActivateWithParameterSlot; //This is an equivalent for g_action_map_add_action_entries(). /** A convenience method for creating a SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @return The Action. */ Glib::RefPtr add_action(const Glib::ustring& name); //This is an equivalent for g_action_map_add_action_entries(). /** A convenience method for creating a SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param slot The callback method to be called when the action is activated. * @return The Action. */ Glib::RefPtr add_action_with_parameter(const Glib::ustring& name, const ActivateWithParameterSlot& slot); /** A Slot to be called when an action has been activated, * without passing a parameter to the slot. * See add_action(). * * For instance, * void on_slot_activated(); */ typedef sigc::slot ActivateSlot; /** A convenience method for creating a SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param slot The callback method to be called when the action is activated. * @return The Action. */ Glib::RefPtr add_action(const Glib::ustring& name, const ActivateSlot& slot); /** A convenience method for creating a boolean-stateful SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_bool(const Glib::ustring& name, bool state = false); /** A convenience method for creating a boolean-stateful (toggle) SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param slot The callback method to be called when the action is activated. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_bool(const Glib::ustring& name, const ActivateSlot& slot, bool state = false); //TODO: Docs: Add hints about how to specify the various possible states in the GtkBuilder XML. /** A convenience method for creating a string-based radio SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_radio_string(const Glib::ustring& name, const Glib::ustring& state); /** A Slot to be called when an action has been activated. * See add_action_radio_string(). * * For instance, * void on_slot_activated(const Glib::VariantBase& parameter); */ typedef sigc::slot< void, const Glib::ustring& > ActivateWithStringParameterSlot; //TODO: Docs: Add hints about how to specify the various possible states in the GtkBuilder XML. /** A convenience method for creating a string-based radio SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param slot The callback method to be called when the action is activated. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_radio_string(const Glib::ustring& name, const ActivateWithStringParameterSlot& slot, const Glib::ustring& state); //TODO: Docs: Add hints about how to specify the various possible states in the GtkBuilder XML. /** A convenience method for creating an integer-based radio SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_radio_integer(const Glib::ustring& name, gint32 state); /** A Slot to be called when an action has been activated. * See add_action_radio_int(). * * For instance, * void on_slot_activated(const Glib::VariantBase& parameter); */ typedef sigc::slot< void, int > ActivateWithIntParameterSlot; //TODO: Docs: Add hints about how to specify the various possible states in the GtkBuilder XML. /** A convenience method for creating an integer-based radio SimpleAction instance * and adding it to the ActionMap. * * @param name The name of the Action. * @param slot The callback method to be called when the action is activated. * @param state The initial state. * @return The Action. */ Glib::RefPtr add_action_radio_integer(const Glib::ustring& name, const ActivateWithIntParameterSlot& slot, gint32 state); /** Adds an action to the @a action_map. * * If the action map already contains an action with the same name * as @a action then the old action is dropped from the action map. * * The action map takes its own reference on @a action. * * @newin{2,32} * * @param action A Action. */ void add_action(const Glib::RefPtr& action); /** Removes the named action from the action map. * * If no action of this name is in the map then nothing happens. * * @newin{2,32} * * @param action_name The name of the action. */ void remove_action(const Glib::ustring& action_name); virtual Glib::RefPtr lookup_action_vfunc(const Glib::ustring& name) const; //TODO: Change this to use const & when we can break ABI. // ( Changing it causes a symbol lookup error when trying to run already-built applications. ) virtual void add_action_vfunc(Glib::RefPtr action) const; virtual void remove_action_vfunc(const Glib::ustring& name); public: public: //C++ methods used to invoke GTK+ virtual functions: protected: //GTK+ Virtual Functions (override these to change behaviour): //Default Signal Handlers:: }; } // namespace Gio namespace Glib { /** A Glib::wrap() method for this object. * * @param object The C instance. * @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref. * @result A C++ instance that wraps this C instance. * * @relates Gio::ActionMap */ Glib::RefPtr wrap(GActionMap* object, bool take_copy = false); } // namespace Glib #endif /* _GIOMM_ACTIONMAP_H */