From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../translation/cld2/internal/fixunicodevalue.cc | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 toolkit/components/translation/cld2/internal/fixunicodevalue.cc (limited to 'toolkit/components/translation/cld2/internal/fixunicodevalue.cc') diff --git a/toolkit/components/translation/cld2/internal/fixunicodevalue.cc b/toolkit/components/translation/cld2/internal/fixunicodevalue.cc new file mode 100644 index 0000000000..03edf7c51c --- /dev/null +++ b/toolkit/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(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 + -- cgit v1.2.3