21 return ConsumeConsonantHeadIfValid() && ConsumeConsonantTailIfValid();
23 return ConsumeVowelIfValid();
36 tprintf(
"Invalid start of grapheme sequence:%c=0x%x\n",
63 if (off <= 0x3b || (0x58 <= off && off <= 0x5f))
96 bool ValidateIndic::ConsumeViramaIfValid(
IndicPair joiner,
bool post_matra) {
97 int num_codes =
codes_.size();
124 tprintf(
"Virama ZWJ ZWNJ in non-Sinhala: base=0x%x!\n",
150 tprintf(
"Invalid pre-virama joiner with no 2nd consonant!!\n");
168 bool ValidateIndic::ConsumeConsonantHeadIfValid() {
169 const int num_codes =
codes_.size();
174 int index =
output_.size() - 3;
180 bool have_nukta =
false;
187 index =
output_.size() - 2 - have_nukta;
207 output_.push_back(joiner.second);
210 tprintf(
"Skipping unnecessary joiner: 0x%x 0x%x 0x%x\n",
218 if (!ConsumeViramaIfValid(joiner,
false))
return false;
230 bool ValidateIndic::ConsumeConsonantTailIfValid() {
260 bool ValidateIndic::ConsumeVowelIfValid() {
std::pair< CharClass, char32 > IndicPair
bool ConsumeGraphemeIfValid() override
Validator::CharClass UnicodeToCharClass(char32 ch) const override
std::vector< IndicPair > codes_
static bool IsVedicAccent(char32 unicode)
static const int kIndicCodePageSize
bool IsSubscriptScript() const
void MultiCodePart(int length)
static bool IsVirama(char32 unicode)
std::vector< char32 > output_
bool UseMultiCode(int length)
static const char32 kZeroWidthJoiner
static const char32 kZeroWidthNonJoiner