X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/374ca955a76ecab1204ca8bfa63ff9238d998416..ef6cf650f4a75c3f97de06b51fa104f2069b9ea2:/icuSources/common/unifilt.cpp diff --git a/icuSources/common/unifilt.cpp b/icuSources/common/unifilt.cpp index 69ac3070..5e1a131f 100644 --- a/icuSources/common/unifilt.cpp +++ b/icuSources/common/unifilt.cpp @@ -1,6 +1,6 @@ /* ********************************************************************** -* Copyright (c) 2001-2004, International Business Machines +* Copyright (c) 2001-2012, International Business Machines * Corporation and others. All Rights Reserved. ********************************************************************** * Date Name Description @@ -10,6 +10,7 @@ #include "unicode/unifilt.h" #include "unicode/rep.h" +#include "unicode/utf16.h" U_NAMESPACE_BEGIN UOBJECT_DEFINE_ABSTRACT_RTTI_IMPLEMENTATION(UnicodeFilter) @@ -22,11 +23,11 @@ UnicodeMatcher::~UnicodeMatcher() {} UnicodeFilter::~UnicodeFilter() {} /** - * UnicodeFunctor API. Cast 'this' to a UnicodeMatcher* pointer - * and return the pointer. + * UnicodeFunctor API. + * Note that UnicodeMatcher is a base class of UnicodeFilter. */ UnicodeMatcher* UnicodeFilter::toMatcher() const { - return (UnicodeMatcher*) this; + return const_cast(this); } void UnicodeFilter::setData(const TransliterationRuleData*) {} @@ -43,7 +44,7 @@ UMatchDegree UnicodeFilter::matches(const Replaceable& text, UChar32 c; if (offset < limit && contains(c = text.char32At(offset))) { - offset += UTF_CHAR_LENGTH(c); + offset += U16_LENGTH(c); return U_MATCH; } if (offset > limit && @@ -53,7 +54,7 @@ UMatchDegree UnicodeFilter::matches(const Replaceable& text, // the lead surrogate). --offset; if (offset >= 0) { - offset -= UTF_CHAR_LENGTH(text.char32At(offset)) - 1; + offset -= U16_LENGTH(text.char32At(offset)) - 1; } return U_MATCH; }