summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-06 12:40:15 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-06 12:40:15 +0000
commit2868939004792107fa2dae733667ca934b1cd90e (patch)
tree009e583b62ec2ec097ea8d5e1824c7a57f6dfcd4 /src
parent99b1a15586c1d84b13a899535612fd0d1a8ec0dc (diff)
downloadrspamd-2868939004792107fa2dae733667ca934b1cd90e.tar.gz
rspamd-2868939004792107fa2dae733667ca934b1cd90e.zip
Fix some issues in rspamd_regexp.
Diffstat (limited to 'src')
-rw-r--r--src/libutil/regexp.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/src/libutil/regexp.c b/src/libutil/regexp.c
index a50148740..444496f45 100644
--- a/src/libutil/regexp.c
+++ b/src/libutil/regexp.c
@@ -119,7 +119,7 @@ rspamd_regexp_t*
rspamd_regexp_new (const gchar *pattern, const gchar *flags,
GError **err)
{
- const gchar *start = pattern, *end, *flags_str, *err_str;
+ const gchar *start = pattern, *end, *flags_str = NULL, *err_str;
rspamd_regexp_t *res;
pcre *r;
gchar sep = 0, *real_pattern;
@@ -151,7 +151,7 @@ rspamd_regexp_new (const gchar *pattern, const gchar *flags,
sep, pattern);
return NULL;
}
- flags = end + 1;
+ flags_str = end + 1;
start ++;
}
}
@@ -160,12 +160,12 @@ rspamd_regexp_new (const gchar *pattern, const gchar *flags,
strict_flags = TRUE;
start = pattern;
end = pattern + strlen (pattern);
+ flags_str = flags;
}
regexp_flags |= PCRE_UTF8 ;
- if (flags != NULL) {
- flags_str = flags;
+ if (flags_str != NULL) {
while (*flags_str) {
switch (*flags_str) {
case 'i':
@@ -366,7 +366,7 @@ rspamd_regexp_search (rspamd_regexp_t *re, const gchar *text, gsize len,
*start = mt + ovec[0];
}
if (end) {
- *end = mt + ovec[0] + ovec[1];
+ *end = mt + ovec[1];
}
if (re->flags & RSPAMD_REGEXP_FLAG_FULL_MATCH) {