Commit 2d5c0986 authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander.Trofimov

detect languages

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@56001 954022d7-b5bf-4e40-9824-e11837661b57
parent 31266398
...@@ -1328,3 +1328,1115 @@ var g_fonts_streams = []; ...@@ -1328,3 +1328,1115 @@ var g_fonts_streams = [];
// выигрыш будет. Не особо то шрифты жмутся lzw или deflate // выигрыш будет. Не особо то шрифты жмутся lzw или deflate
// поэтому лучше из памяти будем удалять base64 строки // поэтому лучше из памяти будем удалять base64 строки
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// класс для подбора шрифтов
function CFontSelect()
{
this.m_wsFontName = "";
this.m_wsFontPath = "";
this.m_lIndex = 0;
this.m_bBold = false;
this.m_bItalic = false;
this.m_bIsFixed = false;
this.m_aPanose = null;
if (typeof(Int8Array) != 'undefined' && !window.opera)
{
this.m_aPanose = new Int8Array(10);
}
else
{
this.m_aPanose = new Array(10);
}
this.m_ulUnicodeRange1 = 0;
this.m_ulUnicodeRange2 = 0;
this.m_ulUnicodeRange3 = 0;
this.m_ulUnicodeRange4 = 0;
this.m_ulCodePageRange1 = 0;
this.m_ulCodePageRange2 = 0;
this.m_usWeigth = 0;
this.m_usWidth = 0;
this.m_sFamilyClass = 0;
this.m_eFontFormat = 0;
this.m_shAvgCharWidth = 0;
this.m_shAscent = 0;
this.m_shDescent = 0;
this.m_shLineGap = 0;
this.m_shXHeight = 0;
this.m_shCapHeight = 0;
}
CFontSelect.prototype =
{
fromStream : function(fs)
{
// name
var _len = fs.GetLong();
this.m_wsFontName = fs.GetString(_len >> 1);
_len = fs.GetLong();
this.m_wsFontPath = fs.GetString(_len >> 1);
if (1 < this.m_wsFontPath.length)
this.m_wsFontPath = this.m_wsFontPath.substring(1);
this.m_lIndex = fs.GetLong();
this.m_bItalic = (1 == fs.GetLong());
this.m_bBold = (1 == fs.GetLong());
this.m_bIsFixed = (1 == fs.GetLong());
var _panose_len = fs.GetLong(); // 10
for (var i = 0; i < _panose_len; i++)
this.m_aPanose[i] = fs.GetUChar();
this.m_ulUnicodeRange1 = fs.GetULong();
this.m_ulUnicodeRange2 = fs.GetULong();
this.m_ulUnicodeRange3 = fs.GetULong();
this.m_ulUnicodeRange4 = fs.GetULong();
this.m_ulCodePageRange1 = fs.GetULong();
this.m_ulCodePageRange2 = fs.GetULong();
this.m_usWeigth = fs.GetUShort();
this.m_usWidth = fs.GetUShort();
this.m_sFamilyClass = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_eFontFormat = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shAvgCharWidth = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shAscent = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shDescent = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shLineGap = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shXHeight = FT_Common.UShort_To_Short(fs.GetUShort());
this.m_shCapHeight = FT_Common.UShort_To_Short(fs.GetUShort());
}
};
function CLanguageFontSelect()
{
this.Type = 0;
this.Ranges = [];
this.CodePage1Mask = 0;
this.CodePage2Mask = 0;
this.DefaultFont = "Arial";
}
var LanguagesFontSelectTypes =
{
Arabic : 1,
Japan : 2,
Korean : 3,
Chinese : 4
};
function CFontSelectList()
{
this.List = new Array();
this.Languages = [];
this.m_pRanges = null;
this.m_pRangesNums = null;
}
function memset(p, start, val, count)
{
var _data = p.data;
for (var i = 0; i < count; i++)
_data[i + start] = val;
}
CFontSelectList.prototype =
{
fromStream : function()
{
// read from stream
var _ft_stream = CreateFontData2(window["g_fonts_selection_bin"]);
var _file_stream = new FileStream(_ft_stream.data, _ft_stream.size);
var count = _file_stream.GetLong();
for (var i = 0; i < count; i++)
{
var _fs = new CFontSelect();
_fs.fromStream(_file_stream);
this.List.push(_fs);
}
// add languages
// 1) arabic
var _arabic_lang = new CLanguageFontSelect();
_arabic_lang.Type = LanguagesFontSelectTypes.Arabic;
_arabic_lang.Ranges.push(0x0600);
_arabic_lang.Ranges.push(0x06FF);
_arabic_lang.Ranges.push(0x0750);
_arabic_lang.Ranges.push(0x077F);
_arabic_lang.Ranges.push(0x08A0);
_arabic_lang.Ranges.push(0x08FF);
_arabic_lang.Ranges.push(0xFB50);
_arabic_lang.Ranges.push(0xFDFF);
_arabic_lang.Ranges.push(0xFE70);
_arabic_lang.Ranges.push(0xFEFF);
_arabic_lang.CodePage1Mask = (1 << 6);
_arabic_lang.CodePage2Mask = (1 << 19) | (1 << 29);
_arabic_lang.DefaultFont = "Tahoma";
// 2) japan
var _japan_lang = new CLanguageFontSelect();
_japan_lang.Type = LanguagesFontSelectTypes.Japan;
_japan_lang.Ranges.push(0x4E00);
_japan_lang.Ranges.push(0x9FBF);
_japan_lang.Ranges.push(0x3040);// Hiragana
_japan_lang.Ranges.push(0x309F);
_japan_lang.Ranges.push(0x30A0);// Katakana
_japan_lang.Ranges.push(0x30FF);
_japan_lang.CodePage1Mask = (1 << 17) | (1 << 30);
_japan_lang.CodePage2Mask = 0;
_japan_lang.DefaultFont = "MS Mincho";
// 3) chinese http://stackoverflow.com/questions/1366068/whats-the-complete-range-for-chinese-characters-in-unicode
var _chinese_lang = new CLanguageFontSelect();
_chinese_lang.Type = LanguagesFontSelectTypes.Chinese;
_chinese_lang.Ranges.push(0x4E00);
_chinese_lang.Ranges.push(0x9FFF);
_chinese_lang.Ranges.push(0x3400);
_chinese_lang.Ranges.push(0x4DFF);
_chinese_lang.Ranges.push(0x20000);
_chinese_lang.Ranges.push(0x2A6DF);
_chinese_lang.Ranges.push(0xF900);
_chinese_lang.Ranges.push(0xFAFF);
_chinese_lang.Ranges.push(0x2F800);
_chinese_lang.Ranges.push(0x2FA1F);
_chinese_lang.CodePage1Mask = (1 << 18) | (1 << 20);
_chinese_lang.CodePage2Mask = 0;
_chinese_lang.DefaultFont = "SimSun";
// 4) korean
var _korean_lang = new CLanguageFontSelect();
_korean_lang.Type = LanguagesFontSelectTypes.Korean;
_korean_lang.Ranges.push(0x1100);
_korean_lang.Ranges.push(0x11FF);
_korean_lang.Ranges.push(0x3130);
_korean_lang.Ranges.push(0x318F);
_korean_lang.Ranges.push(0xAC00);
_korean_lang.Ranges.push(0xD7AF);
_korean_lang.CodePage1Mask = (1 << 19);
_korean_lang.CodePage2Mask = 0;
_korean_lang.DefaultFont = "Batang";
// test
var _array_results = [];
var _count_fonts = this.List.length;
for (var i = 0; i < _count_fonts; i++)
{
var f = this.List[i];
console.log(f.m_wsFontPath + "_" + f.m_lIndex + " codepage1: " + f.m_ulCodePageRange1 + ", codepage2: " + f.m_ulCodePageRange2);
}
},
checkText : function(text)
{
var r1 = 0;
var r2 = 0;
var r3 = 0;
var r4 = 0;
var codePage1 = 0;
var codePage2 = 0;
var len = text.length;
for (var i = 0; i < len; i++)
{
var _code = text.charCodeAt(i);
var lRangeNum = this.m_pRangesNums.data[_code];
var lRange = this.m_pRanges.data[_code];
if (0xFF != lRangeNum)
{
if ((i == 0) && ((lRangeNum == 1) && (lRange == 28)))
{
codePage1 = 0x80000000;
}
else if (((lRangeNum == 2) && (lRange == 3)) || ((lRangeNum == 1) && (lRange == 31)) || ((lRangeNum == 0) && (lRange == 13)))
{
// arabic!
r1 |= (1 << 13);
r2 |= (1 << 31);
r3 |= (1 << 3);
}
else
{
if (0 == lRangeNum)
r1 |= 1 << lRange;
else if (1 == lRangeNum)
r2 |= 1 << lRange;
else if (2 == lRangeNum)
r3 |= 1 << lRange;
else
r4 |= 1 << lRange;
}
}
}
var _array_results = [];
var _count_fonts = this.List.length;
for (var i = 0; i < _count_fonts; i++)
{
var f = this.List[i];
if (((f.m_ulUnicodeRange1 & r1) == r1) &&
((f.m_ulUnicodeRange2 & r2) == r2) &&
((f.m_ulUnicodeRange3 & r3) == r3) &&
((f.m_ulUnicodeRange4 & r4) == r4) &&
((f.m_ulCodePageRange1 & codePage1) == codePage1) &&
((f.m_ulCodePageRange2 & codePage2) == codePage2))
{
_array_results.push(f.m_wsFontPath);
}
}
console.log(_array_results);
},
initRanges : function()
{
// пока не используем
/*
// пока только 2 байта
this.m_pRanges = g_memory.Alloc(0xFFFF);
this.m_pRangesNums = g_memory.Alloc(0xFFFF);
memset(this.m_pRanges, 0, 0xFF, 0xFFFF);
memset(this.m_pRangesNums, 0, 0xFF, 0xFFFF);
// теперь просто по порядку заполняем все рэнджи
var nStart = 0;
var nCount = 0;
// rangeNum 0
// case 00: sUCRName = "Basic Latin"; break; /: U+0020-U+007E :/
nStart = 0x0020;
nCount = 0x007E - nStart + 1;
memset(this.m_pRanges, nStart, 0, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 01: sUCRName = "Latin-1 Supplement"; break; /: U+0080-U+00FF :/
nStart = 0x0080;
nCount = 0x00FF - nStart + 1;
memset(this.m_pRanges, nStart, 1, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 02: sUCRName = "Latin Extended-A"; break; /: U+0100-U+017F :/
nStart = 0x0100;
nCount = 0x017F - nStart + 1;
memset(this.m_pRanges, nStart, 2, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 03: sUCRName = "Latin Extended-B"; break; /: U+0180-U+024F :/
nStart = 0x0180;
nCount = 0x024F - nStart + 1;
memset(this.m_pRanges, nStart, 3, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 04: sUCRName = "IPA Extensions"; break; /: U+0250-U+02AF :/ /: U+1D00-U+1D7F :/ /: U+1D80-U+1DBF :/
nStart = 0x0250;
nCount = 0x02AF - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x1D00;
nCount = 0x1D7F - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x1D80;
nCount = 0x1DBF - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 05: sUCRName = "Spacing Modifier Letters"; break; /: U+02B0-U+02FF :/ /: U+A700-U+A71F :/
nStart = 0x02B0;
nCount = 0x02FF - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0xA700;
nCount = 0xA71F - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 06: sUCRName = "Combining Diacritical Marks"; break; /: U+0300-U+036F :/ /: U+1DC0-U+1DFF :/
nStart = 0x0300;
nCount = 0x036F - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x1DC0;
nCount = 0x1DFF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 07: sUCRName = "Greek and Coptic"; break; /: U+0370-U+03FF :/
nStart = 0x0370;
nCount = 0x03FF - nStart + 1;
memset(this.m_pRanges, nStart, 7, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 08: sUCRName = "Coptic"; break; /: U+2C80-U+2CFF :/
nStart = 0x2C80;
nCount = 0x2CFF - nStart + 1;
memset(this.m_pRanges, nStart, 8, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 09: sUCRName = "Cyrillic"; break; /: U+0400-U+04FF :/ /: U+0500-U+052F :/ /: U+2DE0-U+2DFF :/ /: U+A640-U+A69F :/
nStart = 0x0400;
nCount = 0x04FF - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x0500;
nCount = 0x052F - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x2DE0;
nCount = 0x2DFF - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0xA640;
nCount = 0xA69F - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 10: sUCRName = "Armenian"; break; /: U+0530-U+058F :/
nStart = 0x0530;
nCount = 0x058F - nStart + 1;
memset(this.m_pRanges, nStart, 10, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 11: sUCRName = "Hebrew"; break; /: U+0590-U+05FF :/
nStart = 0x0590;
nCount = 0x05FF - nStart + 1;
memset(this.m_pRanges, nStart, 11, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 12: sUCRName = "Vai"; break; /: U+A500-U+A63F :/
nStart = 0xA500;
nCount = 0xA63F - nStart + 1;
memset(this.m_pRanges, nStart, 12, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 13: sUCRName = "Arabic"; break; /: U+0600-U+06FF :/ /: U+0750-U+077F :/
nStart = 0x0600;
nCount = 0x06FF - nStart + 1;
memset(this.m_pRanges, nStart, 13, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x0750;
nCount = 0x077F - nStart + 1;
memset(this.m_pRanges, nStart, 13, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 14: sUCRName = "NKo"; break; /: U+07C0-U+07FF :/
nStart = 0x07C0;
nCount = 0x07FF - nStart + 1;
memset(this.m_pRanges, nStart, 14, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 15: sUCRName = "Devanagari"; break; /: U+0900-U+097F :/
nStart = 0x0900;
nCount = 0x097F - nStart + 1;
memset(this.m_pRanges, nStart, 15, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 16: sUCRName = "Bengali"; break; /: U+0980-U+09FF :/
nStart = 0x0980;
nCount = 0x09FF - nStart + 1;
memset(this.m_pRanges, nStart, 16, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 17: sUCRName = "Gurmukhi"; break; /: U+0A00-U+0A7F :/
nStart = 0x0A00;
nCount = 0x0A7F - nStart + 1;
memset(this.m_pRanges, nStart, 17, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 18: sUCRName = "Gujarati"; break; /: U+0A80-U+0AFF :/
nStart = 0x0A80;
nCount = 0x0AFF - nStart + 1;
memset(this.m_pRanges, nStart, 18, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 19: sUCRName = "Oriya"; break; /: U+0B00-U+0B7F :/
nStart = 0x0B00;
nCount = 0x0B7F - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 20: sUCRName = "Tamil"; break; /: U+0B80-U+0BFF :/
nStart = 0x0B80;
nCount = 0x0BFF - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 21: sUCRName = "Telugu"; break; /: U+0C00-U+0C7F :/
nStart = 0x0C00;
nCount = 0x0C7F - nStart + 1;
memset(this.m_pRanges, nStart, 21, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 22: sUCRName = "Kannada"; break; /: U+0C80-U+0CFF :/
nStart = 0x0C80;
nCount = 0x0CFF - nStart + 1;
memset(this.m_pRanges, nStart, 22, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 23: sUCRName = "Malayalam"; break; /: U+0D00-U+0D7F :/
nStart = 0x0D00;
nCount = 0x0D7F - nStart + 1;
memset(this.m_pRanges, nStart, 23, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 24: sUCRName = "Thai"; break; /: U+0E00-U+0E7F :/
nStart = 0x0E00;
nCount = 0x0E7F - nStart + 1;
memset(this.m_pRanges, nStart, 24, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 25: sUCRName = "Lao"; break; /: U+0E80-U+0EFF :/
nStart = 0x0E80;
nCount = 0x0EFF - nStart + 1;
memset(this.m_pRanges, nStart, 25, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 26: sUCRName = "Georgian"; break; /: U+10A0-U+10FF :/ /: U+2D00-U+2D2F :/
nStart = 0x10A0;
nCount = 0x10FF - nStart + 1;
memset(this.m_pRanges, nStart, 26, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x2D00;
nCount = 0x2D2F - nStart + 1;
memset(this.m_pRanges, nStart, 26, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 27: sUCRName = "Balinese"; break; /: U+1B00-U+1B7F :/
nStart = 0x1B00;
nCount = 0x1B7F - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 28: sUCRName = "Hangul Jamo"; break; /: U+1100-U+11FF :/
nStart = 0x1100;
nCount = 0x11FF - nStart + 1;
memset(this.m_pRanges, nStart, 28, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 29: sUCRName = "Latin Extended Additional"; break; /: U+1E00-U+1EFF :/ /: U+2C60-U+2C7F :/ /: U+A720-U+A7FF :/
nStart = 0x1E00;
nCount = 0x1EFF - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x2C60;
nCount = 0x2C7F - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0xA720;
nCount = 0xA7FF - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 30: sUCRName = "Greek Extended"; break; /: U+1F00-U+1FFF :/
nStart = 0x1F00;
nCount = 0x1FFF - nStart + 1;
memset(this.m_pRanges, nStart, 30, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
//case 31: sUCRName = "General Punctuation"; break; /: U+2000-U+206F :/ /: U+2E00-U+2E7F :/
nStart = 0x2000;
nCount = 0x206F - nStart + 1;
memset(this.m_pRanges, nStart, 31, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
nStart = 0x2E00;
nCount = 0x2E7F - nStart + 1;
memset(this.m_pRanges, nStart, 31, nCount);
memset(this.m_pRangesNums, nStart, 0, nCount);
// rangeNum 1
//case 00: sUCRName = "Superscripts And Subscripts"; break; /: U+2070-U+209F :/
nStart = 0x2070;
nCount = 0x209F - nStart + 1;
memset(this.m_pRanges, nStart, 0, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 01: sUCRName = "Currency Symbols"; break; /: U+20A0-U+20CF :/
nStart = 0x20A0;
nCount = 0x20CF - nStart + 1;
memset(this.m_pRanges, nStart, 1, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 02: sUCRName = "Combining Diacritical Marks For Symbols"; break; /: U+20D0-U+20FF :/
nStart = 0x20D0;
nCount = 0x20FF - nStart + 1;
memset(this.m_pRanges, nStart, 2, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 03: sUCRName = "Letterlike Symbols"; break; /: U+2100-U+214F :/
nStart = 0x2100;
nCount = 0x214F - nStart + 1;
memset(this.m_pRanges, nStart, 3, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 04: sUCRName = "Number Forms"; break; /: U+2150-U+218F :/
nStart = 0x2150;
nCount = 0x218F - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 05: sUCRName = "Arrows"; break; /: U+2190-U+21FF :/ /: U+27F0-U+27FF :/ /: U+2900-U+297F :/ /: U+2B00-U+2BFF :/
nStart = 0x2190;
nCount = 0x21FF - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x27F0;
nCount = 0x27FF - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2900;
nCount = 0x297F - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2B00;
nCount = 0x2BFF - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 06: sUCRName = "Mathematical Operators"; break; /: U+2200-U+22FF :/ /: U+2A00-U+2AFF :/ /: U+27C0-U+27EF :/ /: U+2980-U+29FF :/
nStart = 0x2200;
nCount = 0x22FF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2A00;
nCount = 0x2AFF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x27C0;
nCount = 0x27EF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2980;
nCount = 0x29FF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 07: sUCRName = "Miscellaneous Technical"; break; /: U+2300-U+23FF :/
nStart = 0x2300;
nCount = 0x23FF - nStart + 1;
memset(this.m_pRanges, nStart, 7, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 08: sUCRName = "Control Pictures"; break; /: U+2400-U+243F :/
nStart = 0x2400;
nCount = 0x243F - nStart + 1;
memset(this.m_pRanges, nStart, 8, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 09: sUCRName = "Optical Character Recognition"; break; /: U+2440-U+245F :/
nStart = 0x2440;
nCount = 0x245F - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 10: sUCRName = "Enclosed Alphanumerics"; break; /: U+2460-U+24FF :/
nStart = 0x2460;
nCount = 0x24FF - nStart + 1;
memset(this.m_pRanges, nStart, 10, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 11: sUCRName = "Box Drawing"; break; /: U+2500-U+257F :/
nStart = 0x2500;
nCount = 0x257F - nStart + 1;
memset(this.m_pRanges, nStart, 11, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 12: sUCRName = "Block Elements"; break; /: U+2580-U+259F :/
nStart = 0x2580;
nCount = 0x259F - nStart + 1;
memset(this.m_pRanges, nStart, 12, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 13: sUCRName = "Geometric Shapes"; break; /: U+25A0-U+25FF :/
nStart = 0x25A0;
nCount = 0x25FF - nStart + 1;
memset(this.m_pRanges, nStart, 13, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 14: sUCRName = "Miscellaneous Symbols"; break; /: U+2600-U+26FF :/
nStart = 0x2600;
nCount = 0x26FF - nStart + 1;
memset(this.m_pRanges, nStart, 14, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 15: sUCRName = "Dingbats"; break; /: U+2700-U+27BF :/
nStart = 0x2700;
nCount = 0x27BF - nStart + 1;
memset(this.m_pRanges, nStart, 15, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 16: sUCRName = "CJK Symbols and Punctuation"; break; /: U+3000-U+303F :/
nStart = 0x3000;
nCount = 0x303F - nStart + 1;
memset(this.m_pRanges, nStart, 16, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 17: sUCRName = "Hiragana"; break; /: U+3040-U+309F :/
nStart = 0x3040;
nCount = 0x309F - nStart + 1;
memset(this.m_pRanges, nStart, 17, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 18: sUCRName = "Katakana"; break; /: U+30A0-U+30FF :/ /: U+31F0-U+31FF :/
nStart = 0x30A0;
nCount = 0x30FF - nStart + 1;
memset(this.m_pRanges, nStart, 18, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x31F0;
nCount = 0x31FF - nStart + 1;
memset(this.m_pRanges, nStart, 18, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 19: sUCRName = "Bopomofo"; break; /: U+3100-U+312F :/ /: U+31A0-U+31BF :/
nStart = 0x3100;
nCount = 0x312F - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x31A0;
nCount = 0x31BF - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 20: sUCRName = "Hangul Compatibility Jamo"; break; /: U+3130-U+318F :/
nStart = 0x3130;
nCount = 0x318F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 21: sUCRName = "Phags-pa"; break; /: U+A840-U+A87F :/
nStart = 0xA840;
nCount = 0xA87F - nStart + 1;
memset(this.m_pRanges, nStart, 21, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 22: sUCRName = "Enclosed CJK Letters and Months"; break; /: U+3200-U+32FF :/
nStart = 0x3200;
nCount = 0x32FF - nStart + 1;
memset(this.m_pRanges, nStart, 22, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 23: sUCRName = "CJK Compatibility"; break; /: U+3300-U+33FF :/
nStart = 0x3300;
nCount = 0x33FF - nStart + 1;
memset(this.m_pRanges, nStart, 23, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 24: sUCRName = "Hangul Syllables"; break; /: U+AC00-U+D7AF :/
nStart = 0xAC00;
nCount = 0xD7AF - nStart + 1;
memset(this.m_pRanges, nStart, 24, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 25: sUCRName = "Non-Plane 0"; break; /: U+D800-U+DB7F :/ /: U+DB80-U+DBFF :/ /: U+DC00-U+DFFF :/ // Не юникодные символы
nStart = 0xD800;
nCount = 0xDB7F - nStart + 1;
memset(this.m_pRanges, nStart, 25, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0xDB80;
nCount = 0xDBFF - nStart + 1;
memset(this.m_pRanges, nStart, 25, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0xDC00;
nCount = 0xDFFF - nStart + 1;
memset(this.m_pRanges, nStart, 25, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 26: sUCRName = "Phoenician"; break; /:U+10900-U+1091F:/
//case 27: sUCRName = "CJK Unified Ideographs"; break; /: U+4E00-U+9FFF :/ /: U+2E80-U+2EFF :/ /: U+2F00-U+2FDF :/ /: U+2FF0-U+2FFF :/ /: U+3400-U+4DB5 :/ /:U+20000-U+2A6D6:/ /: U+3190-U+319F :/
nStart = 0x4E00;
nCount = 0x9FFF - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2E80;
nCount = 0x2EFF - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2F00;
nCount = 0x2FDF - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x2FF0;
nCount = 0x2FFF - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x3400;
nCount = 0x4DB5 - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0x3190;
nCount = 0x319F - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 28: sUCRName = "Private Use Area (plane 0)"; break; /: U+E000-U+F8FF :/ // Не юникодные символы
nStart = 0xE000;
nCount = 0xF8FF - nStart + 1;
memset(this.m_pRanges, nStart, 28, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 29: sUCRName = "CJK Strokes"; break; /: U+31C0-U+31EF :/ /: U+F900-U+FAFF :/ /:U+2F800-U+2FA1F:/
nStart = 0x31C0;
nCount = 0x31EF - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
nStart = 0xF900;
nCount = 0xFAFF - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 30: sUCRName = "Alphabetic Presentation Forms"; break; /: U+FB00-U+FB4F :/
nStart = 0xFB00;
nCount = 0xFB4F - nStart + 1;
memset(this.m_pRanges, nStart, 30, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
//case 31: sUCRName = "Arabic Presentation Forms-A"; break; /: U+FB50-U+FDFF :/
nStart = 0xFB50;
nCount = 0xFDFF - nStart + 1;
memset(this.m_pRanges, nStart, 31, nCount);
memset(this.m_pRangesNums, nStart, 1, nCount);
// rangeNum 2
//case 00: sUCRName = "Combining Half Marks"; break; /: U+FE20-U+FE2F :/
nStart = 0xFE20;
nCount = 0xFE2F - nStart + 1;
memset(this.m_pRanges, nStart, 0, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 01: sUCRName = "Vertical forms"; break; /: U+FE10-U+FE1F :/ /: U+FE30-U+FE4F :/
nStart = 0xFE10;
nCount = 0xFE1F - nStart + 1;
memset(this.m_pRanges, nStart, 1, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0xFE30;
nCount = 0xFE4F - nStart + 1;
memset(this.m_pRanges, nStart, 1, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 02: sUCRName = "Small Form Variants"; break; /: U+FE50-U+FE6F :/
nStart = 0xFE50;
nCount = 0xFE6F - nStart + 1;
memset(this.m_pRanges, nStart, 2, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 03: sUCRName = "Arabic Presentation Forms-B"; break; /: U+FE70-U+FEFE :/
nStart = 0xFE70;
nCount = 0xFEFE - nStart + 1;
memset(this.m_pRanges, nStart, 3, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 04: sUCRName = "Halfwidth and Fullwidth Forms"; break; /: U+FF00-U+FFEF :/
nStart = 0xFF00;
nCount = 0xFFEF - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 05: sUCRName = "Specials"; break; /: U+FFF0-U+FFFF :/
nStart = 0xFFF0;
nCount = 0xFFFF - nStart + 1;
memset(this.m_pRanges, nStart, 5, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 06: sUCRName = "Tibetan"; break; /: U+0F00-U+0FFF :/
nStart = 0x0F00;
nCount = 0x0FFF - nStart + 1;
memset(this.m_pRanges, nStart, 6, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 07: sUCRName = "Syriac"; break; /: U+0700-U+074F :/
nStart = 0x0700;
nCount = 0x074F - nStart + 1;
memset(this.m_pRanges, nStart, 7, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 08: sUCRName = "Thaana"; break; /: U+0780-U+07BF :/
nStart = 0x0780;
nCount = 0x07BF - nStart + 1;
memset(this.m_pRanges, nStart, 8, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 09: sUCRName = "Sinhala"; break; /: U+0D80-U+0DFF :/
nStart = 0x0D80;
nCount = 0x0DFF - nStart + 1;
memset(this.m_pRanges, nStart, 9, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 10: sUCRName = "Myanmar"; break; /: U+1000-U+109F :/
nStart = 0x1000;
nCount = 0x109F - nStart + 1;
memset(this.m_pRanges, nStart, 10, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 11: sUCRName = "Ethiopic"; break; /: U+1200-U+137F :/ /: U+1380-U+139F :/ /: U+2D80-U+2DDF :/
nStart = 0x1200;
nCount = 0x137F - nStart + 1;
memset(this.m_pRanges, nStart, 11, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x1380;
nCount = 0x139F - nStart + 1;
memset(this.m_pRanges, nStart, 11, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x2D80;
nCount = 0x2DDF - nStart + 1;
memset(this.m_pRanges, nStart, 11, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 12: sUCRName = "Cherokee"; break; /: U+13A0-U+13FF :/
nStart = 0x13A0;
nCount = 0x13FF - nStart + 1;
memset(this.m_pRanges, nStart, 12, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 13: sUCRName = "Unified Canadian Aboriginal Syllabics"; break; /: U+1400-U+167F :/
nStart = 0x1400;
nCount = 0x167F - nStart + 1;
memset(this.m_pRanges, nStart, 13, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 14: sUCRName = "Ogham"; break; /: U+1680-U+169F :/
nStart = 0x1680;
nCount = 0x169F - nStart + 1;
memset(this.m_pRanges, nStart, 14, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 15: sUCRName = "Runic"; break; /: U+16A0-U+16FF :/
nStart = 0x16A0;
nCount = 0x16FF - nStart + 1;
memset(this.m_pRanges, nStart, 15, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 16: sUCRName = "Khmer"; break; /: U+1780-U+17FF :/ /: U+19E0-U+19FF :/
nStart = 0x1780;
nCount = 0x17FF - nStart + 1;
memset(this.m_pRanges, nStart, 16, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x19E0;
nCount = 0x19FF - nStart + 1;
memset(this.m_pRanges, nStart, 16, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 17: sUCRName = "Mongolian"; break; /: U+1800-U+18AF :/
nStart = 0x1800;
nCount = 0x18AF - nStart + 1;
memset(this.m_pRanges, nStart, 17, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 18: sUCRName = "Braille Patterns"; break; /: U+2800-U+28FF :/
nStart = 0x2800;
nCount = 0x28FF - nStart + 1;
memset(this.m_pRanges, nStart, 18, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 19: sUCRName = "Yi Syllables"; break; /: U+A000-U+A48F :/ /: U+A490-U+A4CF :/
nStart = 0xA000;
nCount = 0xA48F - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0xA490;
nCount = 0xA4CF - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 20: sUCRName = "Tagalog"; break; /: U+1700-U+171F :/ /: U+1720-U+173F :/ /: U+1740-U+175F :/ /: U+1760-U+177F :/
nStart = 0x1700;
nCount = 0x171F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x1720;
nCount = 0x173F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x1740;
nCount = 0x175F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
nStart = 0x1760;
nCount = 0x177F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 21: sUCRName = "Old Italic"; break; /:U+10300-U+1032F:/
//case 22: sUCRName = "Gothic"; break; /:U+10330-U+1034F:/
//case 23: sUCRName = "Deseret"; break; /:U+10400-U+1044F:/
//case 24: sUCRName = "Byzantine Musical Symbols"; break; /:U+1D000-U+1D0FF:/ /:U+1D100-U+1D1FF:/ /:U+1D200-U+1D24F:/
//case 25: sUCRName = "Mathematical Alphanumeric Symbols"; break; /:U+1D400-U+1D7FF:/
//case 26: sUCRName = "Private Use (plane 15)"; break; /:U+F0000-U+FFFFD:/ /:U+100000-U+10FFFD:/ // Не юникодные символы
//case 27: sUCRName = "Variation Selectors"; break; /: U+FE00-U+FE0F :/ /:U+E0100-U+E01EF:/
nStart = 0xFE00;
nCount = 0xFE0F - nStart + 1;
memset(this.m_pRanges, nStart, 27, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 28: sUCRName = "Tags"; break; /:U+E0000-U+E007F:/
//case 29: sUCRName = "Limbu"; break; /: U+1900-U+194F :/
nStart = 0x1900;
nCount = 0x194F - nStart + 1;
memset(this.m_pRanges, nStart, 29, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 30: sUCRName = "Tai Le"; break; /: U+1950-U+197F :/
nStart = 0x1950;
nCount = 0x197F - nStart + 1;
memset(this.m_pRanges, nStart, 30, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
//case 31: sUCRName = "New Tai Lue"; break; /: U+1980-U+19DF :/
nStart = 0x1980;
nCount = 0x19DF - nStart + 1;
memset(this.m_pRanges, nStart, 31, nCount);
memset(this.m_pRangesNums, nStart, 2, nCount);
// rangeNum 3
//case 00: sUCRName = "Buginese"; break; /: U+1A00-U+1A1F :/
nStart = 0x1A00;
nCount = 0x1A1F - nStart + 1;
memset(this.m_pRanges, nStart, 0, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 01: sUCRName = "Glagolitic"; break; /: U+2C00-U+2C5F :/
nStart = 0x2C00;
nCount = 0x2C5F - nStart + 1;
memset(this.m_pRanges, nStart, 1, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 02: sUCRName = "Tifinagh"; break; /: U+2D30-U+2D7F :/
nStart = 0x2D30;
nCount = 0x2D7F - nStart + 1;
memset(this.m_pRanges, nStart, 2, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 03: sUCRName = "Yijing Hexagram Symbols"; break; /: U+4DC0-U+4DFF :/
nStart = 0x4DC0;
nCount = 0x4DFF - nStart + 1;
memset(this.m_pRanges, nStart, 3, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 04: sUCRName = "Syloti Nagri"; break; /: U+A800-U+A82F :/
nStart = 0xA800;
nCount = 0xA82F - nStart + 1;
memset(this.m_pRanges, nStart, 4, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 05: sUCRName = "Linear B Syllabary"; break; /:U+10000-U+1007F:/ /:U+10080-U+100FF:/ /:U+10100-U+1013F:/
//case 06: sUCRName = "Ancient Greek Numbers"; break; /:U+10140-U+1018F:/
//case 07: sUCRName = "Ugaritic"; break; /:U+10380-U+1039F:/
//case 08: sUCRName = "Old Persian"; break; /:U+103A0-U+103DF:/
//case 09: sUCRName = "Shavian"; break; /:U+10450-U+1047F:/
//case 10: sUCRName = "Osmanya"; break; /:U+10480-U+104AF:/
//case 11: sUCRName = "Cypriot Syllabary"; break; /:U+10800-U+1083F:/
//case 12: sUCRName = "Kharoshthi"; break; /:U+10A00-U+10A5F:/
//case 13: sUCRName = "Tai Xuan Jing Symbols"; break; /:U+1D300-U+1D35F:/
//case 14: sUCRName = "Cuneiform"; break; /:U+12000-U+123FF:/ /:U+12400-U+1247F:/
//case 15: sUCRName = "Counting Rod Numerals"; break; /:U+1D360-U+1D37F:/
//case 16: sUCRName = "Sundanese"; break; /: U+1B80-U+1BBF :/
nStart = 0x1B80;
nCount = 0x1BBF - nStart + 1;
memset(this.m_pRanges, nStart, 16, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 17: sUCRName = "Lepcha"; break; /: U+1C00-U+1C4F :/
nStart = 0x1C00;
nCount = 0x1C4F - nStart + 1;
memset(this.m_pRanges, nStart, 17, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 18: sUCRName = "Ol Chiki"; break; /: U+1C50-U+1C7F :/
nStart = 0x1C50;
nCount = 0x1C7F - nStart + 1;
memset(this.m_pRanges, nStart, 18, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 19: sUCRName = "Saurashtra"; break; /: U+A880-U+A8DF :/
nStart = 0xA880;
nCount = 0xA8DF - nStart + 1;
memset(this.m_pRanges, nStart, 19, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 20: sUCRName = "Kayah Li"; break; /: U+A900-U+A92F :/
nStart = 0xA900;
nCount = 0xA92F - nStart + 1;
memset(this.m_pRanges, nStart, 20, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 21: sUCRName = "Rejang"; break; /: U+A930-U+A95F :/
nStart = 0xA930;
nCount = 0xA95F - nStart + 1;
memset(this.m_pRanges, nStart, 21, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 22: sUCRName = "Cham"; break; /: U+AA00-U+AA5F :/
nStart = 0xAA00;
nCount = 0xAA5F - nStart + 1;
memset(this.m_pRanges, nStart, 22, nCount);
memset(this.m_pRangesNums, nStart, 3, nCount);
//case 23: sUCRName = "Ancient Symbols"; break; /:U+10190-U+101CF:/
//case 24: sUCRName = "Phaistos Disc"; break; /:U+101D0-U+101FF:/
//case 25: sUCRName = "Carian"; break; /:U+102A0-U+102DF:/ /:U+10280-U+1029F:/ /:U+10920-U+1093F:/
//case 26: sUCRName = "Domino Tiles"; break; /:U+1F030-U+1F09F:/ /:U+1F000-U+1F02F:/
//case 27: sUCRName = "Reserved for process-internal usage"; break;
//case 28: sUCRName = "Reserved for process-internal usage"; break;
//case 29: sUCRName = "Reserved for process-internal usage"; break;
//case 30: sUCRName = "Reserved for process-internal usage"; break;
//case 31: sUCRName = "Reserved for process-internal usage"; break;
*/
}
};
var g_fontSelections = new CFontSelectList();
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment