Robin Gareus
ad51c7c2ba
This is intended mainly for GNU/Linux distros who will remove GTK2 support in the near future.
258 lines
6.8 KiB
C++
258 lines
6.8 KiB
C++
// Generated by gmmproc 2.45.3 -- DO NOT MODIFY!
|
|
|
|
|
|
#include <glibmm.h>
|
|
|
|
#include <gtkmm/selectiondata.h>
|
|
#include <gtkmm/private/selectiondata_p.h>
|
|
|
|
|
|
// -*- c++ -*-
|
|
/* $Id: selectiondata.ccg,v 1.5 2006/07/05 16:59:28 murrayc Exp $ */
|
|
|
|
/* Copyright 2002 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., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
#include <gtkmm/textbuffer.h>
|
|
#include <gdkmm/pixbuf.h>
|
|
#include <glibmm/utility.h> //For ScopedPtr<>.
|
|
#include <gtk/gtk.h>
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
void SelectionData::set(const std::string& type, int format, const guint8* data, int length)
|
|
{
|
|
gtk_selection_data_set(gobj(), gdk_atom_intern(type.c_str(), 0), format, data, length);
|
|
}
|
|
|
|
void SelectionData::set(int format, const guint8* data, int length)
|
|
{
|
|
//The C examples do this - that's why I added this method overload. murrayc.
|
|
set(get_target(), format, data, length);
|
|
}
|
|
|
|
void SelectionData::set(const std::string& type, const std::string& data)
|
|
{
|
|
gtk_selection_data_set(gobj(), gdk_atom_intern(type.c_str(), 0),
|
|
sizeof(char) * 8, // format is 8 bits per unit
|
|
reinterpret_cast<const guint8*>(data.data()), data.size());
|
|
}
|
|
|
|
bool SelectionData::set_text(const Glib::ustring& data)
|
|
{
|
|
return gtk_selection_data_set_text(gobj(), data.data(), data.bytes());
|
|
}
|
|
|
|
Glib::ustring SelectionData::get_text() const
|
|
{
|
|
return Glib::convert_return_gchar_ptr_to_ustring(
|
|
reinterpret_cast<char*>(gtk_selection_data_get_text(const_cast<GtkSelectionData*>(gobj()))));
|
|
}
|
|
|
|
std::string SelectionData::get_data_as_string() const
|
|
{
|
|
const guchar* data = get_data();
|
|
const int length = get_length();
|
|
if(data && length > 0)
|
|
return std::string(reinterpret_cast<const char*>(data), length);
|
|
else
|
|
return std::string();
|
|
}
|
|
|
|
std::string SelectionData::get_target() const
|
|
{
|
|
return Glib::convert_return_gchar_ptr_to_stdstring(
|
|
gdk_atom_name( gtk_selection_data_get_target(const_cast<GtkSelectionData*>(gobj())) ) );
|
|
}
|
|
|
|
Gdk::ArrayHandle_AtomString SelectionData::get_targets() const
|
|
{
|
|
GdkAtom* targets = 0;
|
|
int n_targets = 0;
|
|
|
|
if(!gtk_selection_data_get_targets(const_cast<GtkSelectionData*>(gobj()), &targets, &n_targets))
|
|
n_targets = 0; // it's set to -1 otherwise
|
|
|
|
//Note that we free the GdkAtom* array, but we don't need to free its items:
|
|
return Gdk::ArrayHandle_AtomString(targets, n_targets, Glib::OWNERSHIP_SHALLOW);
|
|
}
|
|
|
|
|
|
std::string SelectionData::get_data_type() const
|
|
{
|
|
return Glib::convert_return_gchar_ptr_to_stdstring(
|
|
gdk_atom_name( gtk_selection_data_get_data_type(const_cast<GtkSelectionData*>(gobj())) ) );
|
|
}
|
|
|
|
|
|
} // namespace Gtk
|
|
|
|
namespace
|
|
{
|
|
} // anonymous namespace
|
|
|
|
|
|
namespace Glib
|
|
{
|
|
|
|
Gtk::SelectionData wrap(GtkSelectionData* object, bool take_copy)
|
|
{
|
|
return Gtk::SelectionData(object, take_copy);
|
|
}
|
|
|
|
} // namespace Glib
|
|
|
|
|
|
namespace Gtk
|
|
{
|
|
|
|
|
|
// static
|
|
GType SelectionData::get_type()
|
|
{
|
|
return gtk_selection_data_get_type();
|
|
}
|
|
|
|
SelectionData::SelectionData()
|
|
:
|
|
gobject_ (0) // Allows creation of invalid wrapper, e.g. for output arguments to methods.
|
|
{}
|
|
|
|
SelectionData::SelectionData(const SelectionData& other)
|
|
:
|
|
gobject_ ((other.gobject_) ? gtk_selection_data_copy(other.gobject_) : 0)
|
|
{}
|
|
|
|
SelectionData::SelectionData(GtkSelectionData* gobject, bool make_a_copy)
|
|
:
|
|
// For BoxedType wrappers, make_a_copy is true by default. The static
|
|
// BoxedType wrappers must always take a copy, thus make_a_copy = true
|
|
// ensures identical behaviour if the default argument is used.
|
|
gobject_ ((make_a_copy && gobject) ? gtk_selection_data_copy(gobject) : gobject)
|
|
{}
|
|
|
|
SelectionData& SelectionData::operator=(const SelectionData& other)
|
|
{
|
|
SelectionData temp (other);
|
|
swap(temp);
|
|
return *this;
|
|
}
|
|
|
|
SelectionData::~SelectionData()
|
|
{
|
|
if(gobject_)
|
|
gtk_selection_data_free(gobject_);
|
|
}
|
|
|
|
void SelectionData::swap(SelectionData& other)
|
|
{
|
|
GtkSelectionData *const temp = gobject_;
|
|
gobject_ = other.gobject_;
|
|
other.gobject_ = temp;
|
|
}
|
|
|
|
GtkSelectionData* SelectionData::gobj_copy() const
|
|
{
|
|
return gtk_selection_data_copy(gobject_);
|
|
}
|
|
|
|
|
|
bool SelectionData::set_pixbuf(const Glib::RefPtr<Gdk::Pixbuf>& pixbuf)
|
|
{
|
|
return gtk_selection_data_set_pixbuf(gobj(), Glib::unwrap(pixbuf));
|
|
}
|
|
|
|
Glib::RefPtr<Gdk::Pixbuf> SelectionData::get_pixbuf()
|
|
{
|
|
return Glib::wrap(gtk_selection_data_get_pixbuf(gobj()));
|
|
}
|
|
|
|
Glib::RefPtr<const Gdk::Pixbuf> SelectionData::get_pixbuf() const
|
|
{
|
|
return const_cast<SelectionData*>(this)->get_pixbuf();
|
|
}
|
|
|
|
bool SelectionData::set_uris(const Glib::StringArrayHandle& uris)
|
|
{
|
|
return gtk_selection_data_set_uris(gobj(), const_cast<char**>((uris).data()));
|
|
}
|
|
|
|
Glib::StringArrayHandle SelectionData::get_uris() const
|
|
{
|
|
return Glib::StringArrayHandle(gtk_selection_data_get_uris(const_cast<GtkSelectionData*>(gobj())));
|
|
}
|
|
|
|
const guchar* SelectionData::get_data() const
|
|
{
|
|
return gtk_selection_data_get_data(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
int SelectionData::get_length() const
|
|
{
|
|
return gtk_selection_data_get_length(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
GdkAtom SelectionData::get_selection() const
|
|
{
|
|
return gtk_selection_data_get_selection(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
int SelectionData::get_format() const
|
|
{
|
|
return gtk_selection_data_get_format(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
Glib::RefPtr<Gdk::Display> SelectionData::get_display()
|
|
{
|
|
Glib::RefPtr<Gdk::Display> retvalue = Glib::wrap(gtk_selection_data_get_display(gobj()));
|
|
if(retvalue)
|
|
retvalue->reference(); //The function does not do a ref for us.
|
|
return retvalue;
|
|
}
|
|
|
|
Glib::RefPtr<const Gdk::Display> SelectionData::get_display() const
|
|
{
|
|
return const_cast<SelectionData*>(this)->get_display();
|
|
}
|
|
|
|
bool SelectionData::targets_include_uri() const
|
|
{
|
|
return gtk_selection_data_targets_include_uri(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
bool SelectionData::targets_include_text() const
|
|
{
|
|
return gtk_selection_data_targets_include_text(const_cast<GtkSelectionData*>(gobj()));
|
|
}
|
|
|
|
bool SelectionData::targets_include_rich_text(const Glib::RefPtr<TextBuffer>& buffer) const
|
|
{
|
|
return gtk_selection_data_targets_include_rich_text(const_cast<GtkSelectionData*>(gobj()), Glib::unwrap(buffer));
|
|
}
|
|
|
|
bool SelectionData::targets_include_image(bool writable) const
|
|
{
|
|
return gtk_selection_data_targets_include_image(const_cast<GtkSelectionData*>(gobj()), static_cast<int>(writable));
|
|
}
|
|
|
|
|
|
} // namespace Gtk
|
|
|
|
|