aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--embed/ephy-web-view.c29
1 files changed, 18 insertions, 11 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c
index 9fe4f1fdb..5c3d130fb 100644
--- a/embed/ephy-web-view.c
+++ b/embed/ephy-web-view.c
@@ -2303,23 +2303,28 @@ ephy_web_view_new (void)
return GTK_WIDGET (g_object_new (EPHY_TYPE_WEB_VIEW, NULL));
}
+/**
+ * normalize_or_autosearch_url
+ * @view: an #EphyWebView
+ * @url: url to process
+ *
+ * Returns a normalized representation of @url, or an autosearch string
+ * for it if it has no scheme.
+ *
+ * Returns: the normalized @url or autosearch string
+ */
static char*
normalize_or_autosearch_url (EphyWebView *view, const char *url)
{
char *effective_url;
- SoupURI *soup_uri = NULL;
+ char *scheme;
EphyWebViewPrivate *priv = view->priv;
- /* We use SoupURI as an indication of whether the value given in url
- * is not something we want to search; we only do that, though, if
- * the address has a web scheme, because SoupURI will consider any
- * string: as a valid scheme, and we will end up prepending http://
- * to it */
- if (ephy_embed_utils_address_has_web_scheme (url))
- soup_uri = soup_uri_new (url);
+ scheme = g_uri_parse_scheme (url);
/* If the string doesn't look like an URI, let's search it; */
- if (soup_uri == NULL &&
+ if (!ephy_embed_utils_address_has_web_scheme (url) &&
+ scheme == NULL &&
priv->non_search_regex &&
!g_regex_match (priv->non_search_regex, url, 0, NULL)) {
char *query_param, *url_search;
@@ -2338,11 +2343,13 @@ normalize_or_autosearch_url (EphyWebView *view, const char *url)
effective_url = g_strdup_printf (url_search, query_param + 2);
g_free (query_param);
g_free (url_search);
+ } else if (scheme != NULL) {
+ effective_url = g_strdup (url);
} else
effective_url = ephy_embed_utils_normalize_address (url);
- if (soup_uri)
- soup_uri_free (soup_uri);
+ if (scheme)
+ g_free (scheme);
return effective_url;
}