175 lines
4.9 KiB
C
175 lines
4.9 KiB
C
|
// -*- c++ -*-
|
||
|
// Generated by gtkmmproc -- DO NOT MODIFY!
|
||
|
#ifndef _GIOMM_THEMEDICON_H
|
||
|
#define _GIOMM_THEMEDICON_H
|
||
|
|
||
|
|
||
|
#include <glibmm.h>
|
||
|
|
||
|
// -*- Mode: C++; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
||
|
|
||
|
/* Copyright (C) 2007 The gtkmm Development Team
|
||
|
*
|
||
|
* This library is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU Library General Public
|
||
|
* License as published by the Free Software Foundation; either
|
||
|
* version 2 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
|
||
|
* Library General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Library General Public
|
||
|
* License along with this library; if not, write to the Free
|
||
|
* Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||
|
*/
|
||
|
|
||
|
#include <glibmm/object.h>
|
||
|
#include <giomm/file.h>
|
||
|
#include <giomm/icon.h>
|
||
|
#include <giomm/loadableicon.h>
|
||
|
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
typedef struct _GThemedIcon GThemedIcon;
|
||
|
typedef struct _GThemedIconClass GThemedIconClass;
|
||
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
||
|
|
||
|
|
||
|
namespace Gio
|
||
|
{ class ThemedIcon_Class; } // namespace Gio
|
||
|
namespace Gio
|
||
|
{
|
||
|
|
||
|
/** Icon theming support
|
||
|
* ThemedIcon is an implementation of Gio::Icon that supports icon themes.
|
||
|
* ThemedIcon contains a list of all of the icons present in an icon
|
||
|
* theme, so that icons can be looked up quickly. ThemedIcon does
|
||
|
* not provide actual pixmaps for icons, just the icon names.
|
||
|
* Ideally something like Gtk::IconTheme::choose_icon() should be used to
|
||
|
* resolve the list of names so that fallback icons work nicely with
|
||
|
* themes that inherit other themes.
|
||
|
*
|
||
|
* @newin2p16
|
||
|
*/
|
||
|
|
||
|
class ThemedIcon
|
||
|
: public Glib::Object,
|
||
|
public Icon
|
||
|
{
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
|
||
|
public:
|
||
|
typedef ThemedIcon CppObjectType;
|
||
|
typedef ThemedIcon_Class CppClassType;
|
||
|
typedef GThemedIcon BaseObjectType;
|
||
|
typedef GThemedIconClass BaseClassType;
|
||
|
|
||
|
private: friend class ThemedIcon_Class;
|
||
|
static CppClassType themedicon_class_;
|
||
|
|
||
|
private:
|
||
|
// noncopyable
|
||
|
ThemedIcon(const ThemedIcon&);
|
||
|
ThemedIcon& operator=(const ThemedIcon&);
|
||
|
|
||
|
protected:
|
||
|
explicit ThemedIcon(const Glib::ConstructParams& construct_params);
|
||
|
explicit ThemedIcon(GThemedIcon* castitem);
|
||
|
|
||
|
#endif /* DOXYGEN_SHOULD_SKIP_THIS */
|
||
|
|
||
|
public:
|
||
|
virtual ~ThemedIcon();
|
||
|
|
||
|
#ifndef DOXYGEN_SHOULD_SKIP_THIS
|
||
|
static GType get_type() G_GNUC_CONST;
|
||
|
static GType get_base_type() G_GNUC_CONST;
|
||
|
#endif
|
||
|
|
||
|
///Provides access to the underlying C GObject.
|
||
|
GThemedIcon* gobj() { return reinterpret_cast<GThemedIcon*>(gobject_); }
|
||
|
|
||
|
///Provides access to the underlying C GObject.
|
||
|
const GThemedIcon* gobj() const { return reinterpret_cast<GThemedIcon*>(gobject_); }
|
||
|
|
||
|
///Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
|
||
|
GThemedIcon* gobj_copy();
|
||
|
|
||
|
private:
|
||
|
|
||
|
|
||
|
protected:
|
||
|
//TODO: Documentation:
|
||
|
explicit ThemedIcon(const std::string& iconname, bool use_default_callbacks = false);
|
||
|
|
||
|
|
||
|
public:
|
||
|
|
||
|
static Glib::RefPtr<ThemedIcon> create(const std::string& iconname, bool use_default_callbacks = false);
|
||
|
|
||
|
|
||
|
//TODO: GIcon *g_themed_icon_new_from_names (char **iconnames, int len);
|
||
|
|
||
|
|
||
|
void prepend_name(const std::string& iconname);
|
||
|
|
||
|
/** Append a name to the list of icons from within @a icon.
|
||
|
* @param iconname Name of icon to append to list of icons from within @a icon.
|
||
|
*/
|
||
|
void append_name(const std::string& iconname);
|
||
|
|
||
|
|
||
|
//TODO: gmmproc complains about the wrong number of arguments, but I can't see why. murrayc.
|
||
|
//_WRAP_METHOD(Glib::StringArrayHandle get_names() const, g_themed_icon_get_names)
|
||
|
|
||
|
|
||
|
//There are no signals.
|
||
|
|
||
|
//TODO: Remove these when we can break ABI. They are write-only and construct-only.
|
||
|
//gtkmmproc error: name : attempt to wrap write-only and construct-only property.
|
||
|
//An array: This is awkward to wrap_WRAP_PROPERTY("names", )
|
||
|
//gtkmmproc error: use-default-fallbacks : attempt to wrap write-only and construct-only property.
|
||
|
|
||
|
|
||
|
public:
|
||
|
|
||
|
public:
|
||
|
//C++ methods used to invoke GTK+ virtual functions:
|
||
|
#ifdef GLIBMM_VFUNCS_ENABLED
|
||
|
#endif //GLIBMM_VFUNCS_ENABLED
|
||
|
|
||
|
protected:
|
||
|
//GTK+ Virtual Functions (override these to change behaviour):
|
||
|
#ifdef GLIBMM_VFUNCS_ENABLED
|
||
|
#endif //GLIBMM_VFUNCS_ENABLED
|
||
|
|
||
|
//Default Signal Handlers::
|
||
|
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
|
||
|
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
|
||
|
|
||
|
|
||
|
};
|
||
|
|
||
|
} // 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::ThemedIcon
|
||
|
*/
|
||
|
Glib::RefPtr<Gio::ThemedIcon> wrap(GThemedIcon* object, bool take_copy = false);
|
||
|
}
|
||
|
|
||
|
|
||
|
#endif /* _GIOMM_THEMEDICON_H */
|
||
|
|