--- parser3/src/main/pa_string.C 2001/08/06 16:18:26 1.98 +++ parser3/src/main/pa_string.C 2001/08/10 08:10:13 1.100 @@ -5,7 +5,7 @@ Author: Alexander Petrosyan (http://design.ru/paf) */ -static const char *RCSId="$Id: pa_string.C,v 1.98 2001/08/06 16:18:26 parser Exp $"; +static const char *RCSId="$Id: pa_string.C,v 1.100 2001/08/10 08:10:13 parser Exp $"; #include "pa_config_includes.h" @@ -527,7 +527,7 @@ bool String::match(const unsigned char * int info_substrings=pcre_info(code, 0, 0); if(info_substrings<0) { - (*pcre_free)(code); + pcre_free(code); THROW(0, 0, aorigin, "pcre_info error (%d)", @@ -561,13 +561,13 @@ bool String::match(const unsigned char * exec_option_bits, ovector, ovecsize); if(exec_substrings==PCRE_ERROR_NOMATCH) { - (*pcre_free)(code); - (*row_action)(**table, 0/*last time, no row*/, 0, 0, info); + pcre_free(code); + row_action(**table, 0/*last time, no row*/, 0, 0, info); return option_bits[1]!=0; // global=true+table, not global=false } if(exec_substrings<0) { - (*pcre_free)(code); + pcre_free(code); THROW(0, 0, aorigin, "regular expression execute error (%d)", @@ -584,13 +584,14 @@ bool String::match(const unsigned char * row+=&mid(ovector[i*2+0], ovector[i*2+1]); // .i column value } - (*row_action)(**table, &row, startoffset, ovector[0], info); + row_action(**table, &row, startoffset, ovector[0], info); - if(!option_bits[1] || !(startoffset=ovector[1])) { // not global | going to hang - (*pcre_free)(code); - (*row_action)(**table, 0/*last time, no row*/, 0, 0, info); + if(!option_bits[1] || startoffset==ovector[1]) { // not global | going to hang + pcre_free(code); + row_action(**table, 0/*last time, no row*/, 0, 0, info); return true; } + startoffset=ovector[1]; /* if(option_bits[0] & PCRE_MULTILINE) @@ -657,10 +658,13 @@ double String::as_double() const { const char *cstr=this->cstr(); char *error_pos=0; // 0xABC - if(cstr[0]=='0' && (cstr[1]=='x' || cstr[1]=='X')) - result=(double)(unsigned long)strtol(cstr, &error_pos, 0); + if(cstr[0]=='0') + if(cstr[1]=='x' || cstr[1]=='X') + result=(double)(unsigned long)strtol(cstr, &error_pos, 0); + else + result=(double)strtod(/*skip leading 0*/++cstr, &error_pos); else - result=strtod(cstr, &error_pos); + result=(double)strtod(cstr, &error_pos); if(error_pos && *error_pos) THROW(0, 0, @@ -674,8 +678,11 @@ int String::as_int() const { const char *cstr=this->cstr(); char *error_pos=0; // 0xABC - if(cstr[0]=='0' && (cstr[1]=='x' || cstr[1]=='X')) - result=(int)(unsigned long)strtol(cstr, &error_pos, 0); + if(cstr[0]=='0') + if(cstr[1]=='x' || cstr[1]=='X') + result=(int)(unsigned long)strtol(cstr, &error_pos, 0); + else + result=(int)strtol(/*skip leading 0*/++cstr, &error_pos, 0); else result=(int)strtol(cstr, &error_pos, 0);