aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexandre Mazari <alexandre.mazari@gmail.com>2012-03-29 01:56:43 +0800
committerXan Lopez <xan@igalia.com>2012-03-29 01:56:43 +0800
commit233c86a85e63f00a246badabf1879569ad5d6ea6 (patch)
tree49127c74d37558f94ad609988fa74d98d7d06ca2
parentf1c478dc347b8e59dab6e4d23095b44c33515be7 (diff)
downloadgsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar.gz
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar.bz2
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar.lz
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar.xz
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.tar.zst
gsoc2013-epiphany-233c86a85e63f00a246badabf1879569ad5d6ea6.zip
ephy-web-app-utils: do not use the webview in the web app creation method
It's not really needed, will allow to reuse this code during profile migration. https://bugzilla.gnome.org/show_bug.cgi?id=658925
-rw-r--r--embed/ephy-web-app-utils.c20
-rw-r--r--embed/ephy-web-app-utils.h2
-rw-r--r--src/window-commands.c2
3 files changed, 11 insertions, 13 deletions
diff --git a/embed/ephy-web-app-utils.c b/embed/ephy-web-app-utils.c
index 6c3c4d327..0789f6ef2 100644
--- a/embed/ephy-web-app-utils.c
+++ b/embed/ephy-web-app-utils.c
@@ -182,7 +182,7 @@ out:
#define EPHY_TOOLBARS_XML_FILE "epiphany-toolbars-3.xml"
static char *
-create_desktop_file (EphyWebView *view,
+create_desktop_file (const char *address,
const char *profile_dir,
const char *title,
GdkPixbuf *icon)
@@ -208,7 +208,7 @@ create_desktop_file (EphyWebView *view,
g_key_file_set_value (file, "Desktop Entry", "Name", title);
exec_string = g_strdup_printf ("epiphany --application-mode --profile=\"%s\" %s",
profile_dir,
- webkit_web_view_get_uri (WEBKIT_WEB_VIEW (view)));
+ address);
g_key_file_set_value (file, "Desktop Entry", "Exec", exec_string);
g_free (exec_string);
g_key_file_set_value (file, "Desktop Entry", "StartupNotification", "true");
@@ -267,7 +267,7 @@ out:
}
static void
-create_cookie_jar_for_domain (EphyWebView *view, const char *directory)
+create_cookie_jar_for_domain (const char *address, const char *directory)
{
SoupSession *session;
GSList *cookies, *p;
@@ -281,7 +281,7 @@ create_cookie_jar_for_domain (EphyWebView *view, const char *directory)
g_free (filename);
/* The app domain for the current view */
- uri = soup_uri_new (webkit_web_view_get_uri (WEBKIT_WEB_VIEW (view)));
+ uri = soup_uri_new (address);
domain = uri->host;
/* The current cookies */
@@ -304,23 +304,21 @@ create_cookie_jar_for_domain (EphyWebView *view, const char *directory)
/**
* ephy_web_application_create:
- * @view: an #EphyWebView
+ * @address: the address of the new web application
* @title: the title for the new web application
* @icon: the icon for the new web application
*
- * Creates a new Web Application from the currently loaded URI in the @view.
+ * Creates a new Web Application from the provided address.
*
* Returns: (transfer-full): the path to the desktop file representing the new application
**/
char *
-ephy_web_application_create (EphyWebView *view, const char *title, GdkPixbuf *icon)
+ephy_web_application_create (const char *address, const char *title, GdkPixbuf *icon)
{
char *profile_dir = NULL;
char *toolbar_path = NULL;
char *desktop_file_path = NULL;
- g_return_val_if_fail (EPHY_IS_WEB_VIEW (view), NULL);
-
/* If there's already a WebApp profile for the contents of this
* view, do nothing. */
profile_dir = ephy_web_application_get_profile_directory (title);
@@ -342,10 +340,10 @@ ephy_web_application_create (EphyWebView *view, const char *title, GdkPixbuf *ic
if (!g_file_set_contents (toolbar_path, EPHY_WEB_APP_TOOLBAR, -1, NULL))
goto out;
- create_cookie_jar_for_domain (view, profile_dir);
+ create_cookie_jar_for_domain (address, profile_dir);
/* Create the deskop file. */
- desktop_file_path = create_desktop_file (view, profile_dir, title, icon);
+ desktop_file_path = create_desktop_file (address, profile_dir, title, icon);
out:
if (toolbar_path)
diff --git a/embed/ephy-web-app-utils.h b/embed/ephy-web-app-utils.h
index 7c8a09f3d..b552da3e3 100644
--- a/embed/ephy-web-app-utils.h
+++ b/embed/ephy-web-app-utils.h
@@ -41,7 +41,7 @@ typedef struct {
#define EPHY_WEB_APP_PREFIX "app-"
#define EPHY_WEB_APP_ICON_NAME "app-icon.png"
-char *ephy_web_application_create (EphyWebView *view, const char *title, GdkPixbuf *icon);
+char *ephy_web_application_create (const char *address, const char *title, GdkPixbuf *icon);
gboolean ephy_web_application_delete (const char *name);
diff --git a/src/window-commands.c b/src/window-commands.c
index 70fc0cf64..4c7c4b7cf 100644
--- a/src/window-commands.c
+++ b/src/window-commands.c
@@ -523,7 +523,7 @@ dialog_save_as_application_response_cb (GtkDialog *dialog,
}
/* Create Web Application, including a new profile and .desktop file. */
- desktop_file = ephy_web_application_create (data->view,
+ desktop_file = ephy_web_application_create (webkit_web_view_get_uri (data->view),
gtk_entry_get_text (GTK_ENTRY (data->entry)),
gtk_image_get_pixbuf (GTK_IMAGE (data->image)));
if (desktop_file)