/* -*- c-file-style: "ruby"; indent-tabs-mode: nil -*- */ /* * Copyright (C) 2011 Ruby-GNOME2 Project Team * Copyright (C) 2006 Masao Mutoh * * 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 "rbgtk3private.h" #define RG_TARGET_NAMESPACE cRecentManager #define _SELF(self) (RVAL2GTKRECENTMANAGER(self)) static VALUE rg_initialize(VALUE self) { G_INITIALIZE(self, gtk_recent_manager_new()); return Qnil; } static VALUE rg_s_default(G_GNUC_UNUSED VALUE self) { return GOBJ2RVAL(gtk_recent_manager_get_default()); } static VALUE rg_add_item(int argc, VALUE *argv, VALUE self) { VALUE uri, data; gboolean ret; rb_scan_args(argc, argv, "11", &uri, &data); if (NIL_P(data)){ ret = gtk_recent_manager_add_item(_SELF(self), RVAL2CSTR(uri)); if (! ret) rb_raise(rb_eRuntimeError, "Can't add the uri"); } else { ret = gtk_recent_manager_add_full(_SELF(self), RVAL2CSTR(uri), RVAL2GTKRECENTDATA(data)); if (! ret) rb_raise(rb_eRuntimeError, "Can't add the uri or data"); } return self; } static VALUE rg_remove_item(VALUE self, VALUE uri) { GError* error = NULL; gboolean ret = gtk_recent_manager_remove_item(_SELF(self), RVAL2CSTR(uri), &error); if (! ret) RAISE_GERROR(error); return self; } static VALUE rg_lookup_item(VALUE self, VALUE uri) { GError* error = NULL; GtkRecentInfo* info = gtk_recent_manager_lookup_item(_SELF(self), RVAL2CSTR(uri), &error); if (error) RAISE_GERROR(error); return GTKRECENTINFO2RVAL(info); } static VALUE rg_has_item_p(VALUE self, VALUE uri) { return CBOOL2RVAL(gtk_recent_manager_has_item(_SELF(self), RVAL2CSTR(uri))); } static VALUE rg_move_item(VALUE self, VALUE uri, VALUE new_uri) { GError* error = NULL; gboolean ret = gtk_recent_manager_move_item(_SELF(self), RVAL2CSTR(uri), RVAL2CSTR(new_uri), &error); if (! ret) RAISE_GERROR(error); return self; } static VALUE rg_items(VALUE self) { return BOXEDGLIST2RVAL_FREE(gtk_recent_manager_get_items(_SELF(self)), GTK_TYPE_RECENT_INFO, g_list_free, gtk_recent_info_unref); } static VALUE rg_purge_items(VALUE self) { GError* error = NULL; gint ret = gtk_recent_manager_purge_items(_SELF(self), &error); if (error) RAISE_GERROR(error); return INT2NUM(ret); } void Init_gtk_recent_manager(VALUE mGtk) { VALUE RG_TARGET_NAMESPACE = G_DEF_CLASS(GTK_TYPE_RECENT_MANAGER, "RecentManager", mGtk); RG_DEF_METHOD(initialize, 0); RG_DEF_SMETHOD(default, 0); RG_DEF_METHOD(add_item, -1); RG_DEF_METHOD(remove_item, 1); RG_DEF_METHOD(lookup_item, 1); RG_DEF_METHOD_P(has_item, 1); RG_DEF_METHOD(move_item, 2); RG_DEF_METHOD(items, 0); RG_DEF_METHOD(purge_items, 0); G_DEF_ERROR(GTK_RECENT_MANAGER_ERROR, "RecentManagerError", mGtk, rb_eRuntimeError, GTK_TYPE_RECENT_MANAGER_ERROR); }