1 // Scintilla source code edit control
2 /** @file CaseFolder.cxx
3 ** Classes for case folding.
5 // Copyright 1998-2013 by Neil Hodgson <neilh@scintilla.org>
6 // The License.txt file describes the conditions under which this software may be distributed.
11 #include "CaseFolder.h"
12 #include "CaseConvert.h"
13 #include "UniConversion.h"
16 using namespace Scintilla
;
19 CaseFolder::~CaseFolder() {
22 CaseFolderTable::CaseFolderTable() {
23 for (size_t iChar
=0; iChar
<sizeof(mapping
); iChar
++) {
24 mapping
[iChar
] = static_cast<char>(iChar
);
28 CaseFolderTable::~CaseFolderTable() {
31 size_t CaseFolderTable::Fold(char *folded
, size_t sizeFolded
, const char *mixed
, size_t lenMixed
) {
32 if (lenMixed
> sizeFolded
) {
35 for (size_t i
=0; i
<lenMixed
; i
++) {
36 folded
[i
] = mapping
[static_cast<unsigned char>(mixed
[i
])];
42 void CaseFolderTable::SetTranslation(char ch
, char chTranslation
) {
43 mapping
[static_cast<unsigned char>(ch
)] = chTranslation
;
46 void CaseFolderTable::StandardASCII() {
47 for (size_t iChar
=0; iChar
<sizeof(mapping
); iChar
++) {
48 if (iChar
>= 'A' && iChar
<= 'Z') {
49 mapping
[iChar
] = static_cast<char>(iChar
- 'A' + 'a');
51 mapping
[iChar
] = static_cast<char>(iChar
);
56 CaseFolderUnicode::CaseFolderUnicode() {
58 converter
= ConverterFor(CaseConversionFold
);
61 size_t CaseFolderUnicode::Fold(char *folded
, size_t sizeFolded
, const char *mixed
, size_t lenMixed
) {
62 if ((lenMixed
== 1) && (sizeFolded
> 0)) {
63 folded
[0] = mapping
[static_cast<unsigned char>(mixed
[0])];
66 return converter
->CaseConvertString(folded
, sizeFolded
, mixed
, lenMixed
);