aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/ephy-session.c104
1 files changed, 100 insertions, 4 deletions
diff --git a/src/ephy-session.c b/src/ephy-session.c
index a07c9d2ab..dc38113c8 100644
--- a/src/ephy-session.c
+++ b/src/ephy-session.c
@@ -1267,7 +1267,87 @@ out:
return ret >= 0 ? TRUE : FALSE;
}
-static void
+
+static void
+confirm_before_recover (EphyWindow* window, char* url, char* title)
+{
+
+ GtkWidget *embed;
+ GString *html = g_string_new ("");
+ char *message = g_markup_printf_escaped
+ /* Translators: %s refers to the LSB distributor ID, for instance MandrivaLinux */
+ (_("This page was loading when the web browser closed unexpectedly. "
+ "This might happen again if you reload the page. If it does, please report "
+ "the problem to the %s developers."),
+ LSB_DISTRIBUTOR);
+
+ const char *format =
+ "<?xml version=\"1.0\" encoding=\"utf-8\"?>"
+ "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">"
+ "<html xmlns=\"http://www.w3.org/1999/xhtml\" lang=\"%s\" xml:lang=\"%s\">" /* language (twice) */
+ "<head>"
+ "<title>"
+ "%s" /* web title */
+ "</title>"
+ "<style type=\"text/css\">"
+ "div#body {"
+ "top: 12px;"
+ "right: 12px;"
+ "bottom: 12px;"
+ "left: 12px;"
+ "overflow: auto;"
+ "background-color:#dcdad5;"
+ "font: message-box;"
+ "border: 1px solid;"
+ "background-repeat: no-repeat;"
+ "background-position: center left;"
+ "padding: 12px 12px 12px 72px;"
+ "text-align:left;"
+
+ "h1 {"
+
+ "margin: 0;"
+ "font-size: 1.2em;"
+
+ "}"
+ "</style>"
+
+ "</head>"
+
+ "<body dir=\"%s\">" /* rtl or ltr */
+ "<div id=\"body\">"
+
+ "<h1>"
+ "%s" /* head of the message */
+ "</h1>"
+
+ "<p> %s </p>" /* message */
+
+ "</div>"
+ "</body>"
+ "</html>";
+
+ char *language = g_strdup (pango_language_to_string (gtk_get_default_language ()));
+ g_strdelimit (language, "_-@", '\0');
+
+ g_string_printf (html, format, language, language, title,
+ gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL ? "rtl" : "ltr",
+ _("Blank page"), message);
+
+ embed = (GtkWidget*) ephy_shell_new_tab (ephy_shell, window, NULL, NULL,
+ EPHY_NEW_TAB_IN_EXISTING_WINDOW | EPHY_NEW_TAB_APPEND_LAST);
+
+ /* show generated html and put the original URL in the navigation bar */
+ webkit_web_view_load_html_string (EPHY_GET_WEBKIT_WEB_VIEW_FROM_EMBED (embed),
+ html->str,
+ url);
+ g_string_free (html, TRUE);
+ g_free (message);
+ g_free (language);
+}
+
+
+static void
parse_embed (xmlNodePtr child,
EphyWindow *window,
EphySession *session)
@@ -1289,10 +1369,15 @@ parse_embed (xmlNodePtr child,
xmlFree (attr);
url = xmlGetProp (child, (const xmlChar *) "url");
- if (url == NULL) continue;
+ if (url == NULL)
+ continue;
+
+ /* in the case that crash happens before we receive the URL from the server,
+ this will open an about:blank tab. See http://bugzilla.gnome.org/show_bug.cgi?id=591294
- /* about:recover is not implemented, so tabs
- loading during crash wont be recovered (bug #583953) */
+ Otherwise, if the web was fully loaded, it is reloaded again.
+
+ */
if (!was_loading ||
strcmp ((const char *) url, "about:blank") == 0)
{
@@ -1303,6 +1388,17 @@ parse_embed (xmlNodePtr child,
EPHY_NEW_TAB_OPEN_PAGE |
EPHY_NEW_TAB_APPEND_LAST);
}
+ else if (was_loading && url != NULL &&
+ strcmp ((const char *) url, "about:blank") != 0)
+ {
+ /* shows a message to the user that warns that this page was
+ loading during crash and make Epiphany crash again,
+ in this case we know the URL */
+
+ xmlChar* title = xmlGetProp (child, (const xmlChar *) "title");
+
+ confirm_before_recover (window, (char*) url, (char*) title);
+ }
xmlFree (url);
}