summaryrefslogtreecommitdiff
path: root/gedit/gedit-panel.c
diff options
context:
space:
mode:
Diffstat (limited to 'gedit/gedit-panel.c')
-rwxr-xr-xgedit/gedit-panel.c950
1 files changed, 0 insertions, 950 deletions
diff --git a/gedit/gedit-panel.c b/gedit/gedit-panel.c
deleted file mode 100755
index fb1f9672..00000000
--- a/gedit/gedit-panel.c
+++ /dev/null
@@ -1,950 +0,0 @@
-/*
- * gedit-panel.c
- * This file is part of gedit
- *
- * Copyright (C) 2005 - Paolo Maggi
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program 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 General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/*
- * Modified by the gedit Team, 2005. See the AUTHORS file for a
- * list of people on the gedit Team.
- * See the ChangeLog files for a list of changes.
- *
- * $Id$
- */
-
-#include "gedit-panel.h"
-
-#include <glib/gi18n.h>
-#include <gtk/gtk.h>
-#include <gdk/gdk.h>
-#include <gdk/gdkkeysyms.h>
-
-#include "gedit-close-button.h"
-#include "gedit-window.h"
-#include "gedit-debug.h"
-
-#define PANEL_ITEM_KEY "GeditPanelItemKey"
-
-#define GEDIT_PANEL_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), GEDIT_TYPE_PANEL, GeditPanelPrivate))
-
-struct _GeditPanelPrivate
-{
- GtkOrientation orientation;
-
- /* Title bar (vertical panel only) */
- GtkWidget *title_image;
- GtkWidget *title_label;
-
- /* Notebook */
- GtkWidget *notebook;
-};
-
-typedef struct _GeditPanelItem GeditPanelItem;
-
-struct _GeditPanelItem
-{
- gchar *name;
- GtkWidget *icon;
-};
-
-/* Properties */
-enum {
- PROP_0,
- PROP_ORIENTATION
-};
-
-/* Signals */
-enum {
- ITEM_ADDED,
- ITEM_REMOVED,
- CLOSE,
- FOCUS_DOCUMENT,
- LAST_SIGNAL
-};
-
-static guint signals[LAST_SIGNAL];
-
-static GObject *gedit_panel_constructor (GType type,
- guint n_construct_properties,
- GObjectConstructParam *construct_properties);
-
-
-G_DEFINE_TYPE(GeditPanel, gedit_panel, GTK_TYPE_VBOX)
-
-static void
-gedit_panel_finalize (GObject *obj)
-{
- if (G_OBJECT_CLASS (gedit_panel_parent_class)->finalize)
- (*G_OBJECT_CLASS (gedit_panel_parent_class)->finalize) (obj);
-}
-
-static void
-gedit_panel_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
-{
- GeditPanel *panel = GEDIT_PANEL (object);
-
- switch (prop_id)
- {
- case PROP_ORIENTATION:
- g_value_set_enum(value, panel->priv->orientation);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-gedit_panel_set_property (GObject *object,
- guint prop_id,
- const GValue *value,
- GParamSpec *pspec)
-{
- GeditPanel *panel = GEDIT_PANEL (object);
-
- switch (prop_id)
- {
- case PROP_ORIENTATION:
- panel->priv->orientation = g_value_get_enum (value);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
-}
-
-static void
-gedit_panel_close (GeditPanel *panel)
-{
- gtk_widget_hide (GTK_WIDGET (panel));
-}
-
-static void
-gedit_panel_focus_document (GeditPanel *panel)
-{
- GtkWidget *toplevel = gtk_widget_get_toplevel (GTK_WIDGET (panel));
-#if !GTK_CHECK_VERSION (2, 18, 0)
- if (GTK_WIDGET_TOPLEVEL (toplevel) && GEDIT_IS_WINDOW (toplevel))
-#else
- if (gtk_widget_is_toplevel (toplevel) && GEDIT_IS_WINDOW (toplevel))
-#endif
- {
- GeditView *view;
-
- view = gedit_window_get_active_view (GEDIT_WINDOW (toplevel));
- if (view != NULL)
- gtk_widget_grab_focus (GTK_WIDGET (view));
- }
-}
-
-static void
-gedit_panel_grab_focus (GtkWidget *w)
-{
- gint n;
- GtkWidget *tab;
- GeditPanel *panel = GEDIT_PANEL (w);
-
- n = gtk_notebook_get_current_page (GTK_NOTEBOOK (panel->priv->notebook));
- if (n == -1)
- return;
-
- tab = gtk_notebook_get_nth_page (GTK_NOTEBOOK (panel->priv->notebook),
- n);
- g_return_if_fail (tab != NULL);
-
- gtk_widget_grab_focus (tab);
-}
-
-static void
-gedit_panel_class_init (GeditPanelClass *klass)
-{
- GtkBindingSet *binding_set;
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
-
- g_type_class_add_private (klass, sizeof (GeditPanelPrivate));
-
- object_class->constructor = gedit_panel_constructor;
- object_class->finalize = gedit_panel_finalize;
- object_class->get_property = gedit_panel_get_property;
- object_class->set_property = gedit_panel_set_property;
-
- g_object_class_install_property (object_class,
- PROP_ORIENTATION,
- g_param_spec_enum ("orientation",
- "Orientation",
- "The panel's orientation",
- GTK_TYPE_ORIENTATION,
- GTK_ORIENTATION_VERTICAL,
- G_PARAM_WRITABLE |
- G_PARAM_READABLE |
- G_PARAM_CONSTRUCT_ONLY |
- G_PARAM_STATIC_STRINGS));
-
- widget_class->grab_focus = gedit_panel_grab_focus;
-
- klass->close = gedit_panel_close;
- klass->focus_document = gedit_panel_focus_document;
-
- signals[ITEM_ADDED] =
- g_signal_new ("item_added",
- G_OBJECT_CLASS_TYPE (klass),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (GeditPanelClass, item_added),
- NULL, NULL,
- g_cclosure_marshal_VOID__OBJECT,
- G_TYPE_NONE,
- 1,
- GTK_TYPE_WIDGET);
- signals[ITEM_REMOVED] =
- g_signal_new ("item_removed",
- G_OBJECT_CLASS_TYPE (klass),
- G_SIGNAL_RUN_FIRST,
- G_STRUCT_OFFSET (GeditPanelClass, item_removed),
- NULL, NULL,
- g_cclosure_marshal_VOID__OBJECT,
- G_TYPE_NONE,
- 1,
- GTK_TYPE_WIDGET);
-
- /* Keybinding signals */
- signals[CLOSE] =
- g_signal_new ("close",
- G_OBJECT_CLASS_TYPE (klass),
- G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
- G_STRUCT_OFFSET (GeditPanelClass, close),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE, 0);
- signals[FOCUS_DOCUMENT] =
- g_signal_new ("focus_document",
- G_OBJECT_CLASS_TYPE (klass),
- G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
- G_STRUCT_OFFSET (GeditPanelClass, focus_document),
- NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
- G_TYPE_NONE, 0);
- binding_set = gtk_binding_set_by_class (klass);
-
- gtk_binding_entry_add_signal (binding_set,
- GDK_Escape,
- 0,
- "close",
- 0);
- gtk_binding_entry_add_signal (binding_set,
- GDK_Return,
- GDK_CONTROL_MASK,
- "focus_document",
- 0);
-}
-
-/* This is ugly, since it supports only known
- * storage types of GtkImage, otherwise fall back
- * to the empty icon.
- * See http://bugzilla.mate.org/show_bug.cgi?id=317520.
- */
-static void
-set_gtk_image_from_gtk_image (GtkImage *image,
- GtkImage *source)
-{
- switch (gtk_image_get_storage_type (source))
- {
- case GTK_IMAGE_EMPTY:
- gtk_image_clear (image);
- break;
- case GTK_IMAGE_PIXMAP:
- {
- GdkPixmap *pm;
- GdkBitmap *bm;
-
- gtk_image_get_pixmap (source, &pm, &bm);
- gtk_image_set_from_pixmap (image, pm, bm);
- }
- break;
- case GTK_IMAGE_IMAGE:
- {
- GdkImage *i;
- GdkBitmap *bm;
-
- gtk_image_get_image (source, &i, &bm);
- gtk_image_set_from_image (image, i, bm);
- }
- break;
- case GTK_IMAGE_PIXBUF:
- {
- GdkPixbuf *pb;
-
- pb = gtk_image_get_pixbuf (source);
- gtk_image_set_from_pixbuf (image, pb);
- }
- break;
- case GTK_IMAGE_STOCK:
- {
- gchar *s_id;
- GtkIconSize s;
-
- gtk_image_get_stock (source, &s_id, &s);
- gtk_image_set_from_stock (image, s_id, s);
- }
- break;
- case GTK_IMAGE_ICON_SET:
- {
- GtkIconSet *is;
- GtkIconSize s;
-
- gtk_image_get_icon_set (source, &is, &s);
- gtk_image_set_from_icon_set (image, is, s);
- }
- break;
- case GTK_IMAGE_ANIMATION:
- {
- GdkPixbufAnimation *a;
-
- a = gtk_image_get_animation (source);
- gtk_image_set_from_animation (image, a);
- }
- break;
- case GTK_IMAGE_ICON_NAME:
- {
- const gchar *n;
- GtkIconSize s;
-
- gtk_image_get_icon_name (source, &n, &s);
- gtk_image_set_from_icon_name (image, n, s);
- }
- break;
- default:
- gtk_image_set_from_stock (image,
- GTK_STOCK_FILE,
- GTK_ICON_SIZE_MENU);
- }
-}
-
-static void
-sync_title (GeditPanel *panel,
- GeditPanelItem *item)
-{
- if (panel->priv->orientation != GTK_ORIENTATION_VERTICAL)
- return;
-
- if (item != NULL)
- {
- gtk_label_set_text (GTK_LABEL (panel->priv->title_label),
- item->name);
-
- set_gtk_image_from_gtk_image (GTK_IMAGE (panel->priv->title_image),
- GTK_IMAGE (item->icon));
- }
- else
- {
- gtk_label_set_text (GTK_LABEL (panel->priv->title_label),
- _("Empty"));
-
- gtk_image_set_from_stock (GTK_IMAGE (panel->priv->title_image),
- GTK_STOCK_FILE,
- GTK_ICON_SIZE_MENU);
- }
-}
-
-static void
-notebook_page_changed (GtkNotebook *notebook,
- GtkNotebookPage *page,
- guint page_num,
- GeditPanel *panel)
-{
- GtkWidget *item;
- GeditPanelItem *data;
-
- item = gtk_notebook_get_nth_page (notebook, page_num);
- g_return_if_fail (item != NULL);
-
- data = (GeditPanelItem *)g_object_get_data (G_OBJECT (item),
- PANEL_ITEM_KEY);
- g_return_if_fail (data != NULL);
-
- sync_title (panel, data);
-}
-
-static void
-panel_show (GeditPanel *panel,
- gpointer user_data)
-{
- gint page;
- GtkNotebook *nb;
-
- nb = GTK_NOTEBOOK (panel->priv->notebook);
-
- page = gtk_notebook_get_current_page (nb);
-
- if (page != -1)
- notebook_page_changed (nb, NULL, page, panel);
-}
-
-static void
-gedit_panel_init (GeditPanel *panel)
-{
- panel->priv = GEDIT_PANEL_GET_PRIVATE (panel);
-}
-
-static void
-close_button_clicked_cb (GtkWidget *widget,
- GtkWidget *panel)
-{
- gtk_widget_hide (panel);
-}
-
-static GtkWidget *
-create_close_button (GeditPanel *panel)
-{
- GtkWidget *button;
-
- button = gedit_close_button_new ();
-
- gtk_widget_set_tooltip_text (button, _("Hide panel"));
-
- g_signal_connect (button,
- "clicked",
- G_CALLBACK (close_button_clicked_cb),
- panel);
-
- return button;
-}
-
-static void
-build_notebook_for_panel (GeditPanel *panel)
-{
- /* Create the panel notebook */
- panel->priv->notebook = gtk_notebook_new ();
-
- gtk_notebook_set_tab_pos (GTK_NOTEBOOK (panel->priv->notebook),
- GTK_POS_BOTTOM);
- gtk_notebook_set_scrollable (GTK_NOTEBOOK (panel->priv->notebook),
- TRUE);
- gtk_notebook_popup_enable (GTK_NOTEBOOK (panel->priv->notebook));
-
- gtk_widget_show (GTK_WIDGET (panel->priv->notebook));
-
- g_signal_connect (panel->priv->notebook,
- "switch-page",
- G_CALLBACK (notebook_page_changed),
- panel);
-}
-
-static void
-build_horizontal_panel (GeditPanel *panel)
-{
- GtkWidget *box;
- GtkWidget *sidebar;
- GtkWidget *close_button;
-
- box = gtk_hbox_new(FALSE, 0);
-
- gtk_box_pack_start (GTK_BOX (box),
- panel->priv->notebook,
- TRUE,
- TRUE,
- 0);
-
- /* Toolbar, close button and first separator */
- sidebar = gtk_vbox_new(FALSE, 6);
- gtk_container_set_border_width (GTK_CONTAINER (sidebar), 4);
-
- gtk_box_pack_start (GTK_BOX (box),
- sidebar,
- FALSE,
- FALSE,
- 0);
-
- close_button = create_close_button (panel);
-
- gtk_box_pack_start (GTK_BOX (sidebar),
- close_button,
- FALSE,
- FALSE,
- 0);
-
- gtk_widget_show_all (box);
-
- gtk_box_pack_start (GTK_BOX (panel),
- box,
- TRUE,
- TRUE,
- 0);
-}
-
-static void
-build_vertical_panel (GeditPanel *panel)
-{
- GtkWidget *close_button;
- GtkWidget *title_hbox;
- GtkWidget *icon_name_hbox;
- GtkWidget *dummy_label;
-
- /* Create title hbox */
- title_hbox = gtk_hbox_new (FALSE, 6);
- gtk_container_set_border_width (GTK_CONTAINER (title_hbox), 5);
-
- gtk_box_pack_start (GTK_BOX (panel), title_hbox, FALSE, FALSE, 0);
-
- icon_name_hbox = gtk_hbox_new (FALSE, 0);
- gtk_box_pack_start (GTK_BOX (title_hbox),
- icon_name_hbox,
- TRUE,
- TRUE,
- 0);
-
- panel->priv->title_image =
- gtk_image_new_from_stock (GTK_STOCK_FILE,
- GTK_ICON_SIZE_MENU);
- gtk_box_pack_start (GTK_BOX (icon_name_hbox),
- panel->priv->title_image,
- FALSE,
- TRUE,
- 0);
-
- dummy_label = gtk_label_new (" ");
-
- gtk_box_pack_start (GTK_BOX (icon_name_hbox),
- dummy_label,
- FALSE,
- FALSE,
- 0);
-
- panel->priv->title_label = gtk_label_new (_("Empty"));
- gtk_misc_set_alignment (GTK_MISC (panel->priv->title_label), 0, 0.5);
- gtk_label_set_ellipsize(GTK_LABEL (panel->priv->title_label), PANGO_ELLIPSIZE_END);
-
- gtk_box_pack_start (GTK_BOX (icon_name_hbox),
- panel->priv->title_label,
- TRUE,
- TRUE,
- 0);
-
- close_button = create_close_button (panel);
-
- gtk_box_pack_start (GTK_BOX (title_hbox),
- close_button,
- FALSE,
- FALSE,
- 0);
-
- gtk_widget_show_all (title_hbox);
-
- gtk_box_pack_start (GTK_BOX (panel),
- panel->priv->notebook,
- TRUE,
- TRUE,
- 0);
-}
-
-static GObject *
-gedit_panel_constructor (GType type,
- guint n_construct_properties,
- GObjectConstructParam *construct_properties)
-{
-
- /* Invoke parent constructor. */
- GeditPanelClass *klass = GEDIT_PANEL_CLASS (g_type_class_peek (GEDIT_TYPE_PANEL));
- GObjectClass *parent_class = G_OBJECT_CLASS (g_type_class_peek_parent (klass));
- GObject *obj = parent_class->constructor (type,
- n_construct_properties,
- construct_properties);
-
- /* Build the panel, now that we know the orientation
- (_init has been called previously) */
- GeditPanel *panel = GEDIT_PANEL (obj);
-
- build_notebook_for_panel (panel);
- if (panel->priv->orientation == GTK_ORIENTATION_HORIZONTAL)
- build_horizontal_panel (panel);
- else
- build_vertical_panel (panel);
-
- g_signal_connect (panel,
- "show",
- G_CALLBACK (panel_show),
- NULL);
-
- return obj;
-}
-
-/**
- * gedit_panel_new:
- * @orientation: a #GtkOrientation
- *
- * Creates a new #GeditPanel with the given @orientation. You shouldn't create
- * a new panel use gedit_window_get_side_panel() or gedit_window_get_bottom_panel()
- * instead.
- *
- * Returns: a new #GeditPanel object.
- */
-GtkWidget *
-gedit_panel_new (GtkOrientation orientation)
-{
- return GTK_WIDGET (g_object_new (GEDIT_TYPE_PANEL, "orientation", orientation, NULL));
-}
-
-static GtkWidget *
-build_tab_label (GeditPanel *panel,
- GtkWidget *item,
- const gchar *name,
- GtkWidget *icon)
-{
- GtkWidget *hbox, *label_hbox, *label_ebox;
- GtkWidget *label;
-
- /* set hbox spacing and label padding (see below) so that there's an
- * equal amount of space around the label */
- hbox = gtk_hbox_new (FALSE, 4);
-
- label_ebox = gtk_event_box_new ();
- gtk_event_box_set_visible_window (GTK_EVENT_BOX (label_ebox), FALSE);
- gtk_box_pack_start (GTK_BOX (hbox), label_ebox, TRUE, TRUE, 0);
-
- label_hbox = gtk_hbox_new (FALSE, 4);
- gtk_container_add (GTK_CONTAINER (label_ebox), label_hbox);
-
- /* setup icon */
- gtk_box_pack_start (GTK_BOX (label_hbox), icon, FALSE, FALSE, 0);
-
- /* setup label */
- label = gtk_label_new (name);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_misc_set_padding (GTK_MISC (label), 0, 0);
- gtk_box_pack_start (GTK_BOX (label_hbox), label, TRUE, TRUE, 0);
-
- gtk_widget_set_tooltip_text (label_ebox, name);
-
- gtk_widget_show_all (hbox);
-
- if (panel->priv->orientation == GTK_ORIENTATION_VERTICAL)
- gtk_widget_hide(label);
-
- g_object_set_data (G_OBJECT (item), "label", label);
- g_object_set_data (G_OBJECT (item), "hbox", hbox);
-
- return hbox;
-}
-
-/**
- * gedit_panel_add_item:
- * @panel: a #GeditPanel
- * @item: the #GtkWidget to add to the @panel
- * @name: the name to be shown in the @panel
- * @image: the image to be shown in the @panel
- *
- * Adds a new item to the @panel.
- */
-void
-gedit_panel_add_item (GeditPanel *panel,
- GtkWidget *item,
- const gchar *name,
- GtkWidget *image)
-{
- GeditPanelItem *data;
- GtkWidget *tab_label;
- GtkWidget *menu_label;
- gint w, h;
-
- g_return_if_fail (GEDIT_IS_PANEL (panel));
- g_return_if_fail (GTK_IS_WIDGET (item));
- g_return_if_fail (name != NULL);
- g_return_if_fail (image == NULL || GTK_IS_IMAGE (image));
-
- data = g_new (GeditPanelItem, 1);
-
- data->name = g_strdup (name);
-
- if (image == NULL)
- {
- /* default to empty */
- data->icon = gtk_image_new_from_stock (GTK_STOCK_FILE,
- GTK_ICON_SIZE_MENU);
- }
- else
- {
- data->icon = image;
- }
-
- gtk_icon_size_lookup (GTK_ICON_SIZE_MENU, &w, &h);
- gtk_widget_set_size_request (data->icon, w, h);
-
- g_object_set_data (G_OBJECT (item),
- PANEL_ITEM_KEY,
- data);
-
- tab_label = build_tab_label (panel, item, data->name, data->icon);
-
- menu_label = gtk_label_new (name);
- gtk_misc_set_alignment (GTK_MISC (menu_label), 0.0, 0.5);
-
- if (!GTK_WIDGET_VISIBLE (item))
- gtk_widget_show (item);
-
- gtk_notebook_append_page_menu (GTK_NOTEBOOK (panel->priv->notebook),
- item,
- tab_label,
- menu_label);
-
- g_signal_emit (G_OBJECT (panel), signals[ITEM_ADDED], 0, item);
-}
-
-/**
- * gedit_panel_add_item_with_stock_icon:
- * @panel: a #GeditPanel
- * @item: the #GtkWidget to add to the @panel
- * @name: the name to be shown in the @panel
- * @stock_id: a stock id
- *
- * Same as gedit_panel_add_item() but using an image from stock.
- */
-void
-gedit_panel_add_item_with_stock_icon (GeditPanel *panel,
- GtkWidget *item,
- const gchar *name,
- const gchar *stock_id)
-{
- GtkWidget *icon = NULL;
-
- if (stock_id != NULL)
- {
- icon = gtk_image_new_from_stock (stock_id,
- GTK_ICON_SIZE_MENU);
- }
-
- gedit_panel_add_item (panel, item, name, icon);
-}
-
-/**
- * gedit_panel_remove_item:
- * @panel: a #GeditPanel
- * @item: the item to be removed from the panel
- *
- * Removes the widget @item from the panel if it is in the @panel and returns
- * TRUE if there was not any problem.
- *
- * Returns: TRUE if it was well removed.
- */
-gboolean
-gedit_panel_remove_item (GeditPanel *panel,
- GtkWidget *item)
-{
- GeditPanelItem *data;
- gint page_num;
-
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), FALSE);
- g_return_val_if_fail (GTK_IS_WIDGET (item), FALSE);
-
- page_num = gtk_notebook_page_num (GTK_NOTEBOOK (panel->priv->notebook),
- item);
-
- if (page_num == -1)
- return FALSE;
-
- data = (GeditPanelItem *)g_object_get_data (G_OBJECT (item),
- PANEL_ITEM_KEY);
- g_return_val_if_fail (data != NULL, FALSE);
-
- g_free (data->name);
- g_free (data);
-
- g_object_set_data (G_OBJECT (item),
- PANEL_ITEM_KEY,
- NULL);
-
- /* ref the item to keep it alive during signal emission */
- g_object_ref (G_OBJECT (item));
-
- gtk_notebook_remove_page (GTK_NOTEBOOK (panel->priv->notebook),
- page_num);
-
- /* if we removed all the pages, reset the title */
- if (gtk_notebook_get_n_pages (GTK_NOTEBOOK (panel->priv->notebook)) == 0)
- sync_title (panel, NULL);
-
- g_signal_emit (G_OBJECT (panel), signals[ITEM_REMOVED], 0, item);
-
- g_object_unref (G_OBJECT (item));
-
- return TRUE;
-}
-
-/**
- * gedit_panel_activate_item:
- * @panel: a #GeditPanel
- * @item: the item to be activated
- *
- * Switches to the page that contains @item.
- *
- * Returns: TRUE if it was activated
- */
-gboolean
-gedit_panel_activate_item (GeditPanel *panel,
- GtkWidget *item)
-{
- gint page_num;
-
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), FALSE);
- g_return_val_if_fail (GTK_IS_WIDGET (item), FALSE);
-
- page_num = gtk_notebook_page_num (GTK_NOTEBOOK (panel->priv->notebook),
- item);
-
- if (page_num == -1)
- return FALSE;
-
- gtk_notebook_set_current_page (GTK_NOTEBOOK (panel->priv->notebook),
- page_num);
-
- return TRUE;
-}
-
-/**
- * gedit_panel_item_is_active:
- * @panel: a #GeditPanel
- * @item: a widget contained in #GeditPanel
- *
- * Wheter @item is the one current active in @panel
- *
- * Returns: TRUE if the widget is active
- */
-gboolean
-gedit_panel_item_is_active (GeditPanel *panel,
- GtkWidget *item)
-{
- gint cur_page;
- gint page_num;
-
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), FALSE);
- g_return_val_if_fail (GTK_IS_WIDGET (item), FALSE);
-
- page_num = gtk_notebook_page_num (GTK_NOTEBOOK (panel->priv->notebook),
- item);
-
- if (page_num == -1)
- return FALSE;
-
- cur_page = gtk_notebook_get_current_page (
- GTK_NOTEBOOK (panel->priv->notebook));
-
- return (page_num == cur_page);
-}
-
-/**
- * gedit_panel_get_orientation:
- * @panel: a #GeditPanel
- *
- * Gets the orientation of the @panel.
- *
- * Returns: the #GtkOrientation of #GeditPanel
- */
-GtkOrientation
-gedit_panel_get_orientation (GeditPanel *panel)
-{
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), GTK_ORIENTATION_VERTICAL);
-
- return panel->priv->orientation;
-}
-
-/**
- * gedit_panel_get_n_items:
- * @panel: a #GeditPanel
- *
- * Gets the number of items in a @panel.
- *
- * Returns: the number of items contained in #GeditPanel
- */
-gint
-gedit_panel_get_n_items (GeditPanel *panel)
-{
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), -1);
-
- return gtk_notebook_get_n_pages (GTK_NOTEBOOK (panel->priv->notebook));
-}
-
-gint
-_gedit_panel_get_active_item_id (GeditPanel *panel)
-{
- gint cur_page;
- GtkWidget *item;
- GeditPanelItem *data;
-
- g_return_val_if_fail (GEDIT_IS_PANEL (panel), 0);
-
- cur_page = gtk_notebook_get_current_page (
- GTK_NOTEBOOK (panel->priv->notebook));
- if (cur_page == -1)
- return 0;
-
- item = gtk_notebook_get_nth_page (
- GTK_NOTEBOOK (panel->priv->notebook),
- cur_page);
-
- /* FIXME: for now we use as the hash of the name as id.
- * However the name is not guaranteed to be unique and
- * it is a translated string, so it's subotimal, but should
- * be good enough for now since we don't want to add an
- * ad hoc id argument.
- */
-
- data = (GeditPanelItem *)g_object_get_data (G_OBJECT (item),
- PANEL_ITEM_KEY);
- g_return_val_if_fail (data != NULL, 0);
-
- return g_str_hash (data->name);
-}
-
-void
-_gedit_panel_set_active_item_by_id (GeditPanel *panel,
- gint id)
-{
- gint n, i;
-
- g_return_if_fail (GEDIT_IS_PANEL (panel));
-
- if (id == 0)
- return;
-
- n = gtk_notebook_get_n_pages (
- GTK_NOTEBOOK (panel->priv->notebook));
-
- for (i = 0; i < n; i++)
- {
- GtkWidget *item;
- GeditPanelItem *data;
-
- item = gtk_notebook_get_nth_page (
- GTK_NOTEBOOK (panel->priv->notebook), i);
-
- data = (GeditPanelItem *)g_object_get_data (G_OBJECT (item),
- PANEL_ITEM_KEY);
- g_return_if_fail (data != NULL);
-
- if (g_str_hash (data->name) == id)
- {
- gtk_notebook_set_current_page (
- GTK_NOTEBOOK (panel->priv->notebook), i);
-
- return;
- }
- }
-}