--- parser3/src/main/pa_string.C 2024/11/10 20:46:08 1.280 +++ parser3/src/main/pa_string.C 2025/05/26 00:52:15 1.283 @@ -12,7 +12,7 @@ #include "pa_charset.h" #include "pa_vregex.h" -volatile const char * IDENT_PA_STRING_C="$Id: pa_string.C,v 1.280 2024/11/10 20:46:08 moko Exp $" IDENT_PA_STRING_H; +volatile const char * IDENT_PA_STRING_C="$Id: pa_string.C,v 1.283 2025/05/26 00:52:15 moko Exp $" IDENT_PA_STRING_H; const String String::Empty; @@ -233,7 +233,7 @@ public: *this+=new String("match"); *this+=new String("postmatch"); for(int i=0; i=start', that's(<) impossible - return 0; // all chars are empty, just return empty string + return String::Body(); // all chars are empty, just return empty string } else - break; + break; CORD_prev(pos); } @@ -321,7 +330,7 @@ String::Body String::Body::trim(String:: if(found){ start+=char_length; if(start==our_length) - return 0; // all chars are empty, just return empty string + return String::Body(); // all chars are empty, just return empty string } else break; } @@ -345,7 +354,7 @@ String::Body String::Body::trim(String:: if(found){ end-=char_length; if(end==0) - return 0; // all chars are empty, just return empty string + return String::Body(); // all chars are empty, just return empty string } else break; } @@ -622,7 +631,7 @@ void String::split(ArrayString& result, if(size_t delim_length=strlen(delim)) { size_t pos_before; // while we have 'delim'... - while((pos_before=pos(delim, pos_after, lang))!=STRING_NOT_FOUND) { + while((pos_before=pos(String::Body(delim), pos_after, lang)) != STRING_NOT_FOUND) { result+=&mid(pos_after, pos_before); pos_after=pos_before+delim_length; } @@ -768,7 +777,7 @@ String& String::change_case(Charset& sou } } result.langs=langs; - result.body=new_cstr; + result.body=String::Body(new_cstr); return result; }