diff options
-rw-r--r-- | filter/ChangeLog | 10 | ||||
-rw-r--r-- | filter/filter-file.c | 14 | ||||
-rw-r--r-- | filter/filtertypes.xml | 26 | ||||
-rw-r--r-- | filter/libfilter-i18n.h | 8 |
4 files changed, 38 insertions, 20 deletions
diff --git a/filter/ChangeLog b/filter/ChangeLog index 59309cd4a6..95b02e0d4f 100644 --- a/filter/ChangeLog +++ b/filter/ChangeLog @@ -1,3 +1,13 @@ +2002-07-25 Jeffrey Stedfast <fejj@ximian.com> + + * filter-file.c (validate): Do some minimalistic validation of + command-lines (ie, make sure it isn't an empty string). + + * filtertypes.xml: s/shell-exec/shell/ (for the action) and pass + "/bin/sh" "-c" as the first 2 arguments. For the shell-exec + *rule*, change the name to "pipe-message" and add the "/bin/sh" + "-c" arguments too. + 2002-07-17 Jeffrey Stedfast <fejj@ximian.com> * filter-label.c (xml_create): Use the U_() macro to get the UTF-8 diff --git a/filter/filter-file.c b/filter/filter-file.c index b34dd0f773..14f8e04d5b 100644 --- a/filter/filter-file.c +++ b/filter/filter-file.c @@ -181,29 +181,34 @@ validate (FilterElement *fe) return FALSE; } - /* FIXME: validate command-lines? */ + /* FIXME: do more to validate command-lines? */ if (strcmp (file->type, "file") != 0) { if (stat (file->path, &st) == -1 || !S_ISREG (st.st_mode)) { char *errmsg; - errmsg = g_strdup_printf (_("File '%s' does not exist or is not a regular file."), file->path); + errmsg = g_strdup_printf (_("File '%s' does not exist or is not a regular file."), + file->path); dialog = gnome_ok_dialog (errmsg); g_free (errmsg); gnome_dialog_run_and_close (GNOME_DIALOG (dialog)); return FALSE; } + } else if (strcmp (file->type, "command") != 0) { + /* only requirements so far is that the command can't + be an empty string */ + return file->path[0] != '\0'; } return TRUE; } static int -file_eq(FilterElement *fe, FilterElement *cm) +file_eq (FilterElement *fe, FilterElement *cm) { FilterFile *ff = (FilterFile *)fe, *cf = (FilterFile *)cm; - + return ((FilterElementClass *)(parent_class))->eq(fe, cm) && ((ff->path && cf->path && strcmp(ff->path, cf->path) == 0) || (ff->path == NULL && cf->path == NULL)) @@ -216,7 +221,6 @@ xml_create (FilterElement *fe, xmlNodePtr node) { /* parent implementation */ ((FilterElementClass *)(parent_class))->xml_create (fe, node); - } static xmlNodePtr diff --git a/filter/filtertypes.xml b/filter/filtertypes.xml index 7c0690cfa0..67b7f9a6d3 100644 --- a/filter/filtertypes.xml +++ b/filter/filtertypes.xml @@ -581,32 +581,32 @@ <input type="source" name="source"/> </part> - <part name="command"> - <title>Command</title> + <part name="pipe"> + <title>Pipe Message to Shell Command</title> <input type="command" name="command"/> <input type="optionlist" name="retval-type"> <option value="is"> - <title>is</title> + <title>returns</title> <code> - (match-all (= (shell-exec ${command}) ${retval})) + (match-all (= (pipe-message "/bin/sh" "-c" ${command}) ${retval})) </code> </option> <option value="is-not"> - <title>is not</title> + <title>does not return</title> <code> - (match-all (not (= (shell-exec ${command}) ${retval}))) + (match-all (not (= (pipe-message "/bin/sh" "-c" ${command}) ${retval}))) </code> </option> <option value="greater-than"> - <title>is greater than</title> + <title>returns greater than</title> <code> - (match-all (> (shell-exec ${command}) ${retval})) + (match-all (> (pipe-message "/bin/sh" "-c" ${command}) ${retval})) </code> </option> <option value="less-than"> - <title>is less than</title> + <title>returns less than</title> <code> - (match-all (< (shell-exec ${command}) ${retval})) + (match-all (< (pipe-message "/bin/sh" "-c" ${command}) ${retval})) </code> </option> </input> @@ -682,9 +682,9 @@ <code>(play-sound ${sound})</code> <input type="file" name="sound"/> </part> - <part name="shell-exec"> - <title>Execute Shell Command</title> - <code>(shell-exec ${command})</code> + <part name="shell"> + <title>Shell Command</title> + <code>(shell "/bin/sh" "-c" ${command})</code> <input type="command" name="command"/> </part> </actionset> diff --git a/filter/libfilter-i18n.h b/filter/libfilter-i18n.h index 9d930d930b..4f5d253af5 100644 --- a/filter/libfilter-i18n.h +++ b/filter/libfilter-i18n.h @@ -4,7 +4,6 @@ char *s = N_("Assign Color"); char *s = N_("Assign Score"); char *s = N_("Attachments"); char *s = N_("Beep"); -char *s = N_("Command"); char *s = N_("contains"); char *s = N_("Copy to Folder"); char *s = N_("Date received"); @@ -14,12 +13,12 @@ char *s = N_("Deleted"); char *s = N_("does not contain"); char *s = N_("does not end with"); char *s = N_("does not exist"); +char *s = N_("does not return"); char *s = N_("does not sound like"); char *s = N_("does not start with"); char *s = N_("Do Not Exist"); char *s = N_("Draft"); char *s = N_("ends with"); -char *s = N_("Execute Shell Command"); char *s = N_("Exist"); char *s = N_("exists"); char *s = N_("Expression"); @@ -38,14 +37,19 @@ char *s = N_("Mailing list"); char *s = N_("Message Body"); char *s = N_("Message Header"); char *s = N_("Move to Folder"); +char *s = N_("Pipe Message to Shell Command"); char *s = N_("Play Sound"); char *s = N_("Read"); char *s = N_("Recipients"); char *s = N_("Regex Match"); char *s = N_("Replied to"); +char *s = N_("returns"); +char *s = N_("returns greater than"); +char *s = N_("returns less than"); char *s = N_("Score"); char *s = N_("Sender"); char *s = N_("Set Status"); +char *s = N_("Shell Command"); char *s = N_("Size (kB)"); char *s = N_("sounds like"); char *s = N_("Source Account"); |