X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=daemon%2Fsearch.c;h=7b61d42623f541a043c98d25396504ced058e599;hb=c74516fb4f73c64a0aa6eb720b3cfc5440636ba5;hp=d16e5a0118e28ee1a78a2fca0599c0bc4ffe4003;hpb=ef6a218200864a61696467517a79d47594c623b4;p=doldaconnect.git diff --git a/daemon/search.c b/daemon/search.c index d16e5a0..7b61d42 100644 --- a/daemon/search.c +++ b/daemon/search.c @@ -396,10 +396,12 @@ static struct reinfo analyzere(wchar_t *re, wchar_t **endret, wchar_t endc) if(ret.begstr != NULL) { for(i = 0; (sinf.begstr[i] != L'\0') && (ret.begstr != L'\0') && (ret.begstr[i] == sinf.begstr[i]); i++); - if(i == 0) + if(i == 0) { free(ret.begstr); - else + ret.begstr = NULL; + } else { ret.begstr[i] = L'\0'; + } } free(sinf.begstr); } else { @@ -424,10 +426,12 @@ static struct reinfo analyzere(wchar_t *re, wchar_t **endret, wchar_t endc) maxlen = len1; } for(i = 1; (i <= minlen) && (ret.endstr[len1 - i] == sinf.endstr[len2 - i]); i++); - if(i == 1) + if(i == 1) { free(ret.endstr); - else if(i <= maxlen) + ret.endstr = NULL; + } else if(i <= maxlen) { wmemmove(ret.endstr, ret.endstr + (len1 - i) + 1, i); + } } free(sinf.endstr); } else {