6de53819a7
- 432508bf64998983b3c194d5f164872ce3c2e573 Put visibility tags into absl external build files by Jon Cohen <cohenjon@google.com> - 25d59d11e7b833fe632cddb5bf4d76075ae6282b Use ABSL_PREDICT_TRUE instead of *FALSE for the range che... by Jon Cohen <cohenjon@google.com> - 8d8a5890a55ddd19aac849748441eeb57c684f10 Better detection for MSVC support on std::optional. by Xiaoyi Zhang <zhangxy@google.com> - c1b31e4a97939885c3bbc23ecb093e9619e73ad1 Internal cleanup by Gennadiy Rozental <rogeeff@google.com> - 4f56ad20c4eeccc6f5fb21ec6c7191233d34a090 Internal change. by Matt Calabrese <calabrese@google.com> - d2a02b52c75c295708170f4d17b7ff442c8d6a97 Fixed a minor typo in the SimpleAtob() function comment. by Abseil Team <absl-team@google.com> - 5adbff5c23a45278d06de2ef3a29ea51b0d1269e Internal cleanup by Gennadiy Rozental <rogeeff@google.com> GitOrigin-RevId: 432508bf64998983b3c194d5f164872ce3c2e573 Change-Id: I32ddd151d3350b96a22e8f1830f19b59374953ad
51 lines
1.8 KiB
C++
51 lines
1.8 KiB
C++
// Copyright 2017 The Abseil Authors.
|
|
//
|
|
// 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.
|
|
//
|
|
// UTF8 utilities, implemented to reduce dependencies.
|
|
//
|
|
// If you need Unicode specific processing (for example being aware of
|
|
// Unicode character boundaries, or knowledge of Unicode casing rules,
|
|
// or various forms of equivalence and normalization), take a look at
|
|
// files in i18n/utf8.
|
|
|
|
#ifndef ABSL_STRINGS_INTERNAL_UTF8_H_
|
|
#define ABSL_STRINGS_INTERNAL_UTF8_H_
|
|
|
|
#include <cstddef>
|
|
#include <cstdint>
|
|
|
|
namespace absl {
|
|
namespace strings_internal {
|
|
|
|
// For Unicode code points 0 through 0x10FFFF, EncodeUTF8Char writes
|
|
// out the UTF-8 encoding into buffer, and returns the number of chars
|
|
// it wrote.
|
|
//
|
|
// As described in https://tools.ietf.org/html/rfc3629#section-3 , the encodings
|
|
// are:
|
|
// 00 - 7F : 0xxxxxxx
|
|
// 80 - 7FF : 110xxxxx 10xxxxxx
|
|
// 800 - FFFF : 1110xxxx 10xxxxxx 10xxxxxx
|
|
// 10000 - 10FFFF : 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
|
|
//
|
|
// Values greater than 0x10FFFF are not supported and may or may not write
|
|
// characters into buffer, however never will more than kMaxEncodedUTF8Size
|
|
// bytes be written, regardless of the value of utf8_char.
|
|
enum { kMaxEncodedUTF8Size = 4 };
|
|
size_t EncodeUTF8Char(char *buffer, char32_t utf8_char);
|
|
|
|
} // namespace strings_internal
|
|
} // namespace absl
|
|
|
|
#endif // ABSL_STRINGS_INTERNAL_UTF8_H_
|