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

148 lines
3.4 KiB
C++
Raw Normal View History

// Generated by gtkmmproc -- DO NOT MODIFY!
#include <gtkmm/menubar.h>
#include <gtkmm/private/menubar_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/gtkmenubar.h>
namespace Gtk
{
MenuBar::MenuBar()
:
Glib::ObjectBase(0), //Mark this class as gtkmmproc-generated, rather than a custom class, to allow vfunc optimisations.
Gtk::MenuShell(Glib::ConstructParams(menubar_class_.init(), (char*) 0))
{
// Connect to the signal instead of overriding the on_hierarchy_changed()
// method because invocation of C++ default signal handlers is skipped
// for gtkmmproc-generated classes (a gtkmm-wide optimization).
signal_realize().connect(sigc::mem_fun(*this, &MenuBar::init_accels_handler_));
}
void MenuBar::init_accels_handler_()
{
if(gobj())
{
if(Window *const toplevel = dynamic_cast<Window*>(get_toplevel()))
{
accelerate(*toplevel);
}
}
}
} // namespace Gtk
namespace
{
} // anonymous namespace
namespace Glib
{
Gtk::MenuBar* wrap(GtkMenuBar* object, bool take_copy)
{
return dynamic_cast<Gtk::MenuBar *> (Glib::wrap_auto ((GObject*)(object), take_copy));
}
} /* namespace Glib */
namespace Gtk
{
/* The *_Class implementation: */
const Glib::Class& MenuBar_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_ = &MenuBar_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_menu_bar_get_type());
// Add derived versions of interfaces, if the C type implements any interfaces:
}
return *this;
}
void MenuBar_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);
}
Glib::ObjectBase* MenuBar_Class::wrap_new(GObject* o)
{
return manage(new MenuBar((GtkMenuBar*)(o)));
}
/* The implementation: */
MenuBar::MenuBar(const Glib::ConstructParams& construct_params)
:
Gtk::MenuShell(construct_params)
{
}
MenuBar::MenuBar(GtkMenuBar* castitem)
:
Gtk::MenuShell((GtkMenuShell*)(castitem))
{
}
MenuBar::~MenuBar()
{
destroy_();
}
MenuBar::CppClassType MenuBar::menubar_class_; // initialize static member
GType MenuBar::get_type()
{
return menubar_class_.init().get_type();
}
GType MenuBar::get_base_type()
{
return gtk_menu_bar_get_type();
}
} // namespace Gtk