aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-tab.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-tab.c')
-rw-r--r--src/ephy-tab.c702
1 files changed, 484 insertions, 218 deletions
diff --git a/src/ephy-tab.c b/src/ephy-tab.c
index 4c600a34d..0cf1c6ded 100644
--- a/src/ephy-tab.c
+++ b/src/ephy-tab.c
@@ -27,6 +27,10 @@
#include "ephy-embed-prefs.h"
#include "ephy-debug.h"
#include "egg-menu-merge.h"
+#include "ephy-string.h"
+#include "ephy-notebook.h"
+#include "ephy-file-helpers.h"
+#include "ephy-zoom.h"
#include <bonobo/bonobo-i18n.h>
#include <libgnomevfs/gnome-vfs-uri.h>
@@ -50,34 +54,61 @@ struct EphyTabPrivate
EphyEmbedEvent *event;
gboolean is_active;
TabLoadStatus load_status;
- char status_message[255];
+ char *status_message;
char *link_message;
- char favicon_url[255];
+ char *icon_address;
+ char *address;
char *title;
- char *location;
int load_percent;
gboolean visibility;
int cur_requests;
int total_requests;
int width;
int height;
+ EggAction *action;
+ float zoom;
+ EmbedSecurityLevel security_level;
};
-static void ephy_tab_class_init (EphyTabClass *klass);
-static void ephy_tab_init (EphyTab *tab);
-static void ephy_tab_finalize (GObject *object);
-
+static void ephy_tab_class_init (EphyTabClass *klass);
+static void ephy_tab_init (EphyTab *tab);
+static void ephy_tab_finalize (GObject *object);
+static void ephy_tab_update_color (EphyTab *tab);
enum
{
PROP_0,
- PROP_WINDOW,
+ PROP_ADDRESS,
+ PROP_ICON,
+ PROP_LOAD_PROGRESS,
PROP_LOAD_STATUS,
- PROP_ICON
+ PROP_MESSAGE,
+ PROP_SECURITY,
+ PROP_TITLE,
+ PROP_WINDOW,
+ PROP_ZOOM
};
static GObjectClass *parent_class = NULL;
+static gulong tab_id = 0;
+
+/* internal functions, accessible only from this file */
+void ephy_tab_set_icon_address (EphyTab *tab,
+ const char *location);
+void ephy_tab_set_load_status (EphyTab *tab,
+ TabLoadStatus status);
+void ephy_tab_set_link_message (EphyTab *tab,
+ const char *message);
+void ephy_tab_set_load_percent (EphyTab *tab,
+ int percent);
+void ephy_tab_set_security_level (EphyTab *tab,
+ EmbedSecurityLevel level);
+void ephy_tab_set_title (EphyTab *tab,
+ const char *new_title);
+void ephy_tab_set_zoom (EphyTab *tab,
+ float zoom);
+
/* Class functions */
GType
@@ -119,76 +150,162 @@ ephy_tab_set_property (GObject *object,
switch (prop_id)
{
- case PROP_WINDOW:
- tab->priv->window = g_value_get_object (value);
+ case PROP_ADDRESS:
+ ephy_tab_set_location (tab, g_value_get_string (value));
break;
- case PROP_LOAD_STATUS:
- tab->priv->load_status = g_value_get_int (value);
+ case PROP_WINDOW:
+ ephy_tab_set_window (tab, g_value_get_object (value));
break;
case PROP_ICON:
- /* do nothing yet */
+ case PROP_LOAD_PROGRESS:
+ case PROP_LOAD_STATUS:
+ case PROP_MESSAGE:
+ case PROP_SECURITY:
+ case PROP_TITLE:
+ case PROP_ZOOM:
+ /* read only */
break;
- }
+ }
}
static void
ephy_tab_get_property (GObject *object,
- guint prop_id,
- GValue *value,
- GParamSpec *pspec)
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
{
EphyTab *tab = EPHY_TAB (object);
switch (prop_id)
{
- case PROP_WINDOW:
- g_value_set_object (value, tab->priv->window);
+ case PROP_ADDRESS:
+ g_value_set_string (value, tab->priv->address);
+ break;
+ case PROP_ICON:
+ g_value_set_string (value, tab->priv->icon_address);
+ break;
+ case PROP_LOAD_PROGRESS:
+ g_value_set_int (value, tab->priv->load_percent);
break;
case PROP_LOAD_STATUS:
g_value_set_int (value, tab->priv->load_status);
break;
- case PROP_ICON:
- g_value_set_string (value, tab->priv->favicon_url);
+ case PROP_MESSAGE:
+ g_value_set_string (value, ephy_tab_get_status_message (tab));
+ break;
+ case PROP_SECURITY:
+ g_value_set_int (value, tab->priv->security_level);
+ break;
+ case PROP_TITLE:
+ g_value_set_string (value, tab->priv->title);
+ break;
+ case PROP_WINDOW:
+ g_value_set_object (value, tab->priv->window);
+ break;
+ case PROP_ZOOM:
+ g_value_set_float (value, tab->priv->zoom);
break;
}
}
static void
-ephy_tab_class_init (EphyTabClass *klass)
+ephy_tab_action_activate_cb (EggAction *action, EphyTab *tab)
{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ g_return_if_fail (IS_EPHY_TAB (tab));
- parent_class = g_type_class_peek_parent (klass);
+ ephy_window_jump_to_tab (tab->priv->window, tab);
+}
+
+static void
+ephy_tab_class_init (EphyTabClass *class)
+{
+ GObjectClass *object_class = G_OBJECT_CLASS (class);
+
+ parent_class = g_type_class_peek_parent (class);
object_class->finalize = ephy_tab_finalize;
object_class->get_property = ephy_tab_get_property;
object_class->set_property = ephy_tab_set_property;
g_object_class_install_property (object_class,
- PROP_WINDOW,
- g_param_spec_object ("EphyWindow",
- "EphyWindow",
- "The parent EphyWindow",
- EPHY_WINDOW_TYPE,
+ PROP_ADDRESS,
+ g_param_spec_string ("address",
+ "Address",
+ "The tab's address",
+ "",
G_PARAM_READWRITE));
g_object_class_install_property (object_class,
+ PROP_ICON,
+ g_param_spec_string ("icon",
+ "Icon address",
+ "The tab icon's address",
+ NULL,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (object_class,
+ PROP_LOAD_STATUS,
+ g_param_spec_int ("load-progress",
+ "Load progress",
+ "The tab's load progress in percent",
+ -1,
+ 100,
+ 0,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (object_class,
PROP_LOAD_STATUS,
g_param_spec_int ("load-status",
- "LoadStatus",
+ "Load status",
"The tab's load status",
TAB_LOAD_NONE,
TAB_LOAD_COMPLETED,
TAB_LOAD_NONE,
- G_PARAM_READWRITE));
+ G_PARAM_READABLE));
g_object_class_install_property (object_class,
- PROP_ICON,
- g_param_spec_string ("icon",
- "Icon address",
- "The tab icon's address",
- "",
+ PROP_MESSAGE,
+ g_param_spec_string ("message",
+ "Message",
+ "The tab's statusbar message",
+ NULL,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (object_class,
+ PROP_LOAD_STATUS,
+ g_param_spec_int ("security-level",
+ "Security Level",
+ "The tab's security level",
+ STATE_IS_UNKNOWN,
+ STATE_IS_SECURE_HIGH,
+ STATE_IS_UNKNOWN,
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (object_class,
+ PROP_TITLE,
+ g_param_spec_string ("title",
+ "Title",
+ "The tab's title",
+ _("Blank page"),
+ G_PARAM_READABLE));
+
+ g_object_class_install_property (object_class,
+ PROP_WINDOW,
+ g_param_spec_object ("window",
+ "Window",
+ "The tab's parent window",
+ EPHY_WINDOW_TYPE,
G_PARAM_READWRITE));
+
+ g_object_class_install_property (object_class,
+ PROP_ZOOM,
+ g_param_spec_float ("zoom",
+ "Zoom",
+ "The tab's zoom",
+ ZOOM_MINIMAL,
+ ZOOM_MAXIMAL,
+ 1.0,
+ G_PARAM_READABLE));
}
static void
@@ -229,8 +346,16 @@ ephy_tab_finalize (GObject *object)
g_object_unref (tab->priv->event);
}
- g_free (tab->priv->location);
+ if (tab->priv->action)
+ {
+ g_object_unref (tab->priv->action);
+ }
+
+ g_free (tab->priv->title);
+ g_free (tab->priv->address);
+ g_free (tab->priv->icon_address);
g_free (tab->priv->link_message);
+ g_free (tab->priv->status_message);
g_free (tab->priv);
@@ -242,7 +367,7 @@ ephy_tab_finalize (GObject *object)
/* Public functions */
EphyTab *
-ephy_tab_new ()
+ephy_tab_new (void)
{
EphyTab *tab;
@@ -251,9 +376,9 @@ ephy_tab_new ()
return tab;
}
-static void
+void
ephy_tab_set_load_status (EphyTab *tab,
- TabLoadStatus status)
+ TabLoadStatus status)
{
if (status == TAB_LOAD_COMPLETED)
{
@@ -271,12 +396,43 @@ ephy_tab_set_load_status (EphyTab *tab,
{
tab->priv->load_status = status;
}
+
+ ephy_tab_update_color (tab);
+
+ g_object_notify (G_OBJECT (tab), "load-status");
+}
+
+TabLoadStatus
+ephy_tab_get_load_status (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), TAB_LOAD_NONE);
+
+ return tab->priv->load_status;
+}
+
+void
+ephy_tab_set_link_message (EphyTab *tab, const char *message)
+{
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ g_free (tab->priv->link_message);
+ tab->priv->link_message = g_strdup (message);
+
+ g_object_notify (G_OBJECT (tab), "message");
+}
+
+const char *
+ephy_tab_get_link_message (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), NULL);
+
+ return tab->priv->link_message;
}
EphyEmbed *
ephy_tab_get_embed (EphyTab *tab)
{
- g_return_val_if_fail (IS_EPHY_TAB (G_OBJECT (tab)), NULL);
+ g_return_val_if_fail (IS_EPHY_TAB (tab), NULL);
return tab->priv->embed;
}
@@ -284,16 +440,16 @@ ephy_tab_get_embed (EphyTab *tab)
void
ephy_tab_set_window (EphyTab *tab, EphyWindow *window)
{
- g_return_if_fail (IS_EPHY_TAB (G_OBJECT (tab)));
- if (window) g_return_if_fail (IS_EPHY_WINDOW (G_OBJECT (window)));
+ g_return_if_fail (IS_EPHY_TAB (tab));
+ if (window) g_return_if_fail (IS_EPHY_WINDOW (window));
- tab->priv->window = window;
+ tab->priv->window = window;
}
EphyWindow *
ephy_tab_get_window (EphyTab *tab)
{
- g_return_val_if_fail (IS_EPHY_TAB (G_OBJECT (tab)), NULL);
+ g_return_val_if_fail (IS_EPHY_TAB (tab), NULL);
return tab->priv->window;
}
@@ -334,45 +490,46 @@ ephy_tab_update_color (EphyTab *tab)
void
ephy_tab_set_is_active (EphyTab *tab, gboolean is_active)
{
- TabLoadStatus status;
-
- g_return_if_fail (IS_EPHY_TAB (G_OBJECT (tab)));
+ g_return_if_fail (IS_EPHY_TAB (tab));
tab->priv->is_active = is_active;
- status = ephy_tab_get_load_status (tab);
- if (status == TAB_LOAD_COMPLETED)
+ if (tab->priv->load_status == TAB_LOAD_COMPLETED)
{
ephy_tab_set_load_status (tab, TAB_LOAD_NONE);
}
- ephy_tab_update_color (tab);
}
gboolean
ephy_tab_get_is_active (EphyTab *tab)
{
- g_return_val_if_fail (IS_EPHY_TAB (G_OBJECT (tab)), FALSE);
+ g_return_val_if_fail (IS_EPHY_TAB (tab), FALSE);
return tab->priv->is_active;
}
-gboolean
-ephy_tab_get_visibility (EphyTab *tab)
-{
- return tab->priv->visibility;
-}
-
void
ephy_tab_get_size (EphyTab *tab, int *width, int *height)
{
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
*width = tab->priv->width;
*height = tab->priv->height;
}
-static void
+gboolean
+ephy_tab_get_visibility (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), FALSE);
+
+ return tab->priv->visibility;
+}
+
+void
ephy_tab_set_visibility (EphyTab *tab,
gboolean visible)
{
+ g_return_if_fail (IS_EPHY_TAB (tab));
g_return_if_fail (tab->priv->window != NULL);
tab->priv->visibility = visible;
@@ -383,96 +540,127 @@ ephy_tab_set_favicon (EphyTab *tab,
GdkPixbuf *favicon)
{
GtkWidget *nb;
- EphyBookmarks *eb;
- EphyHistory *history;
nb = ephy_window_get_notebook (tab->priv->window);
ephy_notebook_set_page_icon (EPHY_NOTEBOOK (nb),
GTK_WIDGET (tab->priv->embed),
favicon);
-
- if (tab->priv->favicon_url[0] != '\0')
- {
- eb = ephy_shell_get_bookmarks (ephy_shell);
- history = ephy_embed_shell_get_global_history
- (EPHY_EMBED_SHELL (ephy_shell));
- ephy_bookmarks_set_icon (eb, tab->priv->location,
- tab->priv->favicon_url);
- ephy_history_set_icon (history, tab->priv->location,
- tab->priv->favicon_url);
- ephy_window_update_control (tab->priv->window,
- FaviconControl);
- }
}
-/* Private callbacks for embed signals */
-
static void
-ephy_tab_favicon_cache_changed_cb (EphyFaviconCache *cache,
- char *url,
- EphyTab *tab)
+ephy_tab_icon_cache_changed_cb (EphyFaviconCache *cache,
+ const char *address,
+ EphyTab *tab)
{
GdkPixbuf *pixbuf = NULL;
/* is this for us? */
- if (strncmp (tab->priv->favicon_url, url, 255) != 0) return;
+ if (strcmp (tab->priv->icon_address, address) != 0) return;
+ /* notify */
+ g_object_notify (G_OBJECT (tab), "icon");
+
/* set favicon */
- pixbuf = ephy_favicon_cache_get (cache, tab->priv->favicon_url);
- ephy_tab_set_favicon (tab, pixbuf);
+ if (tab->priv->icon_address)
+ {
+ pixbuf = ephy_favicon_cache_get (cache, tab->priv->icon_address);
+ ephy_tab_set_favicon (tab, pixbuf);
- if (pixbuf) g_object_unref (pixbuf);
+ if (pixbuf)
+ {
+ g_object_unref (pixbuf);
+ }
+ }
}
-static void
-ephy_tab_favicon_cb (EphyEmbed *embed,
- const char *url,
- EphyTab *tab)
+void
+ephy_tab_set_icon_address (EphyTab *tab, const char *address)
{
+ EphyBookmarks *eb;
+ EphyHistory *history;
EphyFaviconCache *cache;
GdkPixbuf *pixbuf = NULL;
- g_strlcpy (tab->priv->favicon_url,
- url, 255);
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ g_free (tab->priv->icon_address);
+ tab->priv->icon_address = g_strdup (address);
cache = ephy_embed_shell_get_favicon_cache
(EPHY_EMBED_SHELL (ephy_shell));
- if (url && url[0] != '\0')
+ if (tab->priv->icon_address)
{
- pixbuf = ephy_favicon_cache_get (cache, tab->priv->favicon_url);
+ eb = ephy_shell_get_bookmarks (ephy_shell);
+ history = ephy_embed_shell_get_global_history
+ (EPHY_EMBED_SHELL (ephy_shell));
+ ephy_bookmarks_set_icon (eb, tab->priv->address,
+ tab->priv->icon_address);
+ ephy_history_set_icon (history, tab->priv->address,
+ tab->priv->icon_address);
+
+ pixbuf = ephy_favicon_cache_get (cache, tab->priv->icon_address);
+
ephy_tab_set_favicon (tab, pixbuf);
- if (pixbuf) g_object_unref (pixbuf);
+
+ if (pixbuf)
+ {
+ g_object_unref (pixbuf);
+ }
}
else
{
ephy_tab_set_favicon (tab, NULL);
}
+
+ ephy_window_update_control (tab->priv->window,
+ FaviconControl);
+
+ g_object_notify (G_OBJECT (tab), "icon");
+}
+
+const char *
+ephy_tab_get_icon_address (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), "");
+
+ return tab->priv->icon_address;
+}
+
+/* Private callbacks for embed signals */
+
+static void
+ephy_tab_favicon_cb (EphyEmbed *embed,
+ const char *address,
+ EphyTab *tab)
+{
+ ephy_tab_set_icon_address (tab, address);
}
static void
ephy_tab_link_message_cb (EphyEmbed *embed,
- const char *message,
+ const gchar *message,
EphyTab *tab)
{
if (!tab->priv->is_active) return;
- g_free (tab->priv->link_message);
- tab->priv->link_message = g_strdup (message);
+ ephy_tab_set_link_message (tab, message);
ephy_window_update_control (tab->priv->window,
StatusbarMessageControl);
}
static void
-ephy_tab_location_cb (EphyEmbed *embed, EphyTab *tab)
+ephy_tab_address_cb (EphyEmbed *embed, EphyTab *tab)
{
- if (tab->priv->location) g_free (tab->priv->location);
- ephy_embed_get_location (embed, TRUE,
- &tab->priv->location);
- tab->priv->link_message = NULL;
- tab->priv->favicon_url[0] = '\0';
- ephy_tab_set_favicon (tab, NULL);
+ char *address;
+
+ ephy_embed_get_location (embed, TRUE, &address);
+ ephy_tab_set_location (tab, address);
+ g_free (address);
+
+ ephy_tab_set_link_message (tab, NULL);
+ ephy_tab_set_icon_address (tab, NULL);
if (tab->priv->is_active)
{
@@ -485,6 +673,8 @@ ephy_tab_location_cb (EphyEmbed *embed, EphyTab *tab)
static void
ephy_tab_zoom_changed_cb (EphyEmbed *embed, float zoom, EphyTab *tab)
{
+ ephy_tab_set_zoom (tab, zoom);
+
if (tab->priv->is_active)
{
ephy_window_update_control (tab->priv->window, ZoomControl);
@@ -492,55 +682,15 @@ ephy_tab_zoom_changed_cb (EphyEmbed *embed, float zoom, EphyTab *tab)
}
static void
-ephy_tab_set_title (EphyTab *tab, const char *title)
-{
- GtkWidget *nb;
-
- nb = ephy_window_get_notebook (tab->priv->window);
- ephy_notebook_set_page_title (EPHY_NOTEBOOK (nb),
- GTK_WIDGET (tab->priv->embed),
- title);
-}
-
-static void
ephy_tab_title_cb (EphyEmbed *embed, EphyTab *tab)
{
- GnomeVFSURI *uri;
-
- if (tab->priv->title) g_free (tab->priv->title);
- ephy_embed_get_title (embed, &tab->priv->title);
-
- if (*(tab->priv->title) == '\0')
- {
- g_free (tab->priv->title);
- tab->priv->title = NULL;
-
- uri = gnome_vfs_uri_new (tab->priv->location);
- if (uri)
- {
- tab->priv->title = gnome_vfs_uri_to_string (uri,
- GNOME_VFS_URI_HIDE_USER_NAME |
- GNOME_VFS_URI_HIDE_PASSWORD |
- GNOME_VFS_URI_HIDE_HOST_PORT |
- GNOME_VFS_URI_HIDE_TOPLEVEL_METHOD |
- GNOME_VFS_URI_HIDE_FRAGMENT_IDENTIFIER);
- gnome_vfs_uri_unref (uri);
- }
+ char *title;
- if (tab->priv->title == NULL || *(tab->priv->title) == '\0')
- {
- g_free (tab->priv->title);
- tab->priv->title = g_strdup (_("Blank page"));
- }
- }
+ ephy_embed_get_title (embed, &title);
- ephy_tab_set_title (tab, tab->priv->title);
+ ephy_tab_set_title (tab, title);
- if (tab->priv->is_active)
- {
- ephy_window_update_control (tab->priv->window,
- TitleControl);
- }
+ g_free (title);
}
static int
@@ -585,13 +735,11 @@ get_host_name_from_uri (const char *uri)
return result;
}
-static void
-build_net_state_message (char *message,
- const char *uri,
- EmbedState flags)
+static char *
+build_net_state_message (const char *uri, EmbedState flags)
{
const char *msg = NULL;
- char *host;
+ char *host, *message = NULL;
host = get_host_name_from_uri (uri);
@@ -627,10 +775,12 @@ build_net_state_message (char *message,
if (msg)
{
- g_snprintf (message, 255, msg, host);
+ message = g_strdup_printf (msg, host);
}
g_free (host);
+
+ return message;
}
static void
@@ -653,30 +803,31 @@ build_progress_from_requests (EphyTab *tab, EmbedState state)
tab->priv->total_requests);
if (load_percent > tab->priv->load_percent)
{
- tab->priv->load_percent = load_percent;
+ ephy_tab_set_load_percent (tab, load_percent);
}
}
}
static void
-ensure_location (EphyTab *tab, const char *uri)
+ensure_address (EphyTab *tab, const char *address)
{
- if (tab->priv->location == NULL)
+ if (tab->priv->address == NULL)
{
- tab->priv->location = g_strdup (uri);
- ephy_window_update_control (tab->priv->window,
- LocationControl);
+ ephy_tab_set_location (tab, address);
+ ephy_window_update_control (tab->priv->window, LocationControl);
}
}
static void
ephy_tab_net_state_cb (EphyEmbed *embed, const char *uri,
- EmbedState state, EphyTab *tab)
+ EmbedState state, EphyTab *tab)
{
- build_net_state_message (tab->priv->status_message, uri, state);
+ g_free (tab->priv->status_message);
+ tab->priv->status_message = build_net_state_message (uri, state);
- ephy_window_update_control (tab->priv->window,
- StatusbarMessageControl);
+ g_object_notify (G_OBJECT (tab), "message");
+
+ ephy_window_update_control (tab->priv->window, StatusbarMessageControl);
if (state & EMBED_STATE_IS_NETWORK)
{
@@ -684,9 +835,9 @@ ephy_tab_net_state_cb (EphyEmbed *embed, const char *uri,
{
tab->priv->total_requests = 0;
tab->priv->cur_requests = 0;
- tab->priv->load_percent = 0;
+ ephy_tab_set_load_percent (tab, 0);
- ensure_location (tab, uri);
+ ensure_address (tab, uri);
ephy_tab_set_load_status (tab, TAB_LOAD_STARTED);
@@ -694,11 +845,10 @@ ephy_tab_net_state_cb (EphyEmbed *embed, const char *uri,
NavControl);
ephy_window_update_control (tab->priv->window,
SpinnerControl);
- ephy_tab_update_color (tab);
}
else if (state & EMBED_STATE_STOP)
{
- tab->priv->load_percent = 0;
+ ephy_tab_set_load_percent (tab, 0);
ephy_tab_set_load_status (tab, TAB_LOAD_COMPLETED);
@@ -718,7 +868,7 @@ ephy_tab_net_state_cb (EphyEmbed *embed, const char *uri,
static void
ephy_tab_new_window_cb (EphyEmbed *embed, EphyEmbed **new_embed,
- EmbedChromeMask chromemask, EphyTab *tab)
+ EmbedChromeMask chromemask, EphyTab *tab)
{
EphyTab *new_tab;
EphyWindow *window;
@@ -744,8 +894,6 @@ static void
ephy_tab_visibility_cb (EphyEmbed *embed, gboolean visibility,
EphyTab *tab)
{
- EphyWindow *window;
-
if (visibility)
{
gtk_widget_show (GTK_WIDGET(embed));
@@ -757,10 +905,9 @@ ephy_tab_visibility_cb (EphyEmbed *embed, gboolean visibility,
ephy_tab_set_visibility (tab, visibility);
- window = ephy_tab_get_window (tab);
- g_return_if_fail (window != NULL);
+ g_return_if_fail (tab->priv->window != NULL);
- ephy_window_update_control (window, WindowVisibilityControl);
+ ephy_window_update_control (tab->priv->window, WindowVisibilityControl);
}
static void
@@ -768,6 +915,9 @@ ephy_tab_destroy_brsr_cb (EphyEmbed *embed, EphyTab *tab)
{
EphyWindow *window;
+ g_return_if_fail (IS_EPHY_TAB (tab));
+ g_return_if_fail (tab->priv->window != NULL);
+
window = ephy_tab_get_window (tab);
ephy_window_remove_tab (window, tab);
@@ -780,14 +930,17 @@ static gint
ephy_tab_open_uri_cb (EphyEmbed *embed, const char *uri,
EphyTab *tab)
{
+ LOG ("ephy_tab_open_uri_cb %s", uri)
+
+ /* FIXME: what is this function supposed to do ? */
return FALSE;
}
static void
ephy_tab_size_to_cb (EphyEmbed *embed, gint width, gint height,
- EphyTab *tab)
+ EphyTab *tab)
{
- GList *tabs;
+ GList *tabs = NULL;
EphyWindow *window;
GtkWidget *widget;
EmbedChromeMask chromemask;
@@ -795,8 +948,8 @@ ephy_tab_size_to_cb (EphyEmbed *embed, gint width, gint height,
tab->priv->width = width;
tab->priv->height = height;
- window = ephy_tab_get_window (tab);
- tabs = (GList *) ephy_window_get_tabs (window);
+ window = tab->priv->window;
+ tabs = ephy_window_get_tabs (window);
widget = GTK_WIDGET (embed);
chromemask = ephy_window_get_chrome (window);
@@ -821,6 +974,8 @@ ephy_tab_size_to_cb (EphyEmbed *embed, gint width, gint height,
g_idle_add (let_me_resize_hack, embed);
}
}
+
+ g_list_free (tabs);
}
static void
@@ -843,7 +998,8 @@ ephy_tab_show_embed_popup (EphyTab *tab, EphyEmbedEvent *event)
char *path;
GtkWidget *widget;
- window = ephy_tab_get_window (tab);
+ g_return_if_fail (IS_EPHY_TAB (tab));
+ window = tab->priv->window;
ephy_embed_event_get_property (event, "framed_page", &value);
framed = g_value_get_int (value);
@@ -955,6 +1111,8 @@ static void
ephy_tab_security_change_cb (EphyEmbed *embed, EmbedSecurityLevel level,
EphyTab *tab)
{
+ ephy_tab_set_security_level (tab, level);
+
if (!tab->priv->is_active) return;
ephy_window_update_control (tab->priv->window,
@@ -967,7 +1125,10 @@ ephy_tab_init (EphyTab *tab)
GObject *embed, *embed_widget;
EphyEmbedSingle *single;
EphyFaviconCache *cache;
+ char *id;
+ LOG ("EphyTab initialising %p", tab)
+
single = ephy_embed_shell_get_embed_single
(EPHY_EMBED_SHELL (ephy_shell));
@@ -976,13 +1137,8 @@ ephy_tab_init (EphyTab *tab)
tab->priv->window = NULL;
tab->priv->event = NULL;
tab->priv->is_active = FALSE;
- *tab->priv->status_message = '\0';
+ tab->priv->status_message = NULL;
tab->priv->link_message = NULL;
- *tab->priv->favicon_url = '\0';
- tab->priv->load_status = TAB_LOAD_NONE;
- tab->priv->load_percent = 0;
- tab->priv->title = NULL;
- tab->priv->location = NULL;
tab->priv->total_requests = 0;
tab->priv->cur_requests = 0;
tab->priv->width = -1;
@@ -995,6 +1151,16 @@ ephy_tab_init (EphyTab *tab)
embed = G_OBJECT (tab->priv->embed);
embed_widget = G_OBJECT (tab->priv->embed);
+ id = g_strdup_printf ("Tab%lu", tab_id++);
+
+ tab->priv->action = g_object_new (EGG_TYPE_ACTION,
+ "name", id,
+ "label", _("Blank page"),
+ NULL);
+ g_free (id);
+ g_signal_connect (tab->priv->action, "activate",
+ G_CALLBACK (ephy_tab_action_activate_cb), tab);
+
/* set a pointer in the embed's widget back to the tab */
g_object_set_data (embed_widget, "EphyTab", tab);
@@ -1008,7 +1174,7 @@ ephy_tab_init (EphyTab *tab)
G_CALLBACK (ephy_tab_link_message_cb),
tab);
g_signal_connect (embed, "ge_location",
- G_CALLBACK (ephy_tab_location_cb),
+ G_CALLBACK (ephy_tab_address_cb),
tab);
g_signal_connect (embed, "ge_title",
G_CALLBACK (ephy_tab_title_cb),
@@ -1049,84 +1215,184 @@ ephy_tab_init (EphyTab *tab)
cache = ephy_embed_shell_get_favicon_cache (EPHY_EMBED_SHELL (ephy_shell));
g_signal_connect_object (G_OBJECT (cache), "changed",
- G_CALLBACK (ephy_tab_favicon_cache_changed_cb),
+ G_CALLBACK (ephy_tab_icon_cache_changed_cb),
tab, 0);
}
-TabLoadStatus
-ephy_tab_get_load_status (EphyTab *tab)
+void
+ephy_tab_set_load_percent (EphyTab *tab, int percent)
{
- return tab->priv->load_status;
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ tab->priv->load_percent = percent;
+
+ g_object_notify (G_OBJECT (tab), "load-progress");
}
int
ephy_tab_get_load_percent (EphyTab *tab)
{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), -1);
+
return tab->priv->load_percent;
}
const char *
ephy_tab_get_status_message (EphyTab *tab)
{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), "");
+
if (tab->priv->link_message)
{
return tab->priv->link_message;
}
- else
+ else if (tab->priv->status_message)
{
return tab->priv->status_message;
}
+ else
+ {
+ return "";
+ }
}
-const char *
-ephy_tab_get_title (EphyTab *tab)
+#define MAX_LABEL_LENGTH 32
+
+void
+ephy_tab_set_title (EphyTab *tab, const char *new_title)
{
- if (tab->priv->title &&
- g_utf8_strlen(tab->priv->title, -1))
+ GtkWidget *nb;
+ GnomeVFSURI *uri;
+ char *title_short = NULL;
+ char *title = NULL;
+
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ g_free (tab->priv->title);
+
+ if (new_title == NULL || new_title[0] == '\0')
{
- return tab->priv->title;
+ uri = gnome_vfs_uri_new (tab->priv->address);
+ if (uri)
+ {
+ title = gnome_vfs_uri_to_string (uri,
+ GNOME_VFS_URI_HIDE_USER_NAME |
+ GNOME_VFS_URI_HIDE_PASSWORD |
+ GNOME_VFS_URI_HIDE_HOST_PORT |
+ GNOME_VFS_URI_HIDE_TOPLEVEL_METHOD |
+ GNOME_VFS_URI_HIDE_FRAGMENT_IDENTIFIER);
+ gnome_vfs_uri_unref (uri);
+ }
+
+ if (title == NULL || title[0] == '\0')
+ {
+ g_free (title);
+ title = g_strdup (_("Blank page"));
+ }
}
else
{
- return _("Untitled");
+ title = g_strdup (new_title);
}
+
+ tab->priv->title = title;
+
+ title_short = ephy_string_shorten (title, MAX_LABEL_LENGTH);
+
+ /**
+ * FIXME: instead of shortening the title here, use an egg action
+ * which creates menu items with ellipsizing labels
+ */
+ g_object_set (G_OBJECT (tab->priv->action),
+ "label", title_short,
+ NULL);
+
+ g_free (title_short);
+
+ if (tab->priv->window != NULL)
+ {
+ nb = ephy_window_get_notebook (tab->priv->window);
+ ephy_notebook_set_page_title (EPHY_NOTEBOOK (nb),
+ GTK_WIDGET (tab->priv->embed),
+ tab->priv->title);
+
+ if (tab->priv->is_active)
+ {
+ ephy_window_update_control (tab->priv->window, TitleControl);
+ }
+ }
+
+ g_object_notify (G_OBJECT (tab), "title");
}
const char *
-ephy_tab_get_location (EphyTab *tab)
+ephy_tab_get_title (EphyTab *tab)
{
- return tab->priv->location;
+ g_return_val_if_fail (IS_EPHY_TAB (tab), "");
+
+ return tab->priv->title;
}
const char *
-ephy_tab_get_favicon_url (EphyTab *tab)
+ephy_tab_get_location (EphyTab *tab)
{
- if (tab->priv->favicon_url[0] == '\0')
- {
- return NULL;
- }
- else
- {
- return tab->priv->favicon_url;
- }
+ g_return_val_if_fail (IS_EPHY_TAB (tab), "");
+
+ return tab->priv->address;
}
void
ephy_tab_set_location (EphyTab *tab,
- char *location)
+ const char *address)
{
- if (tab->priv->location) g_free (tab->priv->location);
- tab->priv->location = g_strdup (location);
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ if (tab->priv->address) g_free (tab->priv->address);
+ tab->priv->address = g_strdup (address);
+
+ g_object_notify (G_OBJECT (tab), "address");
}
void
-ephy_tab_update_control (EphyTab *tab,
- TabControlID id)
+ephy_tab_set_security_level (EphyTab *tab, EmbedSecurityLevel level)
{
- switch (id)
- {
- case TAB_CONTROL_TITLE:
- ephy_tab_set_title (tab, tab->priv->title);
- break;
- }
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ tab->priv->security_level = level;
+
+ g_object_notify (G_OBJECT (tab), "security-level");
+}
+
+EmbedSecurityLevel
+ephy_tab_get_security_level (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), STATE_IS_UNKNOWN);
+
+ return tab->priv->security_level;
+}
+
+void
+ephy_tab_set_zoom (EphyTab *tab, float zoom)
+{
+ g_return_if_fail (IS_EPHY_TAB (tab));
+
+ tab->priv->zoom = zoom;
+
+ g_object_notify (G_OBJECT (tab), "zoom");
+}
+
+float
+ephy_tab_get_zoom (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), 1.0);
+
+ return tab->priv->zoom;
+}
+
+EggAction *
+ephy_tab_get_action (EphyTab *tab)
+{
+ g_return_val_if_fail (IS_EPHY_TAB (tab), NULL);
+
+ return tab->priv->action;
}