mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
case-folding.rb: merge tables
* enc/unicode/case-folding.rb (print_table): merge non-locale and locale tables, and reduce initializing loops. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46268 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
1d588b4fde
commit
88eae35862
4 changed files with 30 additions and 45 deletions
|
@ -236,46 +236,30 @@ static int CaseFoldInited = 0;
|
|||
|
||||
static int init_case_fold_table(void)
|
||||
{
|
||||
const CaseFold_11_Type *p;
|
||||
const CaseUnfold_11_Type *p1;
|
||||
const CaseUnfold_12_Type *p2;
|
||||
const CaseUnfold_13_Type *p3;
|
||||
int i;
|
||||
|
||||
THREAD_ATOMIC_START;
|
||||
|
||||
FoldTable = st_init_numtable_with_size(FOLD_TABLE_SIZE);
|
||||
if (ONIG_IS_NULL(FoldTable)) return ONIGERR_MEMORY;
|
||||
for (i = 0; i < numberof(CaseFold); i++) {
|
||||
p = &CaseFold[i];
|
||||
st_add_direct(FoldTable, (st_data_t )p->from, (st_data_t )&(p->to));
|
||||
}
|
||||
for (i = 0; i < numberof(CaseFold_Locale); i++) {
|
||||
p = &CaseFold_Locale[i];
|
||||
for (i = 0; i < numberof(CaseFold_11_Table); i++) {
|
||||
const CaseFold_11_Type *p = &CaseFold_11_Table[i];
|
||||
st_add_direct(FoldTable, (st_data_t )p->from, (st_data_t )&(p->to));
|
||||
}
|
||||
|
||||
Unfold1Table = st_init_numtable_with_size(UNFOLD1_TABLE_SIZE);
|
||||
if (ONIG_IS_NULL(Unfold1Table)) return ONIGERR_MEMORY;
|
||||
|
||||
for (i = 0; i < numberof(CaseUnfold_11); i++) {
|
||||
p1 = &CaseUnfold_11[i];
|
||||
st_add_direct(Unfold1Table, (st_data_t )p1->from, (st_data_t )&(p1->to));
|
||||
}
|
||||
for (i = 0; i < numberof(CaseUnfold_11_Locale); i++) {
|
||||
p1 = &CaseUnfold_11_Locale[i];
|
||||
for (i = 0; i < numberof(CaseUnfold_11_Table); i++) {
|
||||
const CaseUnfold_11_Type *p1 = &CaseUnfold_11_Table[i];
|
||||
st_add_direct(Unfold1Table, (st_data_t )p1->from, (st_data_t )&(p1->to));
|
||||
}
|
||||
|
||||
Unfold2Table = st_init_table_with_size(&type_code2_hash, UNFOLD2_TABLE_SIZE);
|
||||
if (ONIG_IS_NULL(Unfold2Table)) return ONIGERR_MEMORY;
|
||||
|
||||
for (i = 0; i < numberof(CaseUnfold_12); i++) {
|
||||
p2 = &CaseUnfold_12[i];
|
||||
st_add_direct(Unfold2Table, (st_data_t )p2->from, (st_data_t )(&p2->to));
|
||||
}
|
||||
for (i = 0; i < numberof(CaseUnfold_12_Locale); i++) {
|
||||
p2 = &CaseUnfold_12_Locale[i];
|
||||
for (i = 0; i < numberof(CaseUnfold_12_Table); i++) {
|
||||
const CaseUnfold_12_Type *p2 = &CaseUnfold_12_Table[i];
|
||||
st_add_direct(Unfold2Table, (st_data_t )p2->from, (st_data_t )(&p2->to));
|
||||
}
|
||||
|
||||
|
@ -283,7 +267,7 @@ static int init_case_fold_table(void)
|
|||
if (ONIG_IS_NULL(Unfold3Table)) return ONIGERR_MEMORY;
|
||||
|
||||
for (i = 0; i < numberof(CaseUnfold_13); i++) {
|
||||
p3 = &CaseUnfold_13[i];
|
||||
const CaseUnfold_13_Type *p3 = &CaseUnfold_13[i];
|
||||
st_add_direct(Unfold3Table, (st_data_t )p3->from, (st_data_t )(&p3->to));
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue