2008-04-30 Cosimo Cecchi <cosimoc@gnome.org>
[nautilus.git] / src / nautilus-navigation-bar.c
blob559a0d38a486360183a0cffea8762221471fd5d6
1 /* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
3 /*
4 * Nautilus
6 * Copyright (C) 2000 Eazel, Inc.
8 * Nautilus is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of the
11 * License, or (at your option) any later version.
13 * Nautilus is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
18 * You should have received a copy of the GNU General Public
19 * License along with this program; see the file COPYING. If not,
20 * write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
21 * Boston, MA 02111-1307, USA.
23 * Author: Maciej Stachowiak <mjs@eazel.com>
26 /* nautilus-navigation-bar.c - Abstract navigation bar class
29 #include <config.h>
30 #include "nautilus-navigation-bar.h"
32 #include <eel/eel-gtk-macros.h>
33 #include <gdk/gdkkeysyms.h>
34 #include <gtk/gtksignal.h>
35 #include <gtk/gtkbindings.h>
36 #include <string.h>
38 enum {
39 ACTIVATE,
40 CANCEL,
41 LOCATION_CHANGED,
42 LAST_SIGNAL
44 static guint signals[LAST_SIGNAL];
46 static void nautilus_navigation_bar_class_init (NautilusNavigationBarClass *class);
47 static void nautilus_navigation_bar_init (NautilusNavigationBar *bar);
49 EEL_CLASS_BOILERPLATE (NautilusNavigationBar, nautilus_navigation_bar, GTK_TYPE_HBOX)
51 EEL_IMPLEMENT_MUST_OVERRIDE_SIGNAL (nautilus_navigation_bar, get_location)
52 EEL_IMPLEMENT_MUST_OVERRIDE_SIGNAL (nautilus_navigation_bar, set_location)
54 static void
55 nautilus_navigation_bar_class_init (NautilusNavigationBarClass *klass)
57 GtkObjectClass *object_class;
58 GtkBindingSet *binding_set;
60 object_class = GTK_OBJECT_CLASS (klass);
62 signals[ACTIVATE] = g_signal_new
63 ("activate",
64 G_TYPE_FROM_CLASS (object_class),
65 G_SIGNAL_RUN_LAST,
66 G_STRUCT_OFFSET (NautilusNavigationBarClass,
67 activate),
68 NULL, NULL,
69 g_cclosure_marshal_VOID__VOID,
70 G_TYPE_NONE, 0);
72 signals[CANCEL] = g_signal_new
73 ("cancel",
74 G_TYPE_FROM_CLASS (object_class),
75 G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
76 G_STRUCT_OFFSET (NautilusNavigationBarClass,
77 cancel),
78 NULL, NULL,
79 g_cclosure_marshal_VOID__VOID,
80 G_TYPE_NONE, 0);
82 signals[LOCATION_CHANGED] = g_signal_new
83 ("location_changed",
84 G_TYPE_FROM_CLASS (object_class),
85 G_SIGNAL_RUN_LAST,
86 G_STRUCT_OFFSET (NautilusNavigationBarClass,
87 location_changed),
88 NULL, NULL,
89 g_cclosure_marshal_VOID__STRING,
90 G_TYPE_NONE, 1, G_TYPE_STRING);
92 klass->activate = NULL;
93 klass->cancel = NULL;
95 binding_set = gtk_binding_set_by_class (klass);
96 gtk_binding_entry_add_signal (binding_set, GDK_Escape, 0, "cancel", 0);
98 EEL_ASSIGN_MUST_OVERRIDE_SIGNAL (klass, nautilus_navigation_bar, get_location);
99 EEL_ASSIGN_MUST_OVERRIDE_SIGNAL (klass, nautilus_navigation_bar, set_location);
102 static void
103 nautilus_navigation_bar_init (NautilusNavigationBar *bar)
108 * nautilus_navigation_bar_activate
110 * Change the navigation bar to an active state.
112 * @bar: A NautilusNavigationBar.
114 void
115 nautilus_navigation_bar_activate (NautilusNavigationBar *bar)
117 g_return_if_fail (NAUTILUS_IS_NAVIGATION_BAR (bar));
119 g_signal_emit (bar, signals[ACTIVATE], 0);
123 * nautilus_navigation_bar_get_location
125 * Return the location displayed in the navigation bar.
127 * @bar: A NautilusNavigationBar.
128 * @location: The uri that should be displayed.
130 char *
131 nautilus_navigation_bar_get_location (NautilusNavigationBar *bar)
133 g_return_val_if_fail (NAUTILUS_IS_NAVIGATION_BAR (bar), NULL);
135 return EEL_CALL_METHOD_WITH_RETURN_VALUE
136 (NAUTILUS_NAVIGATION_BAR_CLASS, bar,
137 get_location, (bar));
141 * nautilus_navigation_bar_set_location
143 * Change the location displayed in the navigation bar.
145 * @bar: A NautilusNavigationBar.
146 * @location: The uri that should be displayed.
148 void
149 nautilus_navigation_bar_set_location (NautilusNavigationBar *bar,
150 const char *location)
152 g_return_if_fail (NAUTILUS_IS_NAVIGATION_BAR (bar));
154 EEL_CALL_METHOD (NAUTILUS_NAVIGATION_BAR_CLASS, bar,
155 set_location, (bar, location));
158 void
159 nautilus_navigation_bar_location_changed (NautilusNavigationBar *bar)
161 char *location;
163 g_return_if_fail (NAUTILUS_IS_NAVIGATION_BAR (bar));
165 location = nautilus_navigation_bar_get_location (bar);
166 g_signal_emit (bar,
167 signals[LOCATION_CHANGED], 0,
168 location);
169 g_free (location);