#include "wx/intl.h"
#endif //WX_PRECOMP
+// FreeBSD requires this, it probably doesn't hurt for others
+#ifdef __UNIX__
+ #include <sys/types.h>
+#endif
+
#include <regex.h>
#include "wx/regex.h"
{
m_isCompiled = FALSE;
m_Matches = NULL;
+ m_nMatches = 0;
}
wxRegExImpl::~wxRegExImpl()
{
len++;
+#if wxUSE_UNICODE
+ wxCharBuffer buf(len);
+
+ (void)regerror(errorcode, &m_RegEx, (char *)buf.data(), len);
+
+ msg = buf.data();
+#else // !Unicode
(void)regerror(errorcode, &m_RegEx, msg.GetWriteBuf(len), len);
msg.UngetWriteBuf();
+#endif // Unicode/!Unicode
}
else // regerror() returned 0
{
flagsRE |= REG_NEWLINE;
// compile it
- int errorcode = regcomp(&m_RegEx, expr, flagsRE);
+ int errorcode = regcomp(&m_RegEx, expr.mb_str(), flagsRE);
if ( errorcode )
{
wxLogError(_("Invalid regular expression '%s': %s"),
}
else
{
- // will alloc later
- m_nMatches = WX_REGEX_MAXMATCHES;
+ // we will alloc the array later (only if really needed) but count
+ // the number of sub-expressions in the regex right now
+
+ // there is always one for the whole expression
+ m_nMatches = 1;
+
+ // and some more for bracketed subexperessions
+ const wxChar *cptr = expr.c_str();
+ wxChar prev = _T('\0');
+ while ( *cptr != _T('\0') )
+ {
+ // is this a subexpr start, i.e. "(" for extended regex or
+ // "\(" for a basic one?
+ if ( *cptr == _T('(') &&
+ (flags & wxRE_BASIC ? prev == _T('\\')
+ : prev != _T('\\')) )
+ {
+ m_nMatches++;
+ }
+
+ prev = *cptr;
+ cptr++;
+ }
}
m_isCompiled = TRUE;
}
// do match it
- int rc = regexec(&self->m_RegEx, str, m_nMatches, m_Matches, flagsRE);
+ int rc = regexec(&self->m_RegEx, wxConvertWX2MB(str), m_nMatches, m_Matches, flagsRE);
switch ( rc )
{
wxCHECK_MSG( index < m_nMatches, FALSE, _T("invalid match index") );
const regmatch_t& match = m_Matches[index];
- if ( match.rm_so == -1 )
- return FALSE;
if ( start )
*start = match.rm_so;