Commit 5b593bba authored by John Stiles's avatar John Stiles Committed by GitHub

Merge pull request #2 from miloyip/master

Merge back
parents 33a9f585 266870df
...@@ -199,8 +199,7 @@ public: ...@@ -199,8 +199,7 @@ public:
return EndValue(WriteString(str, length)); return EndValue(WriteString(str, length));
} }
template <typename T> bool String(const Ch* str, SizeType length, bool copy = false) {
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) String(const T* str, SizeType length, bool copy = false) {
RAPIDJSON_ASSERT(str != 0); RAPIDJSON_ASSERT(str != 0);
(void)copy; (void)copy;
Prefix(kStringType); Prefix(kStringType);
...@@ -219,8 +218,7 @@ public: ...@@ -219,8 +218,7 @@ public:
return WriteStartObject(); return WriteStartObject();
} }
template <typename T> bool Key(const Ch* str, SizeType length, bool copy = false) { return String(str, length, copy); }
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) Key(const T* str, SizeType length, bool copy = false) { return String(str, length, copy); }
bool EndObject(SizeType memberCount = 0) { bool EndObject(SizeType memberCount = 0) {
(void)memberCount; (void)memberCount;
...@@ -250,23 +248,9 @@ public: ...@@ -250,23 +248,9 @@ public:
//@{ //@{
//! Simpler but slower overload. //! Simpler but slower overload.
template <typename T> bool String(const Ch* const& str) { return String(str, internal::StrLen(str)); }
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) String(const T* const& str) { return String(str, internal::StrLen(str)); } bool Key(const Ch* const& str) { return Key(str, internal::StrLen(str)); }
template <typename T>
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) Key(const T* const& str) { return Key(str, internal::StrLen(str)); }
//! The compiler can give us the length of quoted strings for free.
template <typename T, size_t N>
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) String(const T (&str)[N]) {
RAPIDJSON_ASSERT(str[N-1] == '\0'); // you must pass in a null-terminated string (quoted constant strings are always null-terminated)
return String(str, N-1);
}
template <typename T, size_t N>
RAPIDJSON_ENABLEIF_RETURN((internal::IsSame<Ch, T>), (bool)) Key(const T (&str)[N]) {
RAPIDJSON_ASSERT(str[N-1] == '\0'); // you must pass in a null-terminated string (quoted constant strings are always null-terminated)
return Key(str, N-1);
}
//@} //@}
//! Write a raw JSON value. //! Write a raw JSON value.
......
...@@ -100,6 +100,19 @@ TEST(Writer, String) { ...@@ -100,6 +100,19 @@ TEST(Writer, String) {
#endif #endif
} }
TEST(Writer, Issue_889) {
char buf[100] = "Hello";
StringBuffer buffer;
Writer<StringBuffer> writer(buffer);
writer.StartArray();
writer.String(buf);
writer.EndArray();
EXPECT_STREQ("[\"Hello\"]", buffer.GetString());
EXPECT_TRUE(writer.IsComplete()); \
}
TEST(Writer, ScanWriteUnescapedString) { TEST(Writer, ScanWriteUnescapedString) {
const char json[] = "[\" \\\"0123456789ABCDEF\"]"; const char json[] = "[\" \\\"0123456789ABCDEF\"]";
// ^ scanning stops here. // ^ scanning stops here.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment