13
0
livetrax/libs/gtkmm2/gtk/gtkmm/imagemenuitem.cc

216 lines
5.1 KiB
C++
Raw Normal View History

// Generated by gtkmmproc -- DO NOT MODIFY!
#include <gtkmm/imagemenuitem.h>
#include <gtkmm/private/imagemenuitem_p.h>
// -*- c++ -*-
/* $Id$ */
/*
*
* Copyright 1998-2002 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 <gtk/gtkimagemenuitem.h>
#include <gtkmm/image.h>
#include <gtkmm/stock.h>
#include <gtkmm/accellabel.h>
namespace Gtk
{
ImageMenuItem::ImageMenuItem(Widget& image,
const Glib::ustring& label, bool mnemonic)
:
// Mark this class as non-derived to allow C++ vfuncs to be skipped.
Glib::ObjectBase(0),
Gtk::MenuItem(Glib::ConstructParams(imagemenuitem_class_.init()))
{
set_image(image);
add_accel_label(label, mnemonic);
}
ImageMenuItem::ImageMenuItem(const Glib::ustring& label, bool mnemonic)
:
// Mark this class as non-derived to allow C++ vfuncs to be skipped.
Glib::ObjectBase(0),
Gtk::MenuItem(Glib::ConstructParams(imagemenuitem_class_.init()))
{
add_accel_label(label, mnemonic);
}
ImageMenuItem::ImageMenuItem(const Gtk::StockID& stock_id)
:
// Mark this class as non-derived to allow C++ vfuncs to be skipped.
Glib::ObjectBase(0),
Gtk::MenuItem(Glib::ConstructParams(imagemenuitem_class_.init()))
{
Gtk::Image* image = new Gtk::Image(stock_id, ICON_SIZE_MENU);
image->show();
set_image( *(Gtk::manage(image)) );
Gtk::StockItem item;
if(Gtk::Stock::lookup(stock_id, item))
{
add_accel_label(item.get_label(), true); //true = use mnemonic.
set_accel_key( AccelKey(item.get_keyval(), item.get_modifier()) );
}
else
{
add_accel_label(stock_id.get_string(), false);
}
}
} // namespace Gtk
namespace
{
} // anonymous namespace
namespace Glib
{
Gtk::ImageMenuItem* wrap(GtkImageMenuItem* object, bool take_copy)
{
return dynamic_cast<Gtk::ImageMenuItem *> (Glib::wrap_auto ((GObject*)(object), take_copy));
}
} /* namespace Glib */
namespace Gtk
{
/* The *_Class implementation: */
const Glib::Class& ImageMenuItem_Class::init()
{
if(!gtype_) // create the GType if necessary
{
// Glib::Class has to know the class init function to clone custom types.
class_init_func_ = &ImageMenuItem_Class::class_init_function;
// This is actually just optimized away, apparently with no harm.
// Make sure that the parent type has been created.
//CppClassParent::CppObjectType::get_type();
// Create the wrapper type, with the same class/instance size as the base type.
register_derived_type(gtk_image_menu_item_get_type());
// Add derived versions of interfaces, if the C type implements any interfaces:
}
return *this;
}
void ImageMenuItem_Class::class_init_function(void* g_class, void* class_data)
{
BaseClassType *const klass = static_cast<BaseClassType*>(g_class);
CppClassParent::class_init_function(klass, class_data);
#ifdef GLIBMM_VFUNCS_ENABLED
#endif //GLIBMM_VFUNCS_ENABLED
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
}
#ifdef GLIBMM_VFUNCS_ENABLED
#endif //GLIBMM_VFUNCS_ENABLED
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
Glib::ObjectBase* ImageMenuItem_Class::wrap_new(GObject* o)
{
return manage(new ImageMenuItem((GtkImageMenuItem*)(o)));
}
/* The implementation: */
ImageMenuItem::ImageMenuItem(const Glib::ConstructParams& construct_params)
:
Gtk::MenuItem(construct_params)
{
}
ImageMenuItem::ImageMenuItem(GtkImageMenuItem* castitem)
:
Gtk::MenuItem((GtkMenuItem*)(castitem))
{
}
ImageMenuItem::~ImageMenuItem()
{
destroy_();
}
ImageMenuItem::CppClassType ImageMenuItem::imagemenuitem_class_; // initialize static member
GType ImageMenuItem::get_type()
{
return imagemenuitem_class_.init().get_type();
}
GType ImageMenuItem::get_base_type()
{
return gtk_image_menu_item_get_type();
}
ImageMenuItem::ImageMenuItem()
:
// Mark this class as non-derived to allow C++ vfuncs to be skipped.
Glib::ObjectBase(0),
Gtk::MenuItem(Glib::ConstructParams(imagemenuitem_class_.init()))
{
}
void ImageMenuItem::set_image(Widget& image)
{
gtk_image_menu_item_set_image(gobj(), (image).gobj());
}
Widget* ImageMenuItem::get_image()
{
return Glib::wrap(gtk_image_menu_item_get_image(gobj()));
}
const Widget* ImageMenuItem::get_image() const
{
return const_cast<ImageMenuItem*>(this)->get_image();
}
#ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
#endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED
#ifdef GLIBMM_VFUNCS_ENABLED
#endif //GLIBMM_VFUNCS_ENABLED
} // namespace Gtk