cphot 0.1
A C++ tool for computing photometry from spectra.
strfunc.h
Go to the documentation of this file.
1 // Tencent is pleased to support the open source community by making RapidJSON available.
2 //
3 // Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip. All rights reserved.
4 //
5 // Licensed under the MIT License (the "License"); you may not use this file except
6 // in compliance with the License. You may obtain a copy of the License at
7 //
8 // http://opensource.org/licenses/MIT
9 //
10 // Unless required by applicable law or agreed to in writing, software distributed
11 // under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
12 // CONDITIONS OF ANY KIND, either express or implied. See the License for the
13 // specific language governing permissions and limitations under the License.
14 
15 #ifndef RAPIDJSON_INTERNAL_STRFUNC_H_
16 #define RAPIDJSON_INTERNAL_STRFUNC_H_
17 
18 #include "../stream.h"
19 
21 namespace internal {
22 
23 //! Custom strlen() which works on different character types.
24 /*! \tparam Ch Character type (e.g. char, wchar_t, short)
25  \param s Null-terminated input string.
26  \return Number of characters in the string.
27  \note This has the same semantics as strlen(), the return value is not number of Unicode codepoints.
28 */
29 template <typename Ch>
30 inline SizeType StrLen(const Ch* s) {
31  RAPIDJSON_ASSERT(s != 0);
32  const Ch* p = s;
33  while (*p) ++p;
34  return SizeType(p - s);
35 }
36 
37 //! Returns number of code points in a encoded string.
38 template<typename Encoding>
39 bool CountStringCodePoint(const typename Encoding::Ch* s, SizeType length, SizeType* outCount) {
40  RAPIDJSON_ASSERT(s != 0);
41  RAPIDJSON_ASSERT(outCount != 0);
43  const typename Encoding::Ch* end = s + length;
44  SizeType count = 0;
45  while (is.src_ < end) {
46  unsigned codepoint;
47  if (!Encoding::Decode(is, &codepoint))
48  return false;
49  count++;
50  }
51  *outCount = count;
52  return true;
53 }
54 
55 } // namespace internal
57 
58 #endif // RAPIDJSON_INTERNAL_STRFUNC_H_
RAPIDJSON_NAMESPACE_END
#define RAPIDJSON_NAMESPACE_END
provide custom rapidjson namespace (closing expression)
Definition: rapidjson.h:119
RAPIDJSON_NAMESPACE_BEGIN
#define RAPIDJSON_NAMESPACE_BEGIN
provide custom rapidjson namespace (opening expression)
Definition: rapidjson.h:116
SizeType
RAPIDJSON_NAMESPACE_BEGIN typedef unsigned SizeType
Size type (for string lengths, array sizes, etc.)
Definition: rapidjson.h:380
GenericStringStream
Read-only string stream.
Definition: fwd.h:47
RAPIDJSON_ASSERT
#define RAPIDJSON_ASSERT(x)
Assertion.
Definition: rapidjson.h:402
GenericStringStream::src_
const Ch * src_
Current read position.
Definition: stream.h:124
internal
Definition: document.h:391
internal::CountStringCodePoint
bool CountStringCodePoint(const typename Encoding::Ch *s, SizeType length, SizeType *outCount)
Returns number of code points in a encoded string.
Definition: strfunc.h:39
internal::StrLen
SizeType StrLen(const Ch *s)
Custom strlen() which works on different character types.
Definition: strfunc.h:30