diff options
author | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 15:50:03 +0200 |
---|---|---|
committer | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 15:50:03 +0200 |
commit | e3b7744bee37c3d4a026d2193bed5e9439c40ff3 (patch) | |
tree | f3f7b07ca9bd78bf7ac2d76dd55b61b2a8bb549e /application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc | |
parent | cbce4f0b6a337f8250b62cae028f1c6d4cce51df (diff) | |
parent | 031afcafe288bf0f46c0c5caae20dd3db8bd0297 (diff) | |
download | UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.gz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.lz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.xz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.zip |
Merge branch 'move-basilisk'
Diffstat (limited to 'application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc')
-rw-r--r-- | application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc b/application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc new file mode 100644 index 000000000..03edf7c51 --- /dev/null +++ b/application/basilisk/components/translation/cld2/internal/fixunicodevalue.cc @@ -0,0 +1,54 @@ +// Copyright 2013 Google Inc. All Rights Reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// +// Routine that maps a Unicode code point to an interchange-valid one +// + +#include "fixunicodevalue.h" +#include "integral_types.h" + +namespace CLD2 { + +// Guarantees that the resulting output value is interchange valid +// 00-FF; map to spaces or MS CP1252 +// D800-DFFF; surrogates +// FDD0-FDEF; non-characters +// xxFFFE-xxFFFF; non-characters +char32 FixUnicodeValue(char32 uv) { + uint32 uuv = static_cast<uint32>(uv); + if (uuv < 0x0100) { + return kMapFullMicrosoft1252OrSpace[uuv]; + } + if (uuv < 0xD800) { + return uv; + } + if ((uuv & ~0x0F) == 0xFDD0) { // non-characters + return 0xFFFD; + } + if ((uuv & ~0x0F) == 0xFDE0) { // non-characters + return 0xFFFD; + } + if ((uuv & 0x00FFFE) == 0xFFFE) { // non-characters + return 0xFFFD; + } + if ((0xE000 <= uuv) && (uuv <= 0x10FFFF)) { + return uv; + } + // surrogates and negative and > 0x10FFFF all land here + return 0xFFFD; +} + +} // End namespace CLD2 + |