// Generated by gmmproc 2.54.0 -- DO NOT MODIFY!
#include <glibmm.h>
#include <gtkmm/filefilter.h>
#include <gtkmm/private/filefilter_p.h>
/* Copyright 2003 The gtkmm 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <gtk/gtk.h> //For gtk_file_filter_flags_get_type().
static gboolean SignalProxy_Custom_gtk_callback(const GtkFileFilterInfo* filter_info, gpointer data)
{
auto the_slot = static_cast<Gtk::FileFilter::SlotCustom*>(data);
try
{
//Create a suitable C++ instance to pass to the C++ method:
Gtk::FileFilter::Info cppInfo;
cppInfo.contains = (Gtk::FileFilterFlags)filter_info->contains;
cppInfo.filename = Glib::convert_const_gchar_ptr_to_ustring(filter_info->filename);
cppInfo.uri = Glib::convert_const_gchar_ptr_to_ustring(filter_info->uri);
cppInfo.display_name = Glib::convert_const_gchar_ptr_to_ustring(filter_info->display_name);
cppInfo.mime_type = Glib::convert_const_gchar_ptr_to_ustring(filter_info->mime_type);
return (*the_slot)(cppInfo);
}
catch(...)
{
Glib::exception_handlers_invoke();
return false; //arbitrary default;
}
}
static void SignalProxy_Custom_gtk_callback_destroy(void* data)
{
delete static_cast<Gtk::FileFilter::SlotCustom*>(data);
}
namespace Gtk
{
void FileFilter::add_custom(FileFilterFlags needed, const SlotCustom& slot)
{
//Create a copy of the slot. A pointer to this will be passed through the callback's data parameter.
//It will be deleted when SignalProxy_Custom::gtk_callback_destroy() is called.
auto slot_copy = new SlotCustom(slot);
gtk_file_filter_add_custom(gobj(), (GtkFileFilterFlags)needed,
&SignalProxy_Custom_gtk_callback,
slot_copy,
&SignalProxy_Custom_gtk_callback_destroy);
}
} // namespace Gtk
namespace
{
} // anonymous namespace
// static
GType Glib::Value<Gtk::FileFilterFlags>::value_type()
{
return gtk_file_filter_flags_get_type();
}
namespace Glib
{
Glib::RefPtr<Gtk::FileFilter> wrap(GtkFileFilter* object, bool take_copy)
{
return Glib::RefPtr<Gtk::FileFilter>( dynamic_cast<Gtk::FileFilter*> (Glib::wrap_auto ((GObject*)(object), take_copy)) );
//We use dynamic_cast<> in case of multiple inheritance.
}
} /* namespace Glib */
namespace Gtk
{
/* The *_Class implementation: */
const Glib::Class& FileFilter_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_ = &FileFilter_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_file_filter_get_type());
// Add derived versions of interfaces, if the C type implements any interfaces:
}
return *this;
}
void FileFilter_Class::class_init_function(void* g_class, void* class_data)
{
const auto klass = static_cast<BaseClassType*>(g_class);
CppClassParent::class_init_function(klass, class_data);
}
Glib::ObjectBase* FileFilter_Class::wrap_new(GObject* object)
{
return new FileFilter((GtkFileFilter*)object);
}
/* The implementation: */
GtkFileFilter* FileFilter::gobj_copy()
{
reference();
return gobj();
}
FileFilter::FileFilter(const Glib::ConstructParams& construct_params)
:
Glib::Object(construct_params)
{
if(gobject_ && g_object_is_floating (gobject_))
g_object_ref_sink(gobject_); //Stops it from being floating.
}
FileFilter::FileFilter(GtkFileFilter* castitem)
:
Glib::Object((GObject*)(castitem))
{}
FileFilter::FileFilter(FileFilter&& src) noexcept
: Glib::Object(std::move(src))
{}
FileFilter& FileFilter::operator=(FileFilter&& src) noexcept
{
Glib::Object::operator=(std::move(src));
return *this;
}
FileFilter::~FileFilter() noexcept
{}
FileFilter::CppClassType FileFilter::filefilter_class_; // initialize static member
GType FileFilter::get_type()
{
return filefilter_class_.init().get_type();
}
GType FileFilter::get_base_type()
{
return gtk_file_filter_get_type();
}
FileFilter::FileFilter()
:
// Mark this class as non-derived to allow C++ vfuncs to be skipped.
Glib::ObjectBase(nullptr),
Glib::Object(Glib::ConstructParams(filefilter_class_.init()))
{
if(gobject_ && g_object_is_floating (gobject_))
g_object_ref_sink(gobject_); //Stops it from being floating.
}
Glib::RefPtr<FileFilter> FileFilter::create()
{
return Glib::RefPtr<FileFilter>( new FileFilter() );
}
void FileFilter::set_name(const Glib::ustring& name)
{
gtk_file_filter_set_name(gobj(), name.c_str());
}
Glib::ustring FileFilter::get_name() const
{
return Glib::convert_const_gchar_ptr_to_ustring(gtk_file_filter_get_name(const_cast<GtkFileFilter*>(gobj())));
}
void FileFilter::add_mime_type(const Glib::ustring& mime_type)
{
gtk_file_filter_add_mime_type(gobj(), mime_type.c_str());
}
void FileFilter::add_pattern(const Glib::ustring& pattern)
{
gtk_file_filter_add_pattern(gobj(), pattern.c_str());
}
void FileFilter::add_pixbuf_formats()
{
gtk_file_filter_add_pixbuf_formats(gobj());
}
FileFilterFlags FileFilter::get_needed() const
{
return ((FileFilterFlags)(gtk_file_filter_get_needed(const_cast<GtkFileFilter*>(gobj()))));
}
} // namespace Gtk