/* Generated by re2c */ #line 1 "unicode_group_Cc.x--encoding-policy(ignore).re" #include #include "utf16.h" #define YYCTYPE unsigned short bool scan(const YYCTYPE * start, const YYCTYPE * const limit) { __attribute__((unused)) const YYCTYPE * YYMARKER; // silence compiler warnings when YYMARKER is not used # define YYCURSOR start Cc: #line 13 "unicode_group_Cc.x--encoding-policy(ignore).c" { YYCTYPE yych; yych = *YYCURSOR; if (yych <= 0x001F) goto yy2; if (yych <= '~') goto yy4; if (yych >= 0x00A0) goto yy4; yy2: ++YYCURSOR; #line 12 "unicode_group_Cc.x--encoding-policy(ignore).re" { goto Cc; } #line 24 "unicode_group_Cc.x--encoding-policy(ignore).c" yy4: ++YYCURSOR; #line 13 "unicode_group_Cc.x--encoding-policy(ignore).re" { return YYCURSOR == limit; } #line 29 "unicode_group_Cc.x--encoding-policy(ignore).c" } #line 14 "unicode_group_Cc.x--encoding-policy(ignore).re" } static const unsigned int chars_Cc [] = {0x0,0x1f, 0x7f,0x9f, 0x20,0x20}; static unsigned int encode_utf16 (const unsigned int * ranges, unsigned int ranges_count, unsigned short * s) { unsigned short * const s_start = s; for (unsigned int i = 0; i < ranges_count; i += 2) for (unsigned int j = ranges[i]; j <= ranges[i + 1]; ++j) { if (j <= re2c::utf16::MAX_1WORD_RUNE) *s++ = j; else { *s++ = re2c::utf16::lead_surr(j); *s++ = re2c::utf16::trail_surr(j); } } return s - s_start; } int main () { YYCTYPE * buffer_Cc = new YYCTYPE [132]; unsigned int buffer_len = encode_utf16 (chars_Cc, sizeof (chars_Cc) / sizeof (unsigned int), buffer_Cc); if (!scan (reinterpret_cast (buffer_Cc), reinterpret_cast (buffer_Cc + buffer_len))) printf("test 'Cc' failed\n"); delete [] buffer_Cc; return 0; }