[Xfce4-commits] <midori:master> Handle unique_filename and null-check data source
Christian Dywan
noreply at xfce.org
Thu Jun 9 00:40:01 CEST 2011
Updating branch refs/heads/master
to 38da85ee430cad53a5089628b674f132f7f52d82 (commit)
from 3a51aafd7f4d491d59d9fa5cc6c231309a0750fd (commit)
commit 38da85ee430cad53a5089628b674f132f7f52d82
Author: Alexander Butenko <a.butenka at gmail.com>
Date: Thu Jun 9 00:37:25 2011 +0200
Handle unique_filename and null-check data source
midori/midori-browser.c | 53 +++++++++++++++++++++++------------------------
1 files changed, 26 insertions(+), 27 deletions(-)
diff --git a/midori/midori-browser.c b/midori/midori-browser.c
index 9863e1c..2dff070 100644
--- a/midori/midori-browser.c
+++ b/midori/midori-browser.c
@@ -1050,7 +1050,8 @@ midori_browser_save_uri (MidoriBrowser* browser,
frame = webkit_web_view_get_main_frame (WEBKIT_WEB_VIEW (web_view));
data_source = webkit_web_frame_get_data_source (frame);
data = webkit_web_data_source_get_data (data_source);
- midori_browser_save_source (uri, data->str, data->len, filename);
+ if (data)
+ midori_browser_save_source (uri, data->str, data->len, filename);
g_free (last_dir);
last_dir = folder;
@@ -3300,8 +3301,6 @@ midori_browser_save_source (const gchar* uri,
const size_t len,
const gchar* outfile)
{
- gchar* filename;
- gchar* extension;
gchar* unique_filename;
gint fd;
FILE* fp;
@@ -3312,16 +3311,20 @@ midori_browser_save_source (const gchar* uri,
if (!outfile)
{
+ gchar* filename;
+ gchar* extension;
+
extension = midori_browser_get_uri_extension (uri);
filename = g_strdup_printf ("%uXXXXXX%s",
g_str_hash (uri), extension);
g_free (extension);
fd = g_file_open_tmp (filename, &unique_filename, NULL);
+ g_free (filename);
}
else
{
- filename = g_strdup (outfile);
- fd = g_open (filename, O_WRONLY|O_CREAT, 0644);
+ unique_filename = g_strdup (outfile);
+ fd = g_open (unique_filename, O_WRONLY|O_CREAT, 0644);
}
if (fd != -1)
@@ -3334,12 +3337,11 @@ midori_browser_save_source (const gchar* uri,
{
g_warning ("Error writing to file %s "
"in midori_browser_source_transfer_cb()", unique_filename);
- g_free (unique_filename);
+ katze_assign (unique_filename, NULL);
}
}
close (fd);
}
- g_free (filename);
return unique_filename;
}
@@ -3347,6 +3349,9 @@ static void
_action_source_view_activate (GtkAction* action,
MidoriBrowser* browser)
{
+ WebKitWebDataSource *data_source;
+ WebKitWebFrame *frame;
+ const GString *data;
GtkWidget* view;
GtkWidget* web_view;
gchar* text_editor;
@@ -3358,41 +3363,35 @@ _action_source_view_activate (GtkAction* action,
g_object_get (browser->settings, "text-editor", &text_editor, NULL);
uri = midori_view_get_display_uri (MIDORI_VIEW (view));
+ web_view = midori_view_get_web_view (MIDORI_VIEW (view));
+ frame = webkit_web_view_get_main_frame (WEBKIT_WEB_VIEW (web_view));
+ data_source = webkit_web_frame_get_data_source (frame);
+ data = webkit_web_data_source_get_data (data_source);
+ if (data)
+ filename = midori_browser_save_source (uri, data->str, data->len, NULL);
+
+ if (!filename)
+ return;
if (!(text_editor && *text_editor))
{
GtkWidget* source;
GtkWidget* web_view;
+ gchar* source_uri;
+
+ source_uri = g_filename_to_uri (filename, NULL, NULL);
+ g_free (filename);
source = midori_view_new (NULL);
midori_view_set_settings (MIDORI_VIEW (source), browser->settings);
web_view = midori_view_get_web_view (MIDORI_VIEW (source));
webkit_web_view_set_view_source_mode (WEBKIT_WEB_VIEW (web_view), TRUE);
- webkit_web_view_load_uri (WEBKIT_WEB_VIEW (web_view), uri);
+ webkit_web_view_load_uri (WEBKIT_WEB_VIEW (web_view), source_uri);
gtk_widget_show (source);
midori_browser_add_tab (browser, source);
- g_free (text_editor);
- return;
}
-
- if (g_str_has_prefix (uri, "file://"))
- filename = g_filename_from_uri (uri, NULL, NULL);
-
else
{
- WebKitWebDataSource *data_source;
- WebKitWebFrame *frame;
- const GString *data;
-
- web_view = midori_view_get_web_view (MIDORI_VIEW (view));
- frame = webkit_web_view_get_main_frame (WEBKIT_WEB_VIEW (web_view));
- data_source = webkit_web_frame_get_data_source (frame);
- data = webkit_web_data_source_get_data (data_source);
- filename = midori_browser_save_source (uri, data->str, data->len, NULL);
- }
-
- if (filename)
- {
sokoke_spawn_program (text_editor, filename);
g_free (filename);
}
More information about the Xfce4-commits
mailing list