aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2004-04-28 23:51:57 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2004-04-28 23:51:57 +0800
commitfdf4f455f632048edbb63096b767453456c617e4 (patch)
treefaff1243782d2c42c610d9343e08b4f6feea0f70 /mail
parent518c1cc2fd6d3e7255bc498e4ca67872b7370c4f (diff)
downloadgsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar.gz
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar.bz2
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar.lz
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar.xz
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.tar.zst
gsoc2013-evolution-fdf4f455f632048edbb63096b767453456c617e4.zip
Use g_shell_parse_argv() to get the actual script path and then check that
2004-04-28 Jeffrey Stedfast <fejj@ximian.com> * em-composer-prefs.c (sig_add_script_response): Use g_shell_parse_argv() to get the actual script path and then check that we can exec argv[0] rather than treating the entire command-line as the signature script. Fixes bug #57305. svn path=/trunk/; revision=25667
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog7
-rw-r--r--mail/em-composer-prefs.c17
2 files changed, 17 insertions, 7 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index b705728b06..8de4e11651 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,10 @@
+2004-04-28 Jeffrey Stedfast <fejj@ximian.com>
+
+ * em-composer-prefs.c (sig_add_script_response): Use
+ g_shell_parse_argv() to get the actual script path and then check
+ that we can exec argv[0] rather than treating the entire
+ command-line as the signature script. Fixes bug #57305.
+
2004-04-28 Not Zed <NotZed@Ximian.com>
* message-list.c (ml_selection_clear_event): return the right
diff --git a/mail/em-composer-prefs.c b/mail/em-composer-prefs.c
index 554e115e78..b5193900ed 100644
--- a/mail/em-composer-prefs.c
+++ b/mail/em-composer-prefs.c
@@ -355,9 +355,10 @@ sig_add_cb (GtkWidget *widget, EMComposerPrefs *prefs)
static void
sig_add_script_response (GtkWidget *widget, int button, EMComposerPrefs *prefs)
{
- const char *name;
- char *script;
+ char *script, **argv = NULL;
GtkWidget *entry;
+ const char *name;
+ int argc;
if (button == GTK_RESPONSE_ACCEPT) {
entry = glade_xml_get_widget (prefs->sig_script_gui, "fileentry_add_script_script");
@@ -365,10 +366,10 @@ sig_add_script_response (GtkWidget *widget, int button, EMComposerPrefs *prefs)
entry = glade_xml_get_widget (prefs->sig_script_gui, "entry_add_script_name");
name = gtk_entry_get_text (GTK_ENTRY (entry));
- if (script && *script) {
+ if (script && *script && g_shell_parse_argv (script, &argc, &argv, NULL)) {
struct stat st;
- if (stat (script, &st) && S_ISREG (st.st_mode) && access (script, X_OK) == 0) {
+ if (stat (argv[0], &st) && S_ISREG (st.st_mode) && access (argv[0], X_OK) == 0) {
GtkWidget *parent;
ESignature *sig;
@@ -385,14 +386,16 @@ sig_add_script_response (GtkWidget *widget, int button, EMComposerPrefs *prefs)
}
gtk_widget_hide (prefs->sig_script_dialog);
- g_free(script);
+ g_strfreev (argv);
+ g_free (script);
return;
}
}
- e_error_run((GtkWindow *)prefs->sig_script_dialog, "mail:signature-notscript", script, NULL);
- g_free(script);
+ e_error_run((GtkWindow *)prefs->sig_script_dialog, "mail:signature-notscript", argv ? argv[0] : script, NULL);
+ g_strfreev (argv);
+ g_free (script);
return;
}