mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 18:22:59 +02:00 
			
		
		
		
	fixed GH# 254
This commit is contained in:
		| @@ -1,7 +1,7 @@ | |||||||
| // | // | ||||||
| // UTF8String.cpp | // UTF8String.cpp | ||||||
| // | // | ||||||
| // $Id: //poco/1.4/Foundation/src/UTF8String.cpp#1 $ | // $Id: //poco/1.4/Foundation/src/UTF8String.cpp#2 $ | ||||||
| // | // | ||||||
| // Library: Foundation | // Library: Foundation | ||||||
| // Package: Text | // Package: Text | ||||||
| @@ -125,26 +125,8 @@ int UTF8::icompare(const std::string& str1, std::string::size_type pos1, std::st | |||||||
| int UTF8::icompare(const std::string& str, std::string::size_type pos, std::string::size_type n, const std::string::value_type* ptr) | int UTF8::icompare(const std::string& str, std::string::size_type pos, std::string::size_type n, const std::string::value_type* ptr) | ||||||
| { | { | ||||||
| 	poco_check_ptr (ptr); | 	poco_check_ptr (ptr); | ||||||
| 	std::string::size_type sz = str.size(); | 	std::string str2(ptr); // TODO: optimize | ||||||
| 	if (pos > sz) pos = sz; | 	return icompare(str, pos, n, str2.begin(), str2.end()); | ||||||
| 	if (pos + n > sz) n = sz - pos; |  | ||||||
| 	TextIterator uit(str.begin() + pos, str.begin() + pos + n, utf8);  |  | ||||||
| 	TextIterator uend(str.begin() + pos + n); |  | ||||||
| 	while (uit != uend && *ptr) |  | ||||||
| 	{ |  | ||||||
| 		int c1 = Unicode::toLower(*uit); |  | ||||||
| 		int c2 = Unicode::toLower(*ptr); |  | ||||||
| 		if (c1 < c2) |  | ||||||
| 			return -1; |  | ||||||
| 		else if (c1 > c2) |  | ||||||
| 			return 1; |  | ||||||
| 		++uit; ++ptr; |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	if (uit == uend) |  | ||||||
| 		return *ptr == 0 ? 0 : -1; |  | ||||||
| 	else |  | ||||||
| 		return 1; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Guenter Obiltschnig
					Guenter Obiltschnig