[balsa/78-edit-with-gnome] sendmsg-window: Use g_file_new_tmp()
- From: Peter Bloomfield <peterb src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [balsa/78-edit-with-gnome] sendmsg-window: Use g_file_new_tmp()
- Date: Mon, 16 May 2022 12:00:25 +0000 (UTC)
commit 0aff2c4cbcb648db56965a956f34cdbd438ad63e
Author: Peter Bloomfield <PeterBloomfield bellsouth net>
Date: Sun May 15 23:03:28 2022 -0400
sendmsg-window: Use g_file_new_tmp()
and GFileIOStream API, instead of mkstemp() and "FILE *" API.
src/sendmsg-window.c | 52 ++++++++++++++++++++++++++++++++--------------------
1 file changed, 32 insertions(+), 20 deletions(-)
---
diff --git a/src/sendmsg-window.c b/src/sendmsg-window.c
index a84914853..87e84a927 100644
--- a/src/sendmsg-window.c
+++ b/src/sendmsg-window.c
@@ -85,7 +85,6 @@
#endif /* ENABLE_AUTOCRYPT */
typedef struct {
- pid_t pid_editor;
gchar *filename;
BalsaSendmsg *bsmsg;
} balsa_edit_with_gnome_data;
@@ -785,17 +784,18 @@ sw_edit_activated(GSimpleAction * action,
gpointer data)
{
BalsaSendmsg *bsmsg = data;
- static const char TMP_PATTERN[] = "/tmp/balsa-edit-XXXXXX";
- gchar filename[sizeof(TMP_PATTERN)];
+ GFile *tmp_file;
+ static const char TMP_PATTERN[] = "balsa-edit-XXXXXX";
+ gchar *filename;
+ GFileIOStream *iostream;
+ GOutputStream *stream;
balsa_edit_with_gnome_data *edit_data;
pid_t pid;
- FILE *tmp;
- int tmpfd;
GtkTextBuffer *buffer;
GtkTextIter start, end;
gchar *p;
GAppInfo *app;
- char **argv;
+ char *argv[3];
GError *error = NULL;
app = g_app_info_get_default_for_type("text/plain", FALSE);
@@ -807,10 +807,18 @@ sw_edit_activated(GSimpleAction * action,
return;
}
- strcpy(filename, TMP_PATTERN);
- tmpfd = mkstemp(filename);
+ tmp_file = g_file_new_tmp(TMP_PATTERN, &iostream, &error);
+ if (tmp_file == NULL) {
+ balsa_information_parented(GTK_WINDOW(bsmsg->window),
+ LIBBALSA_INFORMATION_ERROR,
+ _("Could not create temporary file: %s"),
+ error->message);
+ g_error_free(error);
+ return;
+ }
+ filename = g_file_get_path(tmp_file);
+ g_object_unref(tmp_file);
- argv = g_new(char *, 3);
argv[0] = g_strdup(g_app_info_get_executable(app));
argv[1] =
g_strdup_printf("%s%s",
@@ -821,39 +829,44 @@ sw_edit_activated(GSimpleAction * action,
* terminal??? */
g_object_unref(app);
- tmp = fdopen(tmpfd, "w+");
+ stream = g_io_stream_get_output_stream(G_IO_STREAM(iostream));
- if(balsa_app.edit_headers) {
+ if (balsa_app.edit_headers) {
guint type;
- fprintf(tmp, "%s %s\n", _("Subject:"),
- gtk_entry_get_text(GTK_ENTRY(bsmsg->subject[1])));
+ g_output_stream_printf(stream, NULL, NULL, NULL,
+ "%s %s\n", _("Subject:"),
+ gtk_entry_get_text(GTK_ENTRY(bsmsg->subject[1])));
for (type = 0; type < G_N_ELEMENTS(address_types); type++) {
InternetAddressList *list =
libbalsa_address_view_get_list(bsmsg->recipient_view,
address_types[type]);
gchar *addr_string = internet_address_list_to_string(list, NULL, FALSE);
g_object_unref(list);
- fprintf(tmp, "%s %s\n", _(address_types[type]), addr_string);
+ g_output_stream_printf(stream, NULL, NULL, NULL,
+ "%s %s\n", _(address_types[type]), addr_string);
g_free(addr_string);
}
/* Blank line terminates headers: */
- fprintf(tmp, "\n");
+ g_output_stream_write_all(stream, "\n", 1, NULL, NULL, NULL);
}
gtk_widget_set_sensitive(GTK_WIDGET(bsmsg->text), FALSE);
buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(bsmsg->text));
gtk_text_buffer_get_bounds(buffer, &start, &end);
+
p = gtk_text_iter_get_text(&start, &end);
- fputs(p, tmp);
+ g_output_stream_write_all(stream, p, strlen(p), NULL, NULL, NULL);
g_free(p);
- fclose(tmp);
+
+ g_output_stream_close(stream, NULL, NULL);
+ g_object_unref(iostream);
if (g_spawn_async(NULL, argv, NULL, G_SPAWN_DO_NOT_REAP_CHILD | G_SPAWN_SEARCH_PATH,
NULL, NULL, &pid, &error)) {
/* Return immediately. We don't want balsa to 'hang' */
edit_data = g_malloc(sizeof(balsa_edit_with_gnome_data));
- edit_data->filename = g_strdup(filename);
+ edit_data->filename = filename;
edit_data->bsmsg = bsmsg;
g_child_watch_add(pid, edit_with_gnome_check, edit_data);
} else {
@@ -862,9 +875,8 @@ sw_edit_activated(GSimpleAction * action,
_("Could not launch application: %s"),
error->message);
g_error_free(error);
+ g_free(filename);
}
-
- g_strfreev(argv);
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]