2 * Sylpheed -- regexp pattern matching utilities
3 * Copyright (C) 2001 Thomas Link, Hiroyuki Yamamoto
4 * Modified by Melvin Hadasht.
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
28 #include "string_match.h"
30 int string_match_precompile (gchar *rexp, regex_t *preg, int cflags)
34 g_return_val_if_fail(rexp, -1);
35 g_return_val_if_fail(*rexp, -1);
37 problem = regcomp(preg, rexp, cflags);
43 gchar *string_remove_match(gchar *buf, gint buflen, gchar * txt, regex_t *preg)
55 notfound = regexec(preg, txt+j, 1, &match, (j ? REG_NOTBOL : 0));
57 while (txt[j] && i < buflen -1)
60 if ( match.rm_so == match.rm_eo)
64 while (txt[j] && j != k + match.rm_so)
70 } while (txt[j] && i < buflen - 1);
73 strncpy(buf, _("(Subject cleared by RegExp)"),
75 buf[buflen - 1] = 0x00;