2015-04-03 12:57:16 +08:00
|
|
|
// Tencent is pleased to support the open source community by making RapidJSON available.
|
|
|
|
//
|
|
|
|
// Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip. All rights reserved.
|
2014-08-11 22:26:45 +08:00
|
|
|
//
|
2015-04-03 12:57:16 +08:00
|
|
|
// Licensed under the MIT License (the "License"); you may not use this file except
|
|
|
|
// in compliance with the License. You may obtain a copy of the License at
|
2014-08-11 22:26:45 +08:00
|
|
|
//
|
2015-04-03 12:57:16 +08:00
|
|
|
// http://opensource.org/licenses/MIT
|
2014-08-11 22:26:45 +08:00
|
|
|
//
|
2015-04-03 12:57:16 +08:00
|
|
|
// 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.
|
2014-08-11 22:26:45 +08:00
|
|
|
|
2011-11-18 17:01:23 +00:00
|
|
|
#ifndef RAPIDJSON_INTERNAL_STRFUNC_H_
|
|
|
|
#define RAPIDJSON_INTERNAL_STRFUNC_H_
|
|
|
|
|
2015-04-28 10:09:37 +08:00
|
|
|
#include "../rapidjson.h"
|
|
|
|
|
2014-11-06 19:24:20 +01:00
|
|
|
RAPIDJSON_NAMESPACE_BEGIN
|
2011-11-18 17:01:23 +00:00
|
|
|
namespace internal {
|
|
|
|
|
|
|
|
//! Custom strlen() which works on different character types.
|
2014-08-11 22:26:45 +08:00
|
|
|
/*! \tparam Ch Character type (e.g. char, wchar_t, short)
|
|
|
|
\param s Null-terminated input string.
|
|
|
|
\return Number of characters in the string.
|
|
|
|
\note This has the same semantics as strlen(), the return value is not number of Unicode codepoints.
|
2011-11-18 17:01:23 +00:00
|
|
|
*/
|
|
|
|
template <typename Ch>
|
|
|
|
inline SizeType StrLen(const Ch* s) {
|
2014-08-11 22:26:45 +08:00
|
|
|
const Ch* p = s;
|
|
|
|
while (*p) ++p;
|
|
|
|
return SizeType(p - s);
|
2011-11-18 17:01:23 +00:00
|
|
|
}
|
|
|
|
|
2015-05-07 17:09:55 +08:00
|
|
|
//! Returns number of code points in a encoded string.
|
|
|
|
template<typename Encoding>
|
|
|
|
bool CountStringCodePoint(const typename Encoding::Ch* s, SizeType length, SizeType* outCount) {
|
|
|
|
GenericStringStream<Encoding> is(s);
|
|
|
|
const typename Encoding::Ch* end = s + length;
|
|
|
|
SizeType count = 0;
|
|
|
|
while (is.src_ < end) {
|
|
|
|
unsigned codepoint;
|
|
|
|
if (!Encoding::Decode(is, &codepoint))
|
|
|
|
return false;
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
*outCount = count;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2011-11-18 17:01:23 +00:00
|
|
|
} // namespace internal
|
2014-11-06 19:24:20 +01:00
|
|
|
RAPIDJSON_NAMESPACE_END
|
2011-11-18 17:01:23 +00:00
|
|
|
|
|
|
|
#endif // RAPIDJSON_INTERNAL_STRFUNC_H_
|