@eosrio/node-abieos 2.1.0-beta.0 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (740) hide show
  1. package/README.md +4 -1
  2. package/dist/abieos.node +0 -0
  3. package/lib/abieos.d.ts +19 -0
  4. package/lib/abieos.d.ts.map +1 -0
  5. package/lib/abieos.js +100 -0
  6. package/lib/abieos.ts +107 -0
  7. package/package.json +13 -8
  8. package/.gitmodules +0 -6
  9. package/.idea/misc.xml +0 -6
  10. package/.idea/modules.xml +0 -8
  11. package/.idea/node-abieos.iml +0 -12
  12. package/.idea/vcs.xml +0 -9
  13. package/.idea/workspace.xml +0 -266
  14. package/CMakeLists.txt +0 -35
  15. package/abieos.d.ts +0 -21
  16. package/abieos.js +0 -59
  17. package/eosio.json +0 -1596
  18. package/external/date/CMakeLists.txt +0 -175
  19. package/external/date/LICENSE.txt +0 -31
  20. package/external/date/README.md +0 -61
  21. package/external/date/compile_fail.sh +0 -16
  22. package/external/date/include/date/chrono_io.h +0 -34
  23. package/external/date/include/date/date.h +0 -8335
  24. package/external/date/include/date/ios.h +0 -50
  25. package/external/date/include/date/islamic.h +0 -3031
  26. package/external/date/include/date/iso_week.h +0 -1745
  27. package/external/date/include/date/julian.h +0 -3046
  28. package/external/date/include/date/ptz.h +0 -592
  29. package/external/date/include/date/tz.h +0 -2760
  30. package/external/date/include/date/tz_private.h +0 -318
  31. package/external/date/src/ios.mm +0 -337
  32. package/external/date/src/tz.cpp +0 -3801
  33. package/external/date/test/clock_cast_test/custom_clock.pass.cpp +0 -213
  34. package/external/date/test/clock_cast_test/deprecated.pass.cpp +0 -90
  35. package/external/date/test/clock_cast_test/local_t.pass.cpp +0 -132
  36. package/external/date/test/clock_cast_test/noncastable.pass.cpp +0 -251
  37. package/external/date/test/clock_cast_test/normal_clocks.pass.cpp +0 -102
  38. package/external/date/test/clock_cast_test/to_sys_return_int.fail.cpp +0 -49
  39. package/external/date/test/clock_cast_test/to_sys_return_reference.fail.cpp +0 -51
  40. package/external/date/test/clock_cast_test/to_sys_return_utc_time.fail.cpp +0 -49
  41. package/external/date/test/date_test/day.pass.cpp +0 -143
  42. package/external/date/test/date_test/daypday.fail.cpp +0 -32
  43. package/external/date/test/date_test/daysmday.fail.cpp +0 -32
  44. package/external/date/test/date_test/daysmweekday.fail.cpp +0 -32
  45. package/external/date/test/date_test/detail/decimal_format_seconds.pass.cpp +0 -145
  46. package/external/date/test/date_test/detail/make_precision.pass.cpp +0 -63
  47. package/external/date/test/date_test/detail/static_pow10.pass.cpp +0 -50
  48. package/external/date/test/date_test/detail/width.pass.cpp +0 -64
  49. package/external/date/test/date_test/durations.pass.cpp +0 -62
  50. package/external/date/test/date_test/durations_output.pass.cpp +0 -328
  51. package/external/date/test/date_test/format/century.pass.cpp +0 -117
  52. package/external/date/test/date_test/format/misc.pass.cpp +0 -52
  53. package/external/date/test/date_test/format/range.pass.cpp +0 -78
  54. package/external/date/test/date_test/format/two_dight_year.pass.cpp +0 -121
  55. package/external/date/test/date_test/last.pass.cpp +0 -34
  56. package/external/date/test/date_test/make_time.pass.cpp +0 -164
  57. package/external/date/test/date_test/month.pass.cpp +0 -181
  58. package/external/date/test/date_test/month_day.pass.cpp +0 -82
  59. package/external/date/test/date_test/month_day_last.pass.cpp +0 -75
  60. package/external/date/test/date_test/month_weekday.pass.cpp +0 -77
  61. package/external/date/test/date_test/month_weekday_last.pass.cpp +0 -77
  62. package/external/date/test/date_test/month_weekday_last_less.fail.cpp +0 -34
  63. package/external/date/test/date_test/month_weekday_less.fail.cpp +0 -34
  64. package/external/date/test/date_test/monthpmonth.fail.cpp +0 -32
  65. package/external/date/test/date_test/months_m_year_month.fail.cpp +0 -33
  66. package/external/date/test/date_test/months_m_year_month_day.fail.cpp +0 -33
  67. package/external/date/test/date_test/monthsmmonth.fail.cpp +0 -32
  68. package/external/date/test/date_test/multi_year_duration_addition.pass.cpp +0 -297
  69. package/external/date/test/date_test/op_div_day_day.fail.cpp +0 -33
  70. package/external/date/test/date_test/op_div_int_month.fail.cpp +0 -33
  71. package/external/date/test/date_test/op_div_int_year.fail.cpp +0 -33
  72. package/external/date/test/date_test/op_div_last_last.fail.cpp +0 -33
  73. package/external/date/test/date_test/op_div_month_day.pass.cpp +0 -41
  74. package/external/date/test/date_test/op_div_month_day_last.pass.cpp +0 -39
  75. package/external/date/test/date_test/op_div_month_day_month_day.fail.cpp +0 -33
  76. package/external/date/test/date_test/op_div_month_month.fail.cpp +0 -33
  77. package/external/date/test/date_test/op_div_month_weekday.pass.cpp +0 -39
  78. package/external/date/test/date_test/op_div_month_weekday_last.pass.cpp +0 -39
  79. package/external/date/test/date_test/op_div_month_year.fail.cpp +0 -33
  80. package/external/date/test/date_test/op_div_survey.pass.cpp +0 -437
  81. package/external/date/test/date_test/op_div_weekday_indexed_weekday_indexed.fail.cpp +0 -33
  82. package/external/date/test/date_test/op_div_weekday_last_weekday_last.fail.cpp +0 -33
  83. package/external/date/test/date_test/op_div_year_month.pass.cpp +0 -35
  84. package/external/date/test/date_test/op_div_year_month_day.pass.cpp +0 -43
  85. package/external/date/test/date_test/op_div_year_month_day_last.pass.cpp +0 -41
  86. package/external/date/test/date_test/op_div_year_month_weekday.pass.cpp +0 -41
  87. package/external/date/test/date_test/op_div_year_month_weekday_last.pass.cpp +0 -41
  88. package/external/date/test/date_test/op_div_year_month_year_month.fail.cpp +0 -33
  89. package/external/date/test/date_test/op_div_year_year.fail.cpp +0 -33
  90. package/external/date/test/date_test/parse.pass.cpp +0 -904
  91. package/external/date/test/date_test/sizeof.pass.cpp +0 -62
  92. package/external/date/test/date_test/time_of_day_hours.pass.cpp +0 -104
  93. package/external/date/test/date_test/time_of_day_microfortnights.pass.cpp +0 -119
  94. package/external/date/test/date_test/time_of_day_milliseconds.pass.cpp +0 -126
  95. package/external/date/test/date_test/time_of_day_minutes.pass.cpp +0 -110
  96. package/external/date/test/date_test/time_of_day_nanoseconds.pass.cpp +0 -126
  97. package/external/date/test/date_test/time_of_day_seconds.pass.cpp +0 -116
  98. package/external/date/test/date_test/weekday.pass.cpp +0 -201
  99. package/external/date/test/date_test/weekday_indexed.pass.cpp +0 -70
  100. package/external/date/test/date_test/weekday_last.pass.cpp +0 -66
  101. package/external/date/test/date_test/weekday_lessthan.fail.cpp +0 -32
  102. package/external/date/test/date_test/weekday_sum.fail.cpp +0 -32
  103. package/external/date/test/date_test/year.pass.cpp +0 -146
  104. package/external/date/test/date_test/year_month.pass.cpp +0 -142
  105. package/external/date/test/date_test/year_month_day.pass.cpp +0 -244
  106. package/external/date/test/date_test/year_month_day_last.pass.cpp +0 -177
  107. package/external/date/test/date_test/year_month_day_m_year_month_day.fail.cpp +0 -33
  108. package/external/date/test/date_test/year_month_day_p_year_month_day.fail.cpp +0 -33
  109. package/external/date/test/date_test/year_month_p_year_month.fail.cpp +0 -33
  110. package/external/date/test/date_test/year_month_weekday.pass.cpp +0 -178
  111. package/external/date/test/date_test/year_month_weekday_last.pass.cpp +0 -169
  112. package/external/date/test/date_test/year_p_year.fail.cpp +0 -32
  113. package/external/date/test/date_test/years_m_year.fail.cpp +0 -32
  114. package/external/date/test/date_test/years_m_year_month.fail.cpp +0 -33
  115. package/external/date/test/date_test/years_m_year_month_day.fail.cpp +0 -33
  116. package/external/date/test/iso_week/last.pass.cpp +0 -34
  117. package/external/date/test/iso_week/lastweek_weekday.pass.cpp +0 -82
  118. package/external/date/test/iso_week/op_div_survey.pass.cpp +0 -196
  119. package/external/date/test/iso_week/weekday.pass.cpp +0 -227
  120. package/external/date/test/iso_week/weekday_lessthan.fail.cpp +0 -32
  121. package/external/date/test/iso_week/weekday_sum.fail.cpp +0 -32
  122. package/external/date/test/iso_week/weeknum.pass.cpp +0 -121
  123. package/external/date/test/iso_week/weeknum_p_weeknum.fail.cpp +0 -32
  124. package/external/date/test/iso_week/weeknum_weekday.pass.cpp +0 -86
  125. package/external/date/test/iso_week/year.pass.cpp +0 -120
  126. package/external/date/test/iso_week/year_lastweek.pass.cpp +0 -97
  127. package/external/date/test/iso_week/year_lastweek_weekday.pass.cpp +0 -129
  128. package/external/date/test/iso_week/year_p_year.fail.cpp +0 -32
  129. package/external/date/test/iso_week/year_weeknum.pass.cpp +0 -97
  130. package/external/date/test/iso_week/year_weeknum_weekday.pass.cpp +0 -139
  131. package/external/date/test/iso_week/years_m_year.fail.cpp +0 -32
  132. package/external/date/test/just.pass.cpp +0 -26
  133. package/external/date/test/testit +0 -177
  134. package/external/date/test/tz_test/OffsetZone.pass.cpp +0 -81
  135. package/external/date/test/tz_test/README.md +0 -22
  136. package/external/date/test/tz_test/tzdata2015e.txt.zip +0 -0
  137. package/external/date/test/tz_test/tzdata2015f.txt.zip +0 -0
  138. package/external/date/test/tz_test/tzdata2016c.txt.zip +0 -0
  139. package/external/date/test/tz_test/tzdata2016d.txt.zip +0 -0
  140. package/external/date/test/tz_test/tzdata2016e.txt.zip +0 -0
  141. package/external/date/test/tz_test/tzdata2016f.txt.zip +0 -0
  142. package/external/date/test/tz_test/validate.cpp +0 -165
  143. package/external/date/test/tz_test/zone.pass.cpp +0 -37
  144. package/external/date/test/tz_test/zoned_time.pass.cpp +0 -464
  145. package/external/date/test_fail.sh +0 -10
  146. package/external/rapidjson/.gitattributes +0 -22
  147. package/external/rapidjson/.gitmodules +0 -3
  148. package/external/rapidjson/.travis.yml +0 -99
  149. package/external/rapidjson/CHANGELOG.md +0 -158
  150. package/external/rapidjson/CMakeLists.txt +0 -221
  151. package/external/rapidjson/CMakeModules/FindGTestSrc.cmake +0 -30
  152. package/external/rapidjson/RapidJSON.pc.in +0 -7
  153. package/external/rapidjson/RapidJSONConfig.cmake.in +0 -15
  154. package/external/rapidjson/RapidJSONConfigVersion.cmake.in +0 -10
  155. package/external/rapidjson/appveyor.yml +0 -54
  156. package/external/rapidjson/bin/data/glossary.json +0 -22
  157. package/external/rapidjson/bin/data/menu.json +0 -27
  158. package/external/rapidjson/bin/data/readme.txt +0 -1
  159. package/external/rapidjson/bin/data/sample.json +0 -3315
  160. package/external/rapidjson/bin/data/webapp.json +0 -88
  161. package/external/rapidjson/bin/data/widget.json +0 -26
  162. package/external/rapidjson/bin/encodings/utf16be.json +0 -0
  163. package/external/rapidjson/bin/encodings/utf16bebom.json +0 -0
  164. package/external/rapidjson/bin/encodings/utf16le.json +0 -0
  165. package/external/rapidjson/bin/encodings/utf16lebom.json +0 -0
  166. package/external/rapidjson/bin/encodings/utf32be.json +0 -0
  167. package/external/rapidjson/bin/encodings/utf32bebom.json +0 -0
  168. package/external/rapidjson/bin/encodings/utf32le.json +0 -0
  169. package/external/rapidjson/bin/encodings/utf32lebom.json +0 -0
  170. package/external/rapidjson/bin/encodings/utf8.json +0 -7
  171. package/external/rapidjson/bin/encodings/utf8bom.json +0 -7
  172. package/external/rapidjson/bin/jsonchecker/fail1.json +0 -1
  173. package/external/rapidjson/bin/jsonchecker/fail10.json +0 -1
  174. package/external/rapidjson/bin/jsonchecker/fail11.json +0 -1
  175. package/external/rapidjson/bin/jsonchecker/fail12.json +0 -1
  176. package/external/rapidjson/bin/jsonchecker/fail13.json +0 -1
  177. package/external/rapidjson/bin/jsonchecker/fail14.json +0 -1
  178. package/external/rapidjson/bin/jsonchecker/fail15.json +0 -1
  179. package/external/rapidjson/bin/jsonchecker/fail16.json +0 -1
  180. package/external/rapidjson/bin/jsonchecker/fail17.json +0 -1
  181. package/external/rapidjson/bin/jsonchecker/fail18.json +0 -1
  182. package/external/rapidjson/bin/jsonchecker/fail19.json +0 -1
  183. package/external/rapidjson/bin/jsonchecker/fail2.json +0 -1
  184. package/external/rapidjson/bin/jsonchecker/fail20.json +0 -1
  185. package/external/rapidjson/bin/jsonchecker/fail21.json +0 -1
  186. package/external/rapidjson/bin/jsonchecker/fail22.json +0 -1
  187. package/external/rapidjson/bin/jsonchecker/fail23.json +0 -1
  188. package/external/rapidjson/bin/jsonchecker/fail24.json +0 -1
  189. package/external/rapidjson/bin/jsonchecker/fail25.json +0 -1
  190. package/external/rapidjson/bin/jsonchecker/fail26.json +0 -1
  191. package/external/rapidjson/bin/jsonchecker/fail27.json +0 -2
  192. package/external/rapidjson/bin/jsonchecker/fail28.json +0 -2
  193. package/external/rapidjson/bin/jsonchecker/fail29.json +0 -1
  194. package/external/rapidjson/bin/jsonchecker/fail3.json +0 -1
  195. package/external/rapidjson/bin/jsonchecker/fail30.json +0 -1
  196. package/external/rapidjson/bin/jsonchecker/fail31.json +0 -1
  197. package/external/rapidjson/bin/jsonchecker/fail32.json +0 -1
  198. package/external/rapidjson/bin/jsonchecker/fail33.json +0 -1
  199. package/external/rapidjson/bin/jsonchecker/fail4.json +0 -1
  200. package/external/rapidjson/bin/jsonchecker/fail5.json +0 -1
  201. package/external/rapidjson/bin/jsonchecker/fail6.json +0 -1
  202. package/external/rapidjson/bin/jsonchecker/fail7.json +0 -1
  203. package/external/rapidjson/bin/jsonchecker/fail8.json +0 -1
  204. package/external/rapidjson/bin/jsonchecker/fail9.json +0 -1
  205. package/external/rapidjson/bin/jsonchecker/pass1.json +0 -58
  206. package/external/rapidjson/bin/jsonchecker/pass2.json +0 -1
  207. package/external/rapidjson/bin/jsonchecker/pass3.json +0 -6
  208. package/external/rapidjson/bin/jsonchecker/readme.txt +0 -3
  209. package/external/rapidjson/bin/types/booleans.json +0 -102
  210. package/external/rapidjson/bin/types/floats.json +0 -102
  211. package/external/rapidjson/bin/types/guids.json +0 -102
  212. package/external/rapidjson/bin/types/integers.json +0 -102
  213. package/external/rapidjson/bin/types/mixed.json +0 -592
  214. package/external/rapidjson/bin/types/nulls.json +0 -102
  215. package/external/rapidjson/bin/types/paragraphs.json +0 -102
  216. package/external/rapidjson/bin/types/readme.txt +0 -1
  217. package/external/rapidjson/contrib/natvis/LICENSE +0 -45
  218. package/external/rapidjson/contrib/natvis/README.md +0 -7
  219. package/external/rapidjson/contrib/natvis/rapidjson.natvis +0 -38
  220. package/external/rapidjson/doc/CMakeLists.txt +0 -27
  221. package/external/rapidjson/doc/Doxyfile.in +0 -2369
  222. package/external/rapidjson/doc/Doxyfile.zh-cn.in +0 -2369
  223. package/external/rapidjson/doc/diagram/architecture.dot +0 -50
  224. package/external/rapidjson/doc/diagram/architecture.png +0 -0
  225. package/external/rapidjson/doc/diagram/insituparsing.dot +0 -65
  226. package/external/rapidjson/doc/diagram/insituparsing.png +0 -0
  227. package/external/rapidjson/doc/diagram/iterative-parser-states-diagram.dot +0 -62
  228. package/external/rapidjson/doc/diagram/iterative-parser-states-diagram.png +0 -0
  229. package/external/rapidjson/doc/diagram/move1.dot +0 -47
  230. package/external/rapidjson/doc/diagram/move1.png +0 -0
  231. package/external/rapidjson/doc/diagram/move2.dot +0 -62
  232. package/external/rapidjson/doc/diagram/move2.png +0 -0
  233. package/external/rapidjson/doc/diagram/move3.dot +0 -60
  234. package/external/rapidjson/doc/diagram/move3.png +0 -0
  235. package/external/rapidjson/doc/diagram/normalparsing.dot +0 -56
  236. package/external/rapidjson/doc/diagram/normalparsing.png +0 -0
  237. package/external/rapidjson/doc/diagram/simpledom.dot +0 -54
  238. package/external/rapidjson/doc/diagram/simpledom.png +0 -0
  239. package/external/rapidjson/doc/diagram/tutorial.dot +0 -58
  240. package/external/rapidjson/doc/diagram/tutorial.png +0 -0
  241. package/external/rapidjson/doc/diagram/utilityclass.dot +0 -73
  242. package/external/rapidjson/doc/diagram/utilityclass.png +0 -0
  243. package/external/rapidjson/doc/dom.md +0 -280
  244. package/external/rapidjson/doc/dom.zh-cn.md +0 -284
  245. package/external/rapidjson/doc/encoding.md +0 -146
  246. package/external/rapidjson/doc/encoding.zh-cn.md +0 -152
  247. package/external/rapidjson/doc/faq.md +0 -289
  248. package/external/rapidjson/doc/faq.zh-cn.md +0 -290
  249. package/external/rapidjson/doc/features.md +0 -104
  250. package/external/rapidjson/doc/features.zh-cn.md +0 -103
  251. package/external/rapidjson/doc/internals.md +0 -368
  252. package/external/rapidjson/doc/internals.zh-cn.md +0 -363
  253. package/external/rapidjson/doc/logo/rapidjson.png +0 -0
  254. package/external/rapidjson/doc/logo/rapidjson.svg +0 -119
  255. package/external/rapidjson/doc/misc/DoxygenLayout.xml +0 -194
  256. package/external/rapidjson/doc/misc/doxygenextra.css +0 -274
  257. package/external/rapidjson/doc/misc/footer.html +0 -11
  258. package/external/rapidjson/doc/misc/header.html +0 -24
  259. package/external/rapidjson/doc/npm.md +0 -31
  260. package/external/rapidjson/doc/performance.md +0 -26
  261. package/external/rapidjson/doc/performance.zh-cn.md +0 -26
  262. package/external/rapidjson/doc/pointer.md +0 -234
  263. package/external/rapidjson/doc/pointer.zh-cn.md +0 -234
  264. package/external/rapidjson/doc/sax.md +0 -509
  265. package/external/rapidjson/doc/sax.zh-cn.md +0 -487
  266. package/external/rapidjson/doc/schema.md +0 -505
  267. package/external/rapidjson/doc/schema.zh-cn.md +0 -237
  268. package/external/rapidjson/doc/stream.md +0 -429
  269. package/external/rapidjson/doc/stream.zh-cn.md +0 -429
  270. package/external/rapidjson/doc/tutorial.md +0 -536
  271. package/external/rapidjson/doc/tutorial.zh-cn.md +0 -535
  272. package/external/rapidjson/docker/debian/Dockerfile +0 -8
  273. package/external/rapidjson/example/CMakeLists.txt +0 -45
  274. package/external/rapidjson/example/archiver/archiver.cpp +0 -292
  275. package/external/rapidjson/example/archiver/archiver.h +0 -145
  276. package/external/rapidjson/example/archiver/archivertest.cpp +0 -287
  277. package/external/rapidjson/example/capitalize/capitalize.cpp +0 -67
  278. package/external/rapidjson/example/condense/condense.cpp +0 -32
  279. package/external/rapidjson/example/filterkey/filterkey.cpp +0 -135
  280. package/external/rapidjson/example/filterkeydom/filterkeydom.cpp +0 -170
  281. package/external/rapidjson/example/jsonx/jsonx.cpp +0 -207
  282. package/external/rapidjson/example/lookaheadparser/lookaheadparser.cpp +0 -350
  283. package/external/rapidjson/example/messagereader/messagereader.cpp +0 -105
  284. package/external/rapidjson/example/parsebyparts/parsebyparts.cpp +0 -176
  285. package/external/rapidjson/example/pretty/pretty.cpp +0 -30
  286. package/external/rapidjson/example/prettyauto/prettyauto.cpp +0 -56
  287. package/external/rapidjson/example/schemavalidator/schemavalidator.cpp +0 -78
  288. package/external/rapidjson/example/serialize/serialize.cpp +0 -173
  289. package/external/rapidjson/example/simpledom/simpledom.cpp +0 -29
  290. package/external/rapidjson/example/simplepullreader/simplepullreader.cpp +0 -53
  291. package/external/rapidjson/example/simplereader/simplereader.cpp +0 -42
  292. package/external/rapidjson/example/simplewriter/simplewriter.cpp +0 -36
  293. package/external/rapidjson/example/tutorial/tutorial.cpp +0 -151
  294. package/external/rapidjson/include/rapidjson/allocators.h +0 -284
  295. package/external/rapidjson/include/rapidjson/cursorstreamwrapper.h +0 -78
  296. package/external/rapidjson/include/rapidjson/document.h +0 -2646
  297. package/external/rapidjson/include/rapidjson/encodedstream.h +0 -299
  298. package/external/rapidjson/include/rapidjson/encodings.h +0 -716
  299. package/external/rapidjson/include/rapidjson/error/en.h +0 -74
  300. package/external/rapidjson/include/rapidjson/error/error.h +0 -161
  301. package/external/rapidjson/include/rapidjson/filereadstream.h +0 -99
  302. package/external/rapidjson/include/rapidjson/filewritestream.h +0 -104
  303. package/external/rapidjson/include/rapidjson/fwd.h +0 -151
  304. package/external/rapidjson/include/rapidjson/internal/biginteger.h +0 -290
  305. package/external/rapidjson/include/rapidjson/internal/diyfp.h +0 -271
  306. package/external/rapidjson/include/rapidjson/internal/dtoa.h +0 -245
  307. package/external/rapidjson/include/rapidjson/internal/ieee754.h +0 -78
  308. package/external/rapidjson/include/rapidjson/internal/itoa.h +0 -308
  309. package/external/rapidjson/include/rapidjson/internal/meta.h +0 -186
  310. package/external/rapidjson/include/rapidjson/internal/pow10.h +0 -55
  311. package/external/rapidjson/include/rapidjson/internal/regex.h +0 -732
  312. package/external/rapidjson/include/rapidjson/internal/stack.h +0 -231
  313. package/external/rapidjson/include/rapidjson/internal/strfunc.h +0 -69
  314. package/external/rapidjson/include/rapidjson/internal/strtod.h +0 -290
  315. package/external/rapidjson/include/rapidjson/internal/swap.h +0 -46
  316. package/external/rapidjson/include/rapidjson/istreamwrapper.h +0 -113
  317. package/external/rapidjson/include/rapidjson/memorybuffer.h +0 -70
  318. package/external/rapidjson/include/rapidjson/memorystream.h +0 -71
  319. package/external/rapidjson/include/rapidjson/msinttypes/inttypes.h +0 -316
  320. package/external/rapidjson/include/rapidjson/msinttypes/stdint.h +0 -300
  321. package/external/rapidjson/include/rapidjson/ostreamwrapper.h +0 -81
  322. package/external/rapidjson/include/rapidjson/pointer.h +0 -1357
  323. package/external/rapidjson/include/rapidjson/prettywriter.h +0 -277
  324. package/external/rapidjson/include/rapidjson/rapidjson.h +0 -654
  325. package/external/rapidjson/include/rapidjson/reader.h +0 -2230
  326. package/external/rapidjson/include/rapidjson/schema.h +0 -2494
  327. package/external/rapidjson/include/rapidjson/stream.h +0 -223
  328. package/external/rapidjson/include/rapidjson/stringbuffer.h +0 -121
  329. package/external/rapidjson/include/rapidjson/writer.h +0 -710
  330. package/external/rapidjson/include_dirs.js +0 -2
  331. package/external/rapidjson/library.json +0 -15
  332. package/external/rapidjson/license.txt +0 -57
  333. package/external/rapidjson/package.json +0 -24
  334. package/external/rapidjson/rapidjson.autopkg +0 -77
  335. package/external/rapidjson/readme.md +0 -160
  336. package/external/rapidjson/readme.zh-cn.md +0 -152
  337. package/external/rapidjson/test/CMakeLists.txt +0 -20
  338. package/external/rapidjson/test/perftest/CMakeLists.txt +0 -28
  339. package/external/rapidjson/test/perftest/misctest.cpp +0 -974
  340. package/external/rapidjson/test/perftest/perftest.cpp +0 -24
  341. package/external/rapidjson/test/perftest/perftest.h +0 -185
  342. package/external/rapidjson/test/perftest/platformtest.cpp +0 -166
  343. package/external/rapidjson/test/perftest/rapidjsontest.cpp +0 -472
  344. package/external/rapidjson/test/perftest/schematest.cpp +0 -223
  345. package/external/rapidjson/test/unittest/CMakeLists.txt +0 -92
  346. package/external/rapidjson/test/unittest/allocatorstest.cpp +0 -100
  347. package/external/rapidjson/test/unittest/bigintegertest.cpp +0 -138
  348. package/external/rapidjson/test/unittest/cursorstreamwrappertest.cpp +0 -115
  349. package/external/rapidjson/test/unittest/documenttest.cpp +0 -672
  350. package/external/rapidjson/test/unittest/dtoatest.cpp +0 -98
  351. package/external/rapidjson/test/unittest/encodedstreamtest.cpp +0 -313
  352. package/external/rapidjson/test/unittest/encodingstest.cpp +0 -451
  353. package/external/rapidjson/test/unittest/filestreamtest.cpp +0 -112
  354. package/external/rapidjson/test/unittest/fwdtest.cpp +0 -230
  355. package/external/rapidjson/test/unittest/istreamwrappertest.cpp +0 -181
  356. package/external/rapidjson/test/unittest/itoatest.cpp +0 -160
  357. package/external/rapidjson/test/unittest/jsoncheckertest.cpp +0 -143
  358. package/external/rapidjson/test/unittest/namespacetest.cpp +0 -70
  359. package/external/rapidjson/test/unittest/ostreamwrappertest.cpp +0 -92
  360. package/external/rapidjson/test/unittest/pointertest.cpp +0 -1529
  361. package/external/rapidjson/test/unittest/prettywritertest.cpp +0 -373
  362. package/external/rapidjson/test/unittest/readertest.cpp +0 -2190
  363. package/external/rapidjson/test/unittest/regextest.cpp +0 -638
  364. package/external/rapidjson/test/unittest/schematest.cpp +0 -2072
  365. package/external/rapidjson/test/unittest/simdtest.cpp +0 -219
  366. package/external/rapidjson/test/unittest/strfunctest.cpp +0 -30
  367. package/external/rapidjson/test/unittest/stringbuffertest.cpp +0 -192
  368. package/external/rapidjson/test/unittest/strtodtest.cpp +0 -132
  369. package/external/rapidjson/test/unittest/unittest.cpp +0 -51
  370. package/external/rapidjson/test/unittest/unittest.h +0 -140
  371. package/external/rapidjson/test/unittest/valuetest.cpp +0 -1851
  372. package/external/rapidjson/test/unittest/writertest.cpp +0 -598
  373. package/external/rapidjson/test/valgrind.supp +0 -17
  374. package/external/rapidjson/thirdparty/gtest/.travis.yml +0 -81
  375. package/external/rapidjson/thirdparty/gtest/BUILD.bazel +0 -175
  376. package/external/rapidjson/thirdparty/gtest/CMakeLists.txt +0 -33
  377. package/external/rapidjson/thirdparty/gtest/CONTRIBUTING.md +0 -160
  378. package/external/rapidjson/thirdparty/gtest/LICENSE +0 -28
  379. package/external/rapidjson/thirdparty/gtest/Makefile.am +0 -14
  380. package/external/rapidjson/thirdparty/gtest/README.md +0 -122
  381. package/external/rapidjson/thirdparty/gtest/WORKSPACE +0 -8
  382. package/external/rapidjson/thirdparty/gtest/appveyor.yml +0 -104
  383. package/external/rapidjson/thirdparty/gtest/ci/build-linux-autotools.sh +0 -44
  384. package/external/rapidjson/thirdparty/gtest/ci/build-linux-bazel.sh +0 -36
  385. package/external/rapidjson/thirdparty/gtest/ci/env-linux.sh +0 -41
  386. package/external/rapidjson/thirdparty/gtest/ci/env-osx.sh +0 -40
  387. package/external/rapidjson/thirdparty/gtest/ci/get-nprocessors.sh +0 -48
  388. package/external/rapidjson/thirdparty/gtest/ci/install-linux.sh +0 -49
  389. package/external/rapidjson/thirdparty/gtest/ci/install-osx.sh +0 -39
  390. package/external/rapidjson/thirdparty/gtest/ci/log-config.sh +0 -51
  391. package/external/rapidjson/thirdparty/gtest/ci/travis.sh +0 -44
  392. package/external/rapidjson/thirdparty/gtest/configure.ac +0 -16
  393. package/external/rapidjson/thirdparty/gtest/googlemock/CHANGES +0 -126
  394. package/external/rapidjson/thirdparty/gtest/googlemock/CMakeLists.txt +0 -242
  395. package/external/rapidjson/thirdparty/gtest/googlemock/CONTRIBUTORS +0 -40
  396. package/external/rapidjson/thirdparty/gtest/googlemock/LICENSE +0 -28
  397. package/external/rapidjson/thirdparty/gtest/googlemock/Makefile.am +0 -224
  398. package/external/rapidjson/thirdparty/gtest/googlemock/README.md +0 -344
  399. package/external/rapidjson/thirdparty/gtest/googlemock/build-aux/.keep +0 -0
  400. package/external/rapidjson/thirdparty/gtest/googlemock/cmake/gmock.pc.in +0 -9
  401. package/external/rapidjson/thirdparty/gtest/googlemock/cmake/gmock_main.pc.in +0 -9
  402. package/external/rapidjson/thirdparty/gtest/googlemock/configure.ac +0 -146
  403. package/external/rapidjson/thirdparty/gtest/googlemock/docs/CheatSheet.md +0 -564
  404. package/external/rapidjson/thirdparty/gtest/googlemock/docs/CookBook.md +0 -3660
  405. package/external/rapidjson/thirdparty/gtest/googlemock/docs/DesignDoc.md +0 -280
  406. package/external/rapidjson/thirdparty/gtest/googlemock/docs/Documentation.md +0 -15
  407. package/external/rapidjson/thirdparty/gtest/googlemock/docs/ForDummies.md +0 -447
  408. package/external/rapidjson/thirdparty/gtest/googlemock/docs/FrequentlyAskedQuestions.md +0 -627
  409. package/external/rapidjson/thirdparty/gtest/googlemock/docs/KnownIssues.md +0 -19
  410. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-actions.h +0 -1262
  411. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-cardinalities.h +0 -147
  412. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-actions.h +0 -2571
  413. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-actions.h.pump +0 -833
  414. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-function-mockers.h +0 -1379
  415. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-function-mockers.h.pump +0 -347
  416. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-matchers.h +0 -2258
  417. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-matchers.h.pump +0 -675
  418. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-nice-strict.h +0 -458
  419. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-generated-nice-strict.h.pump +0 -178
  420. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-matchers.h +0 -5255
  421. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-more-actions.h +0 -246
  422. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-more-matchers.h +0 -91
  423. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock-spec-builders.h +0 -1918
  424. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/gmock.h +0 -95
  425. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h +0 -8
  426. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-generated-actions.h.pump +0 -10
  427. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-matchers.h +0 -38
  428. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/custom/gmock-port.h +0 -46
  429. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-generated-internal-utils.h +0 -286
  430. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-generated-internal-utils.h.pump +0 -136
  431. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-internal-utils.h +0 -574
  432. package/external/rapidjson/thirdparty/gtest/googlemock/include/gmock/internal/gmock-port.h +0 -87
  433. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock.sln +0 -32
  434. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock.vcproj +0 -191
  435. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_config.vsprops +0 -15
  436. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_main.vcproj +0 -187
  437. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2005/gmock_test.vcproj +0 -201
  438. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock.sln +0 -46
  439. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock.vcxproj +0 -145
  440. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_config.props +0 -19
  441. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_main.vcxproj +0 -151
  442. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2010/gmock_test.vcxproj +0 -176
  443. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock.sln +0 -46
  444. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock.vcxproj +0 -145
  445. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_config.props +0 -19
  446. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_main.vcxproj +0 -151
  447. package/external/rapidjson/thirdparty/gtest/googlemock/msvc/2015/gmock_test.vcxproj +0 -176
  448. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/fuse_gmock_files.py +0 -240
  449. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/LICENSE +0 -203
  450. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/README +0 -34
  451. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/README.cppclean +0 -115
  452. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/__init__.py +0 -0
  453. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/ast.py +0 -1733
  454. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/gmock_class.py +0 -227
  455. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/gmock_class_test.py +0 -448
  456. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/keywords.py +0 -59
  457. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/tokenize.py +0 -287
  458. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/cpp/utils.py +0 -41
  459. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/generator/gmock_gen.py +0 -31
  460. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/gmock-config.in +0 -303
  461. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/gmock_doctor.py +0 -640
  462. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/upload.py +0 -1387
  463. package/external/rapidjson/thirdparty/gtest/googlemock/scripts/upload_gmock.py +0 -78
  464. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock-all.cc +0 -47
  465. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock-cardinalities.cc +0 -156
  466. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock-internal-utils.cc +0 -204
  467. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock-matchers.cc +0 -573
  468. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock-spec-builders.cc +0 -883
  469. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock.cc +0 -205
  470. package/external/rapidjson/thirdparty/gtest/googlemock/src/gmock_main.cc +0 -54
  471. package/external/rapidjson/thirdparty/gtest/googlemock/test/BUILD.bazel +0 -123
  472. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-actions_test.cc +0 -1575
  473. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-cardinalities_test.cc +0 -428
  474. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-actions_test.cc +0 -1230
  475. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-function-mockers_test.cc +0 -647
  476. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-internal-utils_test.cc +0 -129
  477. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-generated-matchers_test.cc +0 -1341
  478. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-internal-utils_test.cc +0 -718
  479. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-matchers_test.cc +0 -6767
  480. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-more-actions_test.cc +0 -710
  481. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-nice-strict_test.cc +0 -511
  482. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-port_test.cc +0 -43
  483. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock-spec-builders_test.cc +0 -2771
  484. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_all_test.cc +0 -51
  485. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_ex_test.cc +0 -81
  486. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_leak_test.py +0 -108
  487. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_leak_test_.cc +0 -100
  488. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_link2_test.cc +0 -40
  489. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_link_test.cc +0 -40
  490. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_link_test.h +0 -691
  491. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test.py +0 -183
  492. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test_.cc +0 -310
  493. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_output_test_golden.txt +0 -317
  494. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_stress_test.cc +0 -323
  495. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_test.cc +0 -262
  496. package/external/rapidjson/thirdparty/gtest/googlemock/test/gmock_test_utils.py +0 -110
  497. package/external/rapidjson/thirdparty/gtest/googletest/CHANGES +0 -157
  498. package/external/rapidjson/thirdparty/gtest/googletest/CMakeLists.txt +0 -312
  499. package/external/rapidjson/thirdparty/gtest/googletest/CONTRIBUTORS +0 -37
  500. package/external/rapidjson/thirdparty/gtest/googletest/LICENSE +0 -28
  501. package/external/rapidjson/thirdparty/gtest/googletest/Makefile.am +0 -339
  502. package/external/rapidjson/thirdparty/gtest/googletest/README.md +0 -341
  503. package/external/rapidjson/thirdparty/gtest/googletest/cmake/gtest.pc.in +0 -9
  504. package/external/rapidjson/thirdparty/gtest/googletest/cmake/gtest_main.pc.in +0 -10
  505. package/external/rapidjson/thirdparty/gtest/googletest/cmake/internal_utils.cmake +0 -280
  506. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest.cbproj +0 -138
  507. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest.groupproj +0 -54
  508. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest_all.cc +0 -38
  509. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest_link.cc +0 -40
  510. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest_main.cbproj +0 -82
  511. package/external/rapidjson/thirdparty/gtest/googletest/codegear/gtest_unittest.cbproj +0 -88
  512. package/external/rapidjson/thirdparty/gtest/googletest/configure.ac +0 -68
  513. package/external/rapidjson/thirdparty/gtest/googletest/docs/Pkgconfig.md +0 -146
  514. package/external/rapidjson/thirdparty/gtest/googletest/docs/PumpManual.md +0 -177
  515. package/external/rapidjson/thirdparty/gtest/googletest/docs/XcodeGuide.md +0 -93
  516. package/external/rapidjson/thirdparty/gtest/googletest/docs/advanced.md +0 -2416
  517. package/external/rapidjson/thirdparty/gtest/googletest/docs/faq.md +0 -1092
  518. package/external/rapidjson/thirdparty/gtest/googletest/docs/primer.md +0 -536
  519. package/external/rapidjson/thirdparty/gtest/googletest/docs/samples.md +0 -14
  520. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-death-test.h +0 -342
  521. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-message.h +0 -249
  522. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-param-test.h +0 -1438
  523. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-param-test.h.pump +0 -501
  524. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-printers.h +0 -1082
  525. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-spi.h +0 -231
  526. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-test-part.h +0 -179
  527. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest-typed-test.h +0 -264
  528. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest.h +0 -2332
  529. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest_pred_impl.h +0 -357
  530. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/gtest_prod.h +0 -61
  531. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest-port.h +0 -70
  532. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest-printers.h +0 -42
  533. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/custom/gtest.h +0 -45
  534. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-death-test-internal.h +0 -275
  535. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-filepath.h +0 -205
  536. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-internal.h +0 -1277
  537. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-linked_ptr.h +0 -243
  538. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util-generated.h +0 -5139
  539. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util-generated.h.pump +0 -279
  540. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-param-util.h +0 -723
  541. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-port-arch.h +0 -100
  542. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-port.h +0 -2687
  543. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-string.h +0 -167
  544. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-tuple.h +0 -1020
  545. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-tuple.h.pump +0 -347
  546. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-type-util.h +0 -3347
  547. package/external/rapidjson/thirdparty/gtest/googletest/include/gtest/internal/gtest-type-util.h.pump +0 -313
  548. package/external/rapidjson/thirdparty/gtest/googletest/m4/acx_pthread.m4 +0 -363
  549. package/external/rapidjson/thirdparty/gtest/googletest/m4/gtest.m4 +0 -74
  550. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest-md.sln +0 -55
  551. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest-md.vcxproj +0 -149
  552. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest-md.vcxproj.filters +0 -18
  553. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest.sln +0 -55
  554. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest.vcxproj +0 -149
  555. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest.vcxproj.filters +0 -18
  556. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_main-md.vcxproj +0 -154
  557. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_main-md.vcxproj.filters +0 -18
  558. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_main.vcxproj +0 -162
  559. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_main.vcxproj.filters +0 -18
  560. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_prod_test-md.vcxproj +0 -199
  561. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_prod_test-md.vcxproj.filters +0 -26
  562. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_prod_test.vcxproj +0 -191
  563. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_prod_test.vcxproj.filters +0 -26
  564. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_unittest-md.vcxproj +0 -188
  565. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_unittest-md.vcxproj.filters +0 -18
  566. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_unittest.vcxproj +0 -180
  567. package/external/rapidjson/thirdparty/gtest/googletest/msvc/2010/gtest_unittest.vcxproj.filters +0 -18
  568. package/external/rapidjson/thirdparty/gtest/googletest/samples/prime_tables.h +0 -127
  569. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample1.cc +0 -68
  570. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample1.h +0 -43
  571. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample10_unittest.cc +0 -140
  572. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample1_unittest.cc +0 -154
  573. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample2.cc +0 -56
  574. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample2.h +0 -85
  575. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample2_unittest.cc +0 -110
  576. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample3-inl.h +0 -172
  577. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample3_unittest.cc +0 -152
  578. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample4.cc +0 -46
  579. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample4.h +0 -53
  580. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample4_unittest.cc +0 -49
  581. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample5_unittest.cc +0 -199
  582. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample6_unittest.cc +0 -225
  583. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample7_unittest.cc +0 -118
  584. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample8_unittest.cc +0 -174
  585. package/external/rapidjson/thirdparty/gtest/googletest/samples/sample9_unittest.cc +0 -157
  586. package/external/rapidjson/thirdparty/gtest/googletest/scripts/common.py +0 -83
  587. package/external/rapidjson/thirdparty/gtest/googletest/scripts/fuse_gtest_files.py +0 -253
  588. package/external/rapidjson/thirdparty/gtest/googletest/scripts/gen_gtest_pred_impl.py +0 -730
  589. package/external/rapidjson/thirdparty/gtest/googletest/scripts/gtest-config.in +0 -274
  590. package/external/rapidjson/thirdparty/gtest/googletest/scripts/pump.py +0 -855
  591. package/external/rapidjson/thirdparty/gtest/googletest/scripts/release_docs.py +0 -158
  592. package/external/rapidjson/thirdparty/gtest/googletest/scripts/upload.py +0 -1387
  593. package/external/rapidjson/thirdparty/gtest/googletest/scripts/upload_gtest.py +0 -78
  594. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-all.cc +0 -48
  595. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-death-test.cc +0 -1536
  596. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-filepath.cc +0 -385
  597. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-internal-inl.h +0 -1175
  598. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-port.cc +0 -1277
  599. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-printers.cc +0 -458
  600. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-test-part.cc +0 -102
  601. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest-typed-test.cc +0 -119
  602. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest.cc +0 -5846
  603. package/external/rapidjson/thirdparty/gtest/googletest/src/gtest_main.cc +0 -38
  604. package/external/rapidjson/thirdparty/gtest/googletest/test/BUILD.bazel +0 -396
  605. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-death-test_ex_test.cc +0 -93
  606. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-death-test_test.cc +0 -1424
  607. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-filepath_test.cc +0 -652
  608. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-linked_ptr_test.cc +0 -154
  609. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-listener_test.cc +0 -311
  610. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-message_test.cc +0 -159
  611. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-options_test.cc +0 -213
  612. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test2_test.cc +0 -61
  613. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test_test.cc +0 -1110
  614. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-param-test_test.h +0 -53
  615. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-port_test.cc +0 -1303
  616. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-printers_test.cc +0 -1737
  617. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-test-part_test.cc +0 -208
  618. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-tuple_test.cc +0 -320
  619. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test2_test.cc +0 -45
  620. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test_test.cc +0 -380
  621. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-typed-test_test.h +0 -66
  622. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest-unittest-api_test.cc +0 -341
  623. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_all_test.cc +0 -47
  624. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_assert_by_exception_test.cc +0 -119
  625. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_break_on_failure_unittest.py +0 -210
  626. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_break_on_failure_unittest_.cc +0 -87
  627. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_catch_exceptions_test.py +0 -235
  628. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_catch_exceptions_test_.cc +0 -311
  629. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_color_test.py +0 -129
  630. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_color_test_.cc +0 -63
  631. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_env_var_test.py +0 -119
  632. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_env_var_test_.cc +0 -124
  633. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_environment_test.cc +0 -189
  634. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_filter_unittest.py +0 -638
  635. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_filter_unittest_.cc +0 -138
  636. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_help_test.py +0 -172
  637. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_help_test_.cc +0 -46
  638. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_json_outfiles_test.py +0 -162
  639. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_json_output_unittest.py +0 -611
  640. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_json_test_utils.py +0 -60
  641. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_list_tests_unittest.py +0 -207
  642. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_list_tests_unittest_.cc +0 -157
  643. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_main_unittest.cc +0 -45
  644. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_no_test_unittest.cc +0 -56
  645. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test.py +0 -344
  646. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test_.cc +0 -1067
  647. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_output_test_golden_lin.txt +0 -781
  648. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_pred_impl_unittest.cc +0 -2427
  649. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_premature_exit_test.cc +0 -127
  650. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_prod_test.cc +0 -57
  651. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_repeat_test.cc +0 -236
  652. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_shuffle_test.py +0 -325
  653. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_shuffle_test_.cc +0 -103
  654. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_sole_header_test.cc +0 -57
  655. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_stress_test.cc +0 -250
  656. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_test_utils.py +0 -318
  657. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_testbridge_test.py +0 -65
  658. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_testbridge_test_.cc +0 -44
  659. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_ex_test.cc +0 -92
  660. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_test.py +0 -171
  661. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_throw_on_failure_test_.cc +0 -72
  662. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_uninitialized_test.py +0 -69
  663. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_uninitialized_test_.cc +0 -43
  664. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_unittest.cc +0 -7797
  665. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfile1_test_.cc +0 -48
  666. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfile2_test_.cc +0 -48
  667. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_outfiles_test.py +0 -140
  668. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_output_unittest.py +0 -378
  669. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_output_unittest_.cc +0 -179
  670. package/external/rapidjson/thirdparty/gtest/googletest/test/gtest_xml_test_utils.py +0 -196
  671. package/external/rapidjson/thirdparty/gtest/googletest/test/production.cc +0 -36
  672. package/external/rapidjson/thirdparty/gtest/googletest/test/production.h +0 -55
  673. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/DebugProject.xcconfig +0 -30
  674. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/FrameworkTarget.xcconfig +0 -17
  675. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/General.xcconfig +0 -41
  676. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/ReleaseProject.xcconfig +0 -32
  677. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/StaticLibraryTarget.xcconfig +0 -18
  678. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Config/TestTarget.xcconfig +0 -8
  679. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Resources/Info.plist +0 -30
  680. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/Info.plist +0 -28
  681. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/WidgetFramework.xcodeproj/project.pbxproj +0 -457
  682. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/runtests.sh +0 -62
  683. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget.cc +0 -63
  684. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget.h +0 -59
  685. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Samples/FrameworkSample/widget_test.cc +0 -68
  686. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Scripts/runtests.sh +0 -65
  687. package/external/rapidjson/thirdparty/gtest/googletest/xcode/Scripts/versiongenerate.py +0 -100
  688. package/external/rapidjson/thirdparty/gtest/googletest/xcode/gtest.xcodeproj/project.pbxproj +0 -1182
  689. package/external/rapidjson/travis-doxygen.sh +0 -121
  690. package/include/.clang-format +0 -76
  691. package/include/eosio/abi.hpp +0 -286
  692. package/include/eosio/asset.hpp +0 -458
  693. package/include/eosio/bytes.hpp +0 -27
  694. package/include/eosio/chain_conversions.hpp +0 -450
  695. package/include/eosio/chain_types.hpp +0 -14
  696. package/include/eosio/check.hpp +0 -178
  697. package/include/eosio/convert.hpp +0 -95
  698. package/include/eosio/crypto.hpp +0 -147
  699. package/include/eosio/eosio_outcome.hpp +0 -41
  700. package/include/eosio/fixed_bytes.hpp +0 -246
  701. package/include/eosio/float.hpp +0 -35
  702. package/include/eosio/for_each_field.hpp +0 -48
  703. package/include/eosio/fpconv.c +0 -336
  704. package/include/eosio/fpconv.h +0 -41
  705. package/include/eosio/fpconv.license +0 -23
  706. package/include/eosio/from_bin.hpp +0 -272
  707. package/include/eosio/from_json.hpp +0 -737
  708. package/include/eosio/from_string.hpp +0 -28
  709. package/include/eosio/map_macro.h +0 -64
  710. package/include/eosio/murmur.hpp +0 -55
  711. package/include/eosio/name.hpp +0 -174
  712. package/include/eosio/opaque.hpp +0 -108
  713. package/include/eosio/operators.hpp +0 -71
  714. package/include/eosio/powers.h +0 -76
  715. package/include/eosio/reflection.hpp +0 -61
  716. package/include/eosio/ship_protocol.hpp +0 -850
  717. package/include/eosio/stream.hpp +0 -231
  718. package/include/eosio/symbol.hpp +0 -300
  719. package/include/eosio/time.hpp +0 -264
  720. package/include/eosio/to_bin.hpp +0 -189
  721. package/include/eosio/to_json.hpp +0 -279
  722. package/include/eosio/to_key.hpp +0 -298
  723. package/include/eosio/types.hpp +0 -97
  724. package/include/eosio/varint.hpp +0 -452
  725. package/include/outcome-basic.hpp +0 -6836
  726. package/src/abi.cpp +0 -297
  727. package/src/abieos.cpp +0 -263
  728. package/src/abieos.h +0 -76
  729. package/src/abieos.hpp +0 -1010
  730. package/src/abieos_exception.hpp +0 -89
  731. package/src/abieos_numeric.hpp +0 -94
  732. package/src/abieos_ripemd160.hpp +0 -417
  733. package/src/crypto.cpp +0 -215
  734. package/src/key_test.cpp +0 -218
  735. package/src/main.cpp +0 -242
  736. package/src/reflect_test.cpp +0 -28
  737. package/src/template_test.cpp +0 -240
  738. package/src/test.cpp +0 -940
  739. package/tools/CMakeLists.txt +0 -9
  740. package/tools/name.cpp +0 -86
@@ -1,1529 +0,0 @@
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
- #include "unittest.h"
16
- #include "rapidjson/pointer.h"
17
- #include "rapidjson/stringbuffer.h"
18
- #include <sstream>
19
-
20
- using namespace rapidjson;
21
-
22
- static const char kJson[] = "{\n"
23
- " \"foo\":[\"bar\", \"baz\"],\n"
24
- " \"\" : 0,\n"
25
- " \"a/b\" : 1,\n"
26
- " \"c%d\" : 2,\n"
27
- " \"e^f\" : 3,\n"
28
- " \"g|h\" : 4,\n"
29
- " \"i\\\\j\" : 5,\n"
30
- " \"k\\\"l\" : 6,\n"
31
- " \" \" : 7,\n"
32
- " \"m~n\" : 8\n"
33
- "}";
34
-
35
- TEST(Pointer, DefaultConstructor) {
36
- Pointer p;
37
- EXPECT_TRUE(p.IsValid());
38
- EXPECT_EQ(0u, p.GetTokenCount());
39
- }
40
-
41
- TEST(Pointer, Parse) {
42
- {
43
- Pointer p("");
44
- EXPECT_TRUE(p.IsValid());
45
- EXPECT_EQ(0u, p.GetTokenCount());
46
- }
47
-
48
- {
49
- Pointer p("/");
50
- EXPECT_TRUE(p.IsValid());
51
- EXPECT_EQ(1u, p.GetTokenCount());
52
- EXPECT_EQ(0u, p.GetTokens()[0].length);
53
- EXPECT_STREQ("", p.GetTokens()[0].name);
54
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
55
- }
56
-
57
- {
58
- Pointer p("/foo");
59
- EXPECT_TRUE(p.IsValid());
60
- EXPECT_EQ(1u, p.GetTokenCount());
61
- EXPECT_EQ(3u, p.GetTokens()[0].length);
62
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
63
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
64
- }
65
-
66
- #if RAPIDJSON_HAS_STDSTRING
67
- {
68
- Pointer p(std::string("/foo"));
69
- EXPECT_TRUE(p.IsValid());
70
- EXPECT_EQ(1u, p.GetTokenCount());
71
- EXPECT_EQ(3u, p.GetTokens()[0].length);
72
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
73
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
74
- }
75
- #endif
76
-
77
- {
78
- Pointer p("/foo/0");
79
- EXPECT_TRUE(p.IsValid());
80
- EXPECT_EQ(2u, p.GetTokenCount());
81
- EXPECT_EQ(3u, p.GetTokens()[0].length);
82
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
83
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
84
- EXPECT_EQ(1u, p.GetTokens()[1].length);
85
- EXPECT_STREQ("0", p.GetTokens()[1].name);
86
- EXPECT_EQ(0u, p.GetTokens()[1].index);
87
- }
88
-
89
- {
90
- // Unescape ~1
91
- Pointer p("/a~1b");
92
- EXPECT_TRUE(p.IsValid());
93
- EXPECT_EQ(1u, p.GetTokenCount());
94
- EXPECT_EQ(3u, p.GetTokens()[0].length);
95
- EXPECT_STREQ("a/b", p.GetTokens()[0].name);
96
- }
97
-
98
- {
99
- // Unescape ~0
100
- Pointer p("/m~0n");
101
- EXPECT_TRUE(p.IsValid());
102
- EXPECT_EQ(1u, p.GetTokenCount());
103
- EXPECT_EQ(3u, p.GetTokens()[0].length);
104
- EXPECT_STREQ("m~n", p.GetTokens()[0].name);
105
- }
106
-
107
- {
108
- // empty name
109
- Pointer p("/");
110
- EXPECT_TRUE(p.IsValid());
111
- EXPECT_EQ(1u, p.GetTokenCount());
112
- EXPECT_EQ(0u, p.GetTokens()[0].length);
113
- EXPECT_STREQ("", p.GetTokens()[0].name);
114
- }
115
-
116
- {
117
- // empty and non-empty name
118
- Pointer p("//a");
119
- EXPECT_TRUE(p.IsValid());
120
- EXPECT_EQ(2u, p.GetTokenCount());
121
- EXPECT_EQ(0u, p.GetTokens()[0].length);
122
- EXPECT_STREQ("", p.GetTokens()[0].name);
123
- EXPECT_EQ(1u, p.GetTokens()[1].length);
124
- EXPECT_STREQ("a", p.GetTokens()[1].name);
125
- }
126
-
127
- {
128
- // Null characters
129
- Pointer p("/\0\0", 3);
130
- EXPECT_TRUE(p.IsValid());
131
- EXPECT_EQ(1u, p.GetTokenCount());
132
- EXPECT_EQ(2u, p.GetTokens()[0].length);
133
- EXPECT_EQ('\0', p.GetTokens()[0].name[0]);
134
- EXPECT_EQ('\0', p.GetTokens()[0].name[1]);
135
- EXPECT_EQ('\0', p.GetTokens()[0].name[2]);
136
- }
137
-
138
- {
139
- // Valid index
140
- Pointer p("/123");
141
- EXPECT_TRUE(p.IsValid());
142
- EXPECT_EQ(1u, p.GetTokenCount());
143
- EXPECT_STREQ("123", p.GetTokens()[0].name);
144
- EXPECT_EQ(123u, p.GetTokens()[0].index);
145
- }
146
-
147
- {
148
- // Invalid index (with leading zero)
149
- Pointer p("/01");
150
- EXPECT_TRUE(p.IsValid());
151
- EXPECT_EQ(1u, p.GetTokenCount());
152
- EXPECT_STREQ("01", p.GetTokens()[0].name);
153
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
154
- }
155
-
156
- if (sizeof(SizeType) == 4) {
157
- // Invalid index (overflow)
158
- Pointer p("/4294967296");
159
- EXPECT_TRUE(p.IsValid());
160
- EXPECT_EQ(1u, p.GetTokenCount());
161
- EXPECT_STREQ("4294967296", p.GetTokens()[0].name);
162
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
163
- }
164
-
165
- {
166
- // kPointerParseErrorTokenMustBeginWithSolidus
167
- Pointer p(" ");
168
- EXPECT_FALSE(p.IsValid());
169
- EXPECT_EQ(kPointerParseErrorTokenMustBeginWithSolidus, p.GetParseErrorCode());
170
- EXPECT_EQ(0u, p.GetParseErrorOffset());
171
- }
172
-
173
- {
174
- // kPointerParseErrorInvalidEscape
175
- Pointer p("/~");
176
- EXPECT_FALSE(p.IsValid());
177
- EXPECT_EQ(kPointerParseErrorInvalidEscape, p.GetParseErrorCode());
178
- EXPECT_EQ(2u, p.GetParseErrorOffset());
179
- }
180
-
181
- {
182
- // kPointerParseErrorInvalidEscape
183
- Pointer p("/~2");
184
- EXPECT_FALSE(p.IsValid());
185
- EXPECT_EQ(kPointerParseErrorInvalidEscape, p.GetParseErrorCode());
186
- EXPECT_EQ(2u, p.GetParseErrorOffset());
187
- }
188
- }
189
-
190
- TEST(Pointer, Parse_URIFragment) {
191
- {
192
- Pointer p("#");
193
- EXPECT_TRUE(p.IsValid());
194
- EXPECT_EQ(0u, p.GetTokenCount());
195
- }
196
-
197
- {
198
- Pointer p("#/foo");
199
- EXPECT_TRUE(p.IsValid());
200
- EXPECT_EQ(1u, p.GetTokenCount());
201
- EXPECT_EQ(3u, p.GetTokens()[0].length);
202
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
203
- }
204
-
205
- {
206
- Pointer p("#/foo/0");
207
- EXPECT_TRUE(p.IsValid());
208
- EXPECT_EQ(2u, p.GetTokenCount());
209
- EXPECT_EQ(3u, p.GetTokens()[0].length);
210
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
211
- EXPECT_EQ(1u, p.GetTokens()[1].length);
212
- EXPECT_STREQ("0", p.GetTokens()[1].name);
213
- EXPECT_EQ(0u, p.GetTokens()[1].index);
214
- }
215
-
216
- {
217
- // Unescape ~1
218
- Pointer p("#/a~1b");
219
- EXPECT_TRUE(p.IsValid());
220
- EXPECT_EQ(1u, p.GetTokenCount());
221
- EXPECT_EQ(3u, p.GetTokens()[0].length);
222
- EXPECT_STREQ("a/b", p.GetTokens()[0].name);
223
- }
224
-
225
- {
226
- // Unescape ~0
227
- Pointer p("#/m~0n");
228
- EXPECT_TRUE(p.IsValid());
229
- EXPECT_EQ(1u, p.GetTokenCount());
230
- EXPECT_EQ(3u, p.GetTokens()[0].length);
231
- EXPECT_STREQ("m~n", p.GetTokens()[0].name);
232
- }
233
-
234
- {
235
- // empty name
236
- Pointer p("#/");
237
- EXPECT_TRUE(p.IsValid());
238
- EXPECT_EQ(1u, p.GetTokenCount());
239
- EXPECT_EQ(0u, p.GetTokens()[0].length);
240
- EXPECT_STREQ("", p.GetTokens()[0].name);
241
- }
242
-
243
- {
244
- // empty and non-empty name
245
- Pointer p("#//a");
246
- EXPECT_TRUE(p.IsValid());
247
- EXPECT_EQ(2u, p.GetTokenCount());
248
- EXPECT_EQ(0u, p.GetTokens()[0].length);
249
- EXPECT_STREQ("", p.GetTokens()[0].name);
250
- EXPECT_EQ(1u, p.GetTokens()[1].length);
251
- EXPECT_STREQ("a", p.GetTokens()[1].name);
252
- }
253
-
254
- {
255
- // Null characters
256
- Pointer p("#/%00%00");
257
- EXPECT_TRUE(p.IsValid());
258
- EXPECT_EQ(1u, p.GetTokenCount());
259
- EXPECT_EQ(2u, p.GetTokens()[0].length);
260
- EXPECT_EQ('\0', p.GetTokens()[0].name[0]);
261
- EXPECT_EQ('\0', p.GetTokens()[0].name[1]);
262
- EXPECT_EQ('\0', p.GetTokens()[0].name[2]);
263
- }
264
-
265
- {
266
- // Percentage Escapes
267
- EXPECT_STREQ("c%d", Pointer("#/c%25d").GetTokens()[0].name);
268
- EXPECT_STREQ("e^f", Pointer("#/e%5Ef").GetTokens()[0].name);
269
- EXPECT_STREQ("g|h", Pointer("#/g%7Ch").GetTokens()[0].name);
270
- EXPECT_STREQ("i\\j", Pointer("#/i%5Cj").GetTokens()[0].name);
271
- EXPECT_STREQ("k\"l", Pointer("#/k%22l").GetTokens()[0].name);
272
- EXPECT_STREQ(" ", Pointer("#/%20").GetTokens()[0].name);
273
- }
274
-
275
- {
276
- // Valid index
277
- Pointer p("#/123");
278
- EXPECT_TRUE(p.IsValid());
279
- EXPECT_EQ(1u, p.GetTokenCount());
280
- EXPECT_STREQ("123", p.GetTokens()[0].name);
281
- EXPECT_EQ(123u, p.GetTokens()[0].index);
282
- }
283
-
284
- {
285
- // Invalid index (with leading zero)
286
- Pointer p("#/01");
287
- EXPECT_TRUE(p.IsValid());
288
- EXPECT_EQ(1u, p.GetTokenCount());
289
- EXPECT_STREQ("01", p.GetTokens()[0].name);
290
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
291
- }
292
-
293
- if (sizeof(SizeType) == 4) {
294
- // Invalid index (overflow)
295
- Pointer p("#/4294967296");
296
- EXPECT_TRUE(p.IsValid());
297
- EXPECT_EQ(1u, p.GetTokenCount());
298
- EXPECT_STREQ("4294967296", p.GetTokens()[0].name);
299
- EXPECT_EQ(kPointerInvalidIndex, p.GetTokens()[0].index);
300
- }
301
-
302
- {
303
- // Decode UTF-8 perecent encoding to UTF-8
304
- Pointer p("#/%C2%A2");
305
- EXPECT_TRUE(p.IsValid());
306
- EXPECT_EQ(1u, p.GetTokenCount());
307
- EXPECT_STREQ("\xC2\xA2", p.GetTokens()[0].name);
308
- }
309
-
310
- {
311
- // Decode UTF-8 perecent encoding to UTF-16
312
- GenericPointer<GenericValue<UTF16<> > > p(L"#/%C2%A2");
313
- EXPECT_TRUE(p.IsValid());
314
- EXPECT_EQ(1u, p.GetTokenCount());
315
- EXPECT_EQ(static_cast<UTF16<>::Ch>(0x00A2), p.GetTokens()[0].name[0]);
316
- EXPECT_EQ(1u, p.GetTokens()[0].length);
317
- }
318
-
319
- {
320
- // Decode UTF-8 perecent encoding to UTF-16
321
- GenericPointer<GenericValue<UTF16<> > > p(L"#/%E2%82%AC");
322
- EXPECT_TRUE(p.IsValid());
323
- EXPECT_EQ(1u, p.GetTokenCount());
324
- EXPECT_EQ(static_cast<UTF16<>::Ch>(0x20AC), p.GetTokens()[0].name[0]);
325
- EXPECT_EQ(1u, p.GetTokens()[0].length);
326
- }
327
-
328
- {
329
- // kPointerParseErrorTokenMustBeginWithSolidus
330
- Pointer p("# ");
331
- EXPECT_FALSE(p.IsValid());
332
- EXPECT_EQ(kPointerParseErrorTokenMustBeginWithSolidus, p.GetParseErrorCode());
333
- EXPECT_EQ(1u, p.GetParseErrorOffset());
334
- }
335
-
336
- {
337
- // kPointerParseErrorInvalidEscape
338
- Pointer p("#/~");
339
- EXPECT_FALSE(p.IsValid());
340
- EXPECT_EQ(kPointerParseErrorInvalidEscape, p.GetParseErrorCode());
341
- EXPECT_EQ(3u, p.GetParseErrorOffset());
342
- }
343
-
344
- {
345
- // kPointerParseErrorInvalidEscape
346
- Pointer p("#/~2");
347
- EXPECT_FALSE(p.IsValid());
348
- EXPECT_EQ(kPointerParseErrorInvalidEscape, p.GetParseErrorCode());
349
- EXPECT_EQ(3u, p.GetParseErrorOffset());
350
- }
351
-
352
- {
353
- // kPointerParseErrorInvalidPercentEncoding
354
- Pointer p("#/%");
355
- EXPECT_FALSE(p.IsValid());
356
- EXPECT_EQ(kPointerParseErrorInvalidPercentEncoding, p.GetParseErrorCode());
357
- EXPECT_EQ(2u, p.GetParseErrorOffset());
358
- }
359
-
360
- {
361
- // kPointerParseErrorInvalidPercentEncoding (invalid hex)
362
- Pointer p("#/%g0");
363
- EXPECT_FALSE(p.IsValid());
364
- EXPECT_EQ(kPointerParseErrorInvalidPercentEncoding, p.GetParseErrorCode());
365
- EXPECT_EQ(2u, p.GetParseErrorOffset());
366
- }
367
-
368
- {
369
- // kPointerParseErrorInvalidPercentEncoding (invalid hex)
370
- Pointer p("#/%0g");
371
- EXPECT_FALSE(p.IsValid());
372
- EXPECT_EQ(kPointerParseErrorInvalidPercentEncoding, p.GetParseErrorCode());
373
- EXPECT_EQ(2u, p.GetParseErrorOffset());
374
- }
375
-
376
- {
377
- // kPointerParseErrorInvalidPercentEncoding (incomplete UTF-8 sequence)
378
- Pointer p("#/%C2");
379
- EXPECT_FALSE(p.IsValid());
380
- EXPECT_EQ(kPointerParseErrorInvalidPercentEncoding, p.GetParseErrorCode());
381
- EXPECT_EQ(2u, p.GetParseErrorOffset());
382
- }
383
-
384
- {
385
- // kPointerParseErrorCharacterMustPercentEncode
386
- Pointer p("#/ ");
387
- EXPECT_FALSE(p.IsValid());
388
- EXPECT_EQ(kPointerParseErrorCharacterMustPercentEncode, p.GetParseErrorCode());
389
- EXPECT_EQ(2u, p.GetParseErrorOffset());
390
- }
391
-
392
- {
393
- // kPointerParseErrorCharacterMustPercentEncode
394
- Pointer p("#/\n");
395
- EXPECT_FALSE(p.IsValid());
396
- EXPECT_EQ(kPointerParseErrorCharacterMustPercentEncode, p.GetParseErrorCode());
397
- EXPECT_EQ(2u, p.GetParseErrorOffset());
398
- }
399
- }
400
-
401
- TEST(Pointer, Stringify) {
402
- // Test by roundtrip
403
- const char* sources[] = {
404
- "",
405
- "/foo",
406
- "/foo/0",
407
- "/",
408
- "/a~1b",
409
- "/c%d",
410
- "/e^f",
411
- "/g|h",
412
- "/i\\j",
413
- "/k\"l",
414
- "/ ",
415
- "/m~0n",
416
- "/\xC2\xA2",
417
- "/\xE2\x82\xAC",
418
- "/\xF0\x9D\x84\x9E"
419
- };
420
-
421
- for (size_t i = 0; i < sizeof(sources) / sizeof(sources[0]); i++) {
422
- Pointer p(sources[i]);
423
- StringBuffer s;
424
- EXPECT_TRUE(p.Stringify(s));
425
- EXPECT_STREQ(sources[i], s.GetString());
426
-
427
- // Stringify to URI fragment
428
- StringBuffer s2;
429
- EXPECT_TRUE(p.StringifyUriFragment(s2));
430
- Pointer p2(s2.GetString(), s2.GetSize());
431
- EXPECT_TRUE(p2.IsValid());
432
- EXPECT_TRUE(p == p2);
433
- }
434
-
435
- {
436
- // Strigify to URI fragment with an invalid UTF-8 sequence
437
- Pointer p("/\xC2");
438
- StringBuffer s;
439
- EXPECT_FALSE(p.StringifyUriFragment(s));
440
- }
441
- }
442
-
443
- // Construct a Pointer with static tokens, no dynamic allocation involved.
444
- #define NAME(s) { s, static_cast<SizeType>(sizeof(s) / sizeof(s[0]) - 1), kPointerInvalidIndex }
445
- #define INDEX(i) { #i, static_cast<SizeType>(sizeof(#i) - 1), i }
446
-
447
- static const Pointer::Token kTokens[] = { NAME("foo"), INDEX(0) }; // equivalent to "/foo/0"
448
-
449
- #undef NAME
450
- #undef INDEX
451
-
452
- TEST(Pointer, ConstructorWithToken) {
453
- Pointer p(kTokens, sizeof(kTokens) / sizeof(kTokens[0]));
454
- EXPECT_TRUE(p.IsValid());
455
- EXPECT_EQ(2u, p.GetTokenCount());
456
- EXPECT_EQ(3u, p.GetTokens()[0].length);
457
- EXPECT_STREQ("foo", p.GetTokens()[0].name);
458
- EXPECT_EQ(1u, p.GetTokens()[1].length);
459
- EXPECT_STREQ("0", p.GetTokens()[1].name);
460
- EXPECT_EQ(0u, p.GetTokens()[1].index);
461
- }
462
-
463
- TEST(Pointer, CopyConstructor) {
464
- {
465
- CrtAllocator allocator;
466
- Pointer p("/foo/0", &allocator);
467
- Pointer q(p);
468
- EXPECT_TRUE(q.IsValid());
469
- EXPECT_EQ(2u, q.GetTokenCount());
470
- EXPECT_EQ(3u, q.GetTokens()[0].length);
471
- EXPECT_STREQ("foo", q.GetTokens()[0].name);
472
- EXPECT_EQ(1u, q.GetTokens()[1].length);
473
- EXPECT_STREQ("0", q.GetTokens()[1].name);
474
- EXPECT_EQ(0u, q.GetTokens()[1].index);
475
- EXPECT_EQ(&p.GetAllocator(), &q.GetAllocator());
476
- }
477
-
478
- // Static tokens
479
- {
480
- Pointer p(kTokens, sizeof(kTokens) / sizeof(kTokens[0]));
481
- Pointer q(p);
482
- EXPECT_TRUE(q.IsValid());
483
- EXPECT_EQ(2u, q.GetTokenCount());
484
- EXPECT_EQ(3u, q.GetTokens()[0].length);
485
- EXPECT_STREQ("foo", q.GetTokens()[0].name);
486
- EXPECT_EQ(1u, q.GetTokens()[1].length);
487
- EXPECT_STREQ("0", q.GetTokens()[1].name);
488
- EXPECT_EQ(0u, q.GetTokens()[1].index);
489
- }
490
- }
491
-
492
- TEST(Pointer, Assignment) {
493
- {
494
- CrtAllocator allocator;
495
- Pointer p("/foo/0", &allocator);
496
- Pointer q;
497
- q = p;
498
- EXPECT_TRUE(q.IsValid());
499
- EXPECT_EQ(2u, q.GetTokenCount());
500
- EXPECT_EQ(3u, q.GetTokens()[0].length);
501
- EXPECT_STREQ("foo", q.GetTokens()[0].name);
502
- EXPECT_EQ(1u, q.GetTokens()[1].length);
503
- EXPECT_STREQ("0", q.GetTokens()[1].name);
504
- EXPECT_EQ(0u, q.GetTokens()[1].index);
505
- EXPECT_NE(&p.GetAllocator(), &q.GetAllocator());
506
- q = q;
507
- EXPECT_TRUE(q.IsValid());
508
- EXPECT_EQ(2u, q.GetTokenCount());
509
- EXPECT_EQ(3u, q.GetTokens()[0].length);
510
- EXPECT_STREQ("foo", q.GetTokens()[0].name);
511
- EXPECT_EQ(1u, q.GetTokens()[1].length);
512
- EXPECT_STREQ("0", q.GetTokens()[1].name);
513
- EXPECT_EQ(0u, q.GetTokens()[1].index);
514
- EXPECT_NE(&p.GetAllocator(), &q.GetAllocator());
515
- }
516
-
517
- // Static tokens
518
- {
519
- Pointer p(kTokens, sizeof(kTokens) / sizeof(kTokens[0]));
520
- Pointer q;
521
- q = p;
522
- EXPECT_TRUE(q.IsValid());
523
- EXPECT_EQ(2u, q.GetTokenCount());
524
- EXPECT_EQ(3u, q.GetTokens()[0].length);
525
- EXPECT_STREQ("foo", q.GetTokens()[0].name);
526
- EXPECT_EQ(1u, q.GetTokens()[1].length);
527
- EXPECT_STREQ("0", q.GetTokens()[1].name);
528
- EXPECT_EQ(0u, q.GetTokens()[1].index);
529
- }
530
- }
531
-
532
- TEST(Pointer, Append) {
533
- {
534
- Pointer p;
535
- Pointer q = p.Append("foo");
536
- EXPECT_TRUE(Pointer("/foo") == q);
537
- q = q.Append(1234);
538
- EXPECT_TRUE(Pointer("/foo/1234") == q);
539
- q = q.Append("");
540
- EXPECT_TRUE(Pointer("/foo/1234/") == q);
541
- }
542
-
543
- {
544
- Pointer p;
545
- Pointer q = p.Append(Value("foo").Move());
546
- EXPECT_TRUE(Pointer("/foo") == q);
547
- q = q.Append(Value(1234).Move());
548
- EXPECT_TRUE(Pointer("/foo/1234") == q);
549
- q = q.Append(Value(kStringType).Move());
550
- EXPECT_TRUE(Pointer("/foo/1234/") == q);
551
- }
552
-
553
- #if RAPIDJSON_HAS_STDSTRING
554
- {
555
- Pointer p;
556
- Pointer q = p.Append(std::string("foo"));
557
- EXPECT_TRUE(Pointer("/foo") == q);
558
- }
559
- #endif
560
- }
561
-
562
- TEST(Pointer, Equality) {
563
- EXPECT_TRUE(Pointer("/foo/0") == Pointer("/foo/0"));
564
- EXPECT_FALSE(Pointer("/foo/0") == Pointer("/foo/1"));
565
- EXPECT_FALSE(Pointer("/foo/0") == Pointer("/foo/0/1"));
566
- EXPECT_FALSE(Pointer("/foo/0") == Pointer("a"));
567
- EXPECT_FALSE(Pointer("a") == Pointer("a")); // Invalid always not equal
568
- }
569
-
570
- TEST(Pointer, Inequality) {
571
- EXPECT_FALSE(Pointer("/foo/0") != Pointer("/foo/0"));
572
- EXPECT_TRUE(Pointer("/foo/0") != Pointer("/foo/1"));
573
- EXPECT_TRUE(Pointer("/foo/0") != Pointer("/foo/0/1"));
574
- EXPECT_TRUE(Pointer("/foo/0") != Pointer("a"));
575
- EXPECT_TRUE(Pointer("a") != Pointer("a")); // Invalid always not equal
576
- }
577
-
578
- TEST(Pointer, Create) {
579
- Document d;
580
- {
581
- Value* v = &Pointer("").Create(d, d.GetAllocator());
582
- EXPECT_EQ(&d, v);
583
- }
584
- {
585
- Value* v = &Pointer("/foo").Create(d, d.GetAllocator());
586
- EXPECT_EQ(&d["foo"], v);
587
- }
588
- {
589
- Value* v = &Pointer("/foo/0").Create(d, d.GetAllocator());
590
- EXPECT_EQ(&d["foo"][0], v);
591
- }
592
- {
593
- Value* v = &Pointer("/foo/-").Create(d, d.GetAllocator());
594
- EXPECT_EQ(&d["foo"][1], v);
595
- }
596
-
597
- {
598
- Value* v = &Pointer("/foo/-/-").Create(d, d.GetAllocator());
599
- // "foo/-" is a newly created null value x.
600
- // "foo/-/-" finds that x is not an array, it converts x to empty object
601
- // and treats - as "-" member name
602
- EXPECT_EQ(&d["foo"][2]["-"], v);
603
- }
604
-
605
- {
606
- // Document with no allocator
607
- Value* v = &Pointer("/foo/-").Create(d);
608
- EXPECT_EQ(&d["foo"][3], v);
609
- }
610
-
611
- {
612
- // Value (not document) must give allocator
613
- Value* v = &Pointer("/-").Create(d["foo"], d.GetAllocator());
614
- EXPECT_EQ(&d["foo"][4], v);
615
- }
616
- }
617
-
618
- TEST(Pointer, Get) {
619
- Document d;
620
- d.Parse(kJson);
621
-
622
- EXPECT_EQ(&d, Pointer("").Get(d));
623
- EXPECT_EQ(&d["foo"], Pointer("/foo").Get(d));
624
- EXPECT_EQ(&d["foo"][0], Pointer("/foo/0").Get(d));
625
- EXPECT_EQ(&d[""], Pointer("/").Get(d));
626
- EXPECT_EQ(&d["a/b"], Pointer("/a~1b").Get(d));
627
- EXPECT_EQ(&d["c%d"], Pointer("/c%d").Get(d));
628
- EXPECT_EQ(&d["e^f"], Pointer("/e^f").Get(d));
629
- EXPECT_EQ(&d["g|h"], Pointer("/g|h").Get(d));
630
- EXPECT_EQ(&d["i\\j"], Pointer("/i\\j").Get(d));
631
- EXPECT_EQ(&d["k\"l"], Pointer("/k\"l").Get(d));
632
- EXPECT_EQ(&d[" "], Pointer("/ ").Get(d));
633
- EXPECT_EQ(&d["m~n"], Pointer("/m~0n").Get(d));
634
- EXPECT_TRUE(Pointer("/abc").Get(d) == 0);
635
- size_t unresolvedTokenIndex;
636
- EXPECT_TRUE(Pointer("/foo/2").Get(d, &unresolvedTokenIndex) == 0); // Out of boundary
637
- EXPECT_EQ(1u, unresolvedTokenIndex);
638
- EXPECT_TRUE(Pointer("/foo/a").Get(d, &unresolvedTokenIndex) == 0); // "/foo" is an array, cannot query by "a"
639
- EXPECT_EQ(1u, unresolvedTokenIndex);
640
- EXPECT_TRUE(Pointer("/foo/0/0").Get(d, &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
641
- EXPECT_EQ(2u, unresolvedTokenIndex);
642
- EXPECT_TRUE(Pointer("/foo/0/a").Get(d, &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
643
- EXPECT_EQ(2u, unresolvedTokenIndex);
644
- }
645
-
646
- TEST(Pointer, GetWithDefault) {
647
- Document d;
648
- d.Parse(kJson);
649
-
650
- // Value version
651
- Document::AllocatorType& a = d.GetAllocator();
652
- const Value v("qux");
653
- EXPECT_TRUE(Value("bar") == Pointer("/foo/0").GetWithDefault(d, v, a));
654
- EXPECT_TRUE(Value("baz") == Pointer("/foo/1").GetWithDefault(d, v, a));
655
- EXPECT_TRUE(Value("qux") == Pointer("/foo/2").GetWithDefault(d, v, a));
656
- EXPECT_TRUE(Value("last") == Pointer("/foo/-").GetWithDefault(d, Value("last").Move(), a));
657
- EXPECT_STREQ("last", d["foo"][3].GetString());
658
-
659
- EXPECT_TRUE(Pointer("/foo/null").GetWithDefault(d, Value().Move(), a).IsNull());
660
- EXPECT_TRUE(Pointer("/foo/null").GetWithDefault(d, "x", a).IsNull());
661
-
662
- // Generic version
663
- EXPECT_EQ(-1, Pointer("/foo/int").GetWithDefault(d, -1, a).GetInt());
664
- EXPECT_EQ(-1, Pointer("/foo/int").GetWithDefault(d, -2, a).GetInt());
665
- EXPECT_EQ(0x87654321, Pointer("/foo/uint").GetWithDefault(d, 0x87654321, a).GetUint());
666
- EXPECT_EQ(0x87654321, Pointer("/foo/uint").GetWithDefault(d, 0x12345678, a).GetUint());
667
-
668
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
669
- EXPECT_EQ(i64, Pointer("/foo/int64").GetWithDefault(d, i64, a).GetInt64());
670
- EXPECT_EQ(i64, Pointer("/foo/int64").GetWithDefault(d, i64 + 1, a).GetInt64());
671
-
672
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
673
- EXPECT_EQ(u64, Pointer("/foo/uint64").GetWithDefault(d, u64, a).GetUint64());
674
- EXPECT_EQ(u64, Pointer("/foo/uint64").GetWithDefault(d, u64 - 1, a).GetUint64());
675
-
676
- EXPECT_TRUE(Pointer("/foo/true").GetWithDefault(d, true, a).IsTrue());
677
- EXPECT_TRUE(Pointer("/foo/true").GetWithDefault(d, false, a).IsTrue());
678
-
679
- EXPECT_TRUE(Pointer("/foo/false").GetWithDefault(d, false, a).IsFalse());
680
- EXPECT_TRUE(Pointer("/foo/false").GetWithDefault(d, true, a).IsFalse());
681
-
682
- // StringRef version
683
- EXPECT_STREQ("Hello", Pointer("/foo/hello").GetWithDefault(d, "Hello", a).GetString());
684
-
685
- // Copy string version
686
- {
687
- char buffer[256];
688
- strcpy(buffer, "World");
689
- EXPECT_STREQ("World", Pointer("/foo/world").GetWithDefault(d, buffer, a).GetString());
690
- memset(buffer, 0, sizeof(buffer));
691
- }
692
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
693
-
694
- #if RAPIDJSON_HAS_STDSTRING
695
- EXPECT_STREQ("C++", Pointer("/foo/C++").GetWithDefault(d, std::string("C++"), a).GetString());
696
- #endif
697
- }
698
-
699
- TEST(Pointer, GetWithDefault_NoAllocator) {
700
- Document d;
701
- d.Parse(kJson);
702
-
703
- // Value version
704
- const Value v("qux");
705
- EXPECT_TRUE(Value("bar") == Pointer("/foo/0").GetWithDefault(d, v));
706
- EXPECT_TRUE(Value("baz") == Pointer("/foo/1").GetWithDefault(d, v));
707
- EXPECT_TRUE(Value("qux") == Pointer("/foo/2").GetWithDefault(d, v));
708
- EXPECT_TRUE(Value("last") == Pointer("/foo/-").GetWithDefault(d, Value("last").Move()));
709
- EXPECT_STREQ("last", d["foo"][3].GetString());
710
-
711
- EXPECT_TRUE(Pointer("/foo/null").GetWithDefault(d, Value().Move()).IsNull());
712
- EXPECT_TRUE(Pointer("/foo/null").GetWithDefault(d, "x").IsNull());
713
-
714
- // Generic version
715
- EXPECT_EQ(-1, Pointer("/foo/int").GetWithDefault(d, -1).GetInt());
716
- EXPECT_EQ(-1, Pointer("/foo/int").GetWithDefault(d, -2).GetInt());
717
- EXPECT_EQ(0x87654321, Pointer("/foo/uint").GetWithDefault(d, 0x87654321).GetUint());
718
- EXPECT_EQ(0x87654321, Pointer("/foo/uint").GetWithDefault(d, 0x12345678).GetUint());
719
-
720
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
721
- EXPECT_EQ(i64, Pointer("/foo/int64").GetWithDefault(d, i64).GetInt64());
722
- EXPECT_EQ(i64, Pointer("/foo/int64").GetWithDefault(d, i64 + 1).GetInt64());
723
-
724
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
725
- EXPECT_EQ(u64, Pointer("/foo/uint64").GetWithDefault(d, u64).GetUint64());
726
- EXPECT_EQ(u64, Pointer("/foo/uint64").GetWithDefault(d, u64 - 1).GetUint64());
727
-
728
- EXPECT_TRUE(Pointer("/foo/true").GetWithDefault(d, true).IsTrue());
729
- EXPECT_TRUE(Pointer("/foo/true").GetWithDefault(d, false).IsTrue());
730
-
731
- EXPECT_TRUE(Pointer("/foo/false").GetWithDefault(d, false).IsFalse());
732
- EXPECT_TRUE(Pointer("/foo/false").GetWithDefault(d, true).IsFalse());
733
-
734
- // StringRef version
735
- EXPECT_STREQ("Hello", Pointer("/foo/hello").GetWithDefault(d, "Hello").GetString());
736
-
737
- // Copy string version
738
- {
739
- char buffer[256];
740
- strcpy(buffer, "World");
741
- EXPECT_STREQ("World", Pointer("/foo/world").GetWithDefault(d, buffer).GetString());
742
- memset(buffer, 0, sizeof(buffer));
743
- }
744
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
745
-
746
- #if RAPIDJSON_HAS_STDSTRING
747
- EXPECT_STREQ("C++", Pointer("/foo/C++").GetWithDefault(d, std::string("C++")).GetString());
748
- #endif
749
- }
750
-
751
- TEST(Pointer, Set) {
752
- Document d;
753
- d.Parse(kJson);
754
- Document::AllocatorType& a = d.GetAllocator();
755
-
756
- // Value version
757
- Pointer("/foo/0").Set(d, Value(123).Move(), a);
758
- EXPECT_EQ(123, d["foo"][0].GetInt());
759
-
760
- Pointer("/foo/-").Set(d, Value(456).Move(), a);
761
- EXPECT_EQ(456, d["foo"][2].GetInt());
762
-
763
- Pointer("/foo/null").Set(d, Value().Move(), a);
764
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
765
-
766
- // Const Value version
767
- const Value foo(d["foo"], a);
768
- Pointer("/clone").Set(d, foo, a);
769
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
770
-
771
- // Generic version
772
- Pointer("/foo/int").Set(d, -1, a);
773
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
774
-
775
- Pointer("/foo/uint").Set(d, 0x87654321, a);
776
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
777
-
778
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
779
- Pointer("/foo/int64").Set(d, i64, a);
780
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
781
-
782
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
783
- Pointer("/foo/uint64").Set(d, u64, a);
784
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
785
-
786
- Pointer("/foo/true").Set(d, true, a);
787
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
788
-
789
- Pointer("/foo/false").Set(d, false, a);
790
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
791
-
792
- // StringRef version
793
- Pointer("/foo/hello").Set(d, "Hello", a);
794
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
795
-
796
- // Copy string version
797
- {
798
- char buffer[256];
799
- strcpy(buffer, "World");
800
- Pointer("/foo/world").Set(d, buffer, a);
801
- memset(buffer, 0, sizeof(buffer));
802
- }
803
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
804
-
805
- #if RAPIDJSON_HAS_STDSTRING
806
- Pointer("/foo/c++").Set(d, std::string("C++"), a);
807
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
808
- #endif
809
- }
810
-
811
- TEST(Pointer, Set_NoAllocator) {
812
- Document d;
813
- d.Parse(kJson);
814
-
815
- // Value version
816
- Pointer("/foo/0").Set(d, Value(123).Move());
817
- EXPECT_EQ(123, d["foo"][0].GetInt());
818
-
819
- Pointer("/foo/-").Set(d, Value(456).Move());
820
- EXPECT_EQ(456, d["foo"][2].GetInt());
821
-
822
- Pointer("/foo/null").Set(d, Value().Move());
823
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
824
-
825
- // Const Value version
826
- const Value foo(d["foo"], d.GetAllocator());
827
- Pointer("/clone").Set(d, foo);
828
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
829
-
830
- // Generic version
831
- Pointer("/foo/int").Set(d, -1);
832
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
833
-
834
- Pointer("/foo/uint").Set(d, 0x87654321);
835
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
836
-
837
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
838
- Pointer("/foo/int64").Set(d, i64);
839
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
840
-
841
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
842
- Pointer("/foo/uint64").Set(d, u64);
843
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
844
-
845
- Pointer("/foo/true").Set(d, true);
846
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
847
-
848
- Pointer("/foo/false").Set(d, false);
849
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
850
-
851
- // StringRef version
852
- Pointer("/foo/hello").Set(d, "Hello");
853
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
854
-
855
- // Copy string version
856
- {
857
- char buffer[256];
858
- strcpy(buffer, "World");
859
- Pointer("/foo/world").Set(d, buffer);
860
- memset(buffer, 0, sizeof(buffer));
861
- }
862
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
863
-
864
- #if RAPIDJSON_HAS_STDSTRING
865
- Pointer("/foo/c++").Set(d, std::string("C++"));
866
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
867
- #endif
868
- }
869
-
870
- TEST(Pointer, Swap) {
871
- Document d;
872
- d.Parse(kJson);
873
- Document::AllocatorType& a = d.GetAllocator();
874
- Pointer("/foo/0").Swap(d, *Pointer("/foo/1").Get(d), a);
875
- EXPECT_STREQ("baz", d["foo"][0].GetString());
876
- EXPECT_STREQ("bar", d["foo"][1].GetString());
877
- }
878
-
879
- TEST(Pointer, Swap_NoAllocator) {
880
- Document d;
881
- d.Parse(kJson);
882
- Pointer("/foo/0").Swap(d, *Pointer("/foo/1").Get(d));
883
- EXPECT_STREQ("baz", d["foo"][0].GetString());
884
- EXPECT_STREQ("bar", d["foo"][1].GetString());
885
- }
886
-
887
- TEST(Pointer, Erase) {
888
- Document d;
889
- d.Parse(kJson);
890
-
891
- EXPECT_FALSE(Pointer("").Erase(d));
892
- EXPECT_FALSE(Pointer("/nonexist").Erase(d));
893
- EXPECT_FALSE(Pointer("/nonexist/nonexist").Erase(d));
894
- EXPECT_FALSE(Pointer("/foo/nonexist").Erase(d));
895
- EXPECT_FALSE(Pointer("/foo/nonexist/nonexist").Erase(d));
896
- EXPECT_FALSE(Pointer("/foo/0/nonexist").Erase(d));
897
- EXPECT_FALSE(Pointer("/foo/0/nonexist/nonexist").Erase(d));
898
- EXPECT_FALSE(Pointer("/foo/2/nonexist").Erase(d));
899
- EXPECT_TRUE(Pointer("/foo/0").Erase(d));
900
- EXPECT_EQ(1u, d["foo"].Size());
901
- EXPECT_STREQ("baz", d["foo"][0].GetString());
902
- EXPECT_TRUE(Pointer("/foo/0").Erase(d));
903
- EXPECT_TRUE(d["foo"].Empty());
904
- EXPECT_TRUE(Pointer("/foo").Erase(d));
905
- EXPECT_TRUE(Pointer("/foo").Get(d) == 0);
906
-
907
- Pointer("/a/0/b/0").Create(d);
908
-
909
- EXPECT_TRUE(Pointer("/a/0/b/0").Get(d) != 0);
910
- EXPECT_TRUE(Pointer("/a/0/b/0").Erase(d));
911
- EXPECT_TRUE(Pointer("/a/0/b/0").Get(d) == 0);
912
-
913
- EXPECT_TRUE(Pointer("/a/0/b").Get(d) != 0);
914
- EXPECT_TRUE(Pointer("/a/0/b").Erase(d));
915
- EXPECT_TRUE(Pointer("/a/0/b").Get(d) == 0);
916
-
917
- EXPECT_TRUE(Pointer("/a/0").Get(d) != 0);
918
- EXPECT_TRUE(Pointer("/a/0").Erase(d));
919
- EXPECT_TRUE(Pointer("/a/0").Get(d) == 0);
920
-
921
- EXPECT_TRUE(Pointer("/a").Get(d) != 0);
922
- EXPECT_TRUE(Pointer("/a").Erase(d));
923
- EXPECT_TRUE(Pointer("/a").Get(d) == 0);
924
- }
925
-
926
- TEST(Pointer, CreateValueByPointer) {
927
- Document d;
928
- Document::AllocatorType& a = d.GetAllocator();
929
-
930
- {
931
- Value& v = CreateValueByPointer(d, Pointer("/foo/0"), a);
932
- EXPECT_EQ(&d["foo"][0], &v);
933
- }
934
- {
935
- Value& v = CreateValueByPointer(d, "/foo/1", a);
936
- EXPECT_EQ(&d["foo"][1], &v);
937
- }
938
- }
939
-
940
- TEST(Pointer, CreateValueByPointer_NoAllocator) {
941
- Document d;
942
-
943
- {
944
- Value& v = CreateValueByPointer(d, Pointer("/foo/0"));
945
- EXPECT_EQ(&d["foo"][0], &v);
946
- }
947
- {
948
- Value& v = CreateValueByPointer(d, "/foo/1");
949
- EXPECT_EQ(&d["foo"][1], &v);
950
- }
951
- }
952
-
953
- TEST(Pointer, GetValueByPointer) {
954
- Document d;
955
- d.Parse(kJson);
956
-
957
- EXPECT_EQ(&d["foo"][0], GetValueByPointer(d, Pointer("/foo/0")));
958
- EXPECT_EQ(&d["foo"][0], GetValueByPointer(d, "/foo/0"));
959
-
960
- size_t unresolvedTokenIndex;
961
- EXPECT_TRUE(GetValueByPointer(d, "/foo/2", &unresolvedTokenIndex) == 0); // Out of boundary
962
- EXPECT_EQ(1u, unresolvedTokenIndex);
963
- EXPECT_TRUE(GetValueByPointer(d, "/foo/a", &unresolvedTokenIndex) == 0); // "/foo" is an array, cannot query by "a"
964
- EXPECT_EQ(1u, unresolvedTokenIndex);
965
- EXPECT_TRUE(GetValueByPointer(d, "/foo/0/0", &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
966
- EXPECT_EQ(2u, unresolvedTokenIndex);
967
- EXPECT_TRUE(GetValueByPointer(d, "/foo/0/a", &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
968
- EXPECT_EQ(2u, unresolvedTokenIndex);
969
-
970
- // const version
971
- const Value& v = d;
972
- EXPECT_EQ(&d["foo"][0], GetValueByPointer(v, Pointer("/foo/0")));
973
- EXPECT_EQ(&d["foo"][0], GetValueByPointer(v, "/foo/0"));
974
-
975
- EXPECT_TRUE(GetValueByPointer(v, "/foo/2", &unresolvedTokenIndex) == 0); // Out of boundary
976
- EXPECT_EQ(1u, unresolvedTokenIndex);
977
- EXPECT_TRUE(GetValueByPointer(v, "/foo/a", &unresolvedTokenIndex) == 0); // "/foo" is an array, cannot query by "a"
978
- EXPECT_EQ(1u, unresolvedTokenIndex);
979
- EXPECT_TRUE(GetValueByPointer(v, "/foo/0/0", &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
980
- EXPECT_EQ(2u, unresolvedTokenIndex);
981
- EXPECT_TRUE(GetValueByPointer(v, "/foo/0/a", &unresolvedTokenIndex) == 0); // "/foo/0" is an string, cannot further query
982
- EXPECT_EQ(2u, unresolvedTokenIndex);
983
-
984
- }
985
-
986
- TEST(Pointer, GetValueByPointerWithDefault_Pointer) {
987
- Document d;
988
- d.Parse(kJson);
989
-
990
- Document::AllocatorType& a = d.GetAllocator();
991
- const Value v("qux");
992
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, Pointer("/foo/0"), v, a));
993
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, Pointer("/foo/0"), v, a));
994
- EXPECT_TRUE(Value("baz") == GetValueByPointerWithDefault(d, Pointer("/foo/1"), v, a));
995
- EXPECT_TRUE(Value("qux") == GetValueByPointerWithDefault(d, Pointer("/foo/2"), v, a));
996
- EXPECT_TRUE(Value("last") == GetValueByPointerWithDefault(d, Pointer("/foo/-"), Value("last").Move(), a));
997
- EXPECT_STREQ("last", d["foo"][3].GetString());
998
-
999
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/null"), Value().Move(), a).IsNull());
1000
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/null"), "x", a).IsNull());
1001
-
1002
- // Generic version
1003
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, Pointer("/foo/int"), -1, a).GetInt());
1004
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, Pointer("/foo/int"), -2, a).GetInt());
1005
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, Pointer("/foo/uint"), 0x87654321, a).GetUint());
1006
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, Pointer("/foo/uint"), 0x12345678, a).GetUint());
1007
-
1008
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1009
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, Pointer("/foo/int64"), i64, a).GetInt64());
1010
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, Pointer("/foo/int64"), i64 + 1, a).GetInt64());
1011
-
1012
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1013
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, Pointer("/foo/uint64"), u64, a).GetUint64());
1014
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, Pointer("/foo/uint64"), u64 - 1, a).GetUint64());
1015
-
1016
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/true"), true, a).IsTrue());
1017
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/true"), false, a).IsTrue());
1018
-
1019
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/false"), false, a).IsFalse());
1020
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/false"), true, a).IsFalse());
1021
-
1022
- // StringRef version
1023
- EXPECT_STREQ("Hello", GetValueByPointerWithDefault(d, Pointer("/foo/hello"), "Hello", a).GetString());
1024
-
1025
- // Copy string version
1026
- {
1027
- char buffer[256];
1028
- strcpy(buffer, "World");
1029
- EXPECT_STREQ("World", GetValueByPointerWithDefault(d, Pointer("/foo/world"), buffer, a).GetString());
1030
- memset(buffer, 0, sizeof(buffer));
1031
- }
1032
- EXPECT_STREQ("World", GetValueByPointer(d, Pointer("/foo/world"))->GetString());
1033
-
1034
- #if RAPIDJSON_HAS_STDSTRING
1035
- EXPECT_STREQ("C++", GetValueByPointerWithDefault(d, Pointer("/foo/C++"), std::string("C++"), a).GetString());
1036
- #endif
1037
- }
1038
-
1039
- TEST(Pointer, GetValueByPointerWithDefault_String) {
1040
- Document d;
1041
- d.Parse(kJson);
1042
-
1043
- Document::AllocatorType& a = d.GetAllocator();
1044
- const Value v("qux");
1045
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, "/foo/0", v, a));
1046
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, "/foo/0", v, a));
1047
- EXPECT_TRUE(Value("baz") == GetValueByPointerWithDefault(d, "/foo/1", v, a));
1048
- EXPECT_TRUE(Value("qux") == GetValueByPointerWithDefault(d, "/foo/2", v, a));
1049
- EXPECT_TRUE(Value("last") == GetValueByPointerWithDefault(d, "/foo/-", Value("last").Move(), a));
1050
- EXPECT_STREQ("last", d["foo"][3].GetString());
1051
-
1052
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/null", Value().Move(), a).IsNull());
1053
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/null", "x", a).IsNull());
1054
-
1055
- // Generic version
1056
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, "/foo/int", -1, a).GetInt());
1057
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, "/foo/int", -2, a).GetInt());
1058
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, "/foo/uint", 0x87654321, a).GetUint());
1059
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, "/foo/uint", 0x12345678, a).GetUint());
1060
-
1061
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1062
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, "/foo/int64", i64, a).GetInt64());
1063
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, "/foo/int64", i64 + 1, a).GetInt64());
1064
-
1065
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1066
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, "/foo/uint64", u64, a).GetUint64());
1067
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, "/foo/uint64", u64 - 1, a).GetUint64());
1068
-
1069
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/true", true, a).IsTrue());
1070
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/true", false, a).IsTrue());
1071
-
1072
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/false", false, a).IsFalse());
1073
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/false", true, a).IsFalse());
1074
-
1075
- // StringRef version
1076
- EXPECT_STREQ("Hello", GetValueByPointerWithDefault(d, "/foo/hello", "Hello", a).GetString());
1077
-
1078
- // Copy string version
1079
- {
1080
- char buffer[256];
1081
- strcpy(buffer, "World");
1082
- EXPECT_STREQ("World", GetValueByPointerWithDefault(d, "/foo/world", buffer, a).GetString());
1083
- memset(buffer, 0, sizeof(buffer));
1084
- }
1085
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1086
-
1087
- #if RAPIDJSON_HAS_STDSTRING
1088
- EXPECT_STREQ("C++", GetValueByPointerWithDefault(d, "/foo/C++", std::string("C++"), a).GetString());
1089
- #endif
1090
- }
1091
-
1092
- TEST(Pointer, GetValueByPointerWithDefault_Pointer_NoAllocator) {
1093
- Document d;
1094
- d.Parse(kJson);
1095
-
1096
- const Value v("qux");
1097
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, Pointer("/foo/0"), v));
1098
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, Pointer("/foo/0"), v));
1099
- EXPECT_TRUE(Value("baz") == GetValueByPointerWithDefault(d, Pointer("/foo/1"), v));
1100
- EXPECT_TRUE(Value("qux") == GetValueByPointerWithDefault(d, Pointer("/foo/2"), v));
1101
- EXPECT_TRUE(Value("last") == GetValueByPointerWithDefault(d, Pointer("/foo/-"), Value("last").Move()));
1102
- EXPECT_STREQ("last", d["foo"][3].GetString());
1103
-
1104
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/null"), Value().Move()).IsNull());
1105
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/null"), "x").IsNull());
1106
-
1107
- // Generic version
1108
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, Pointer("/foo/int"), -1).GetInt());
1109
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, Pointer("/foo/int"), -2).GetInt());
1110
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, Pointer("/foo/uint"), 0x87654321).GetUint());
1111
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, Pointer("/foo/uint"), 0x12345678).GetUint());
1112
-
1113
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1114
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, Pointer("/foo/int64"), i64).GetInt64());
1115
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, Pointer("/foo/int64"), i64 + 1).GetInt64());
1116
-
1117
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1118
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, Pointer("/foo/uint64"), u64).GetUint64());
1119
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, Pointer("/foo/uint64"), u64 - 1).GetUint64());
1120
-
1121
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/true"), true).IsTrue());
1122
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/true"), false).IsTrue());
1123
-
1124
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/false"), false).IsFalse());
1125
- EXPECT_TRUE(GetValueByPointerWithDefault(d, Pointer("/foo/false"), true).IsFalse());
1126
-
1127
- // StringRef version
1128
- EXPECT_STREQ("Hello", GetValueByPointerWithDefault(d, Pointer("/foo/hello"), "Hello").GetString());
1129
-
1130
- // Copy string version
1131
- {
1132
- char buffer[256];
1133
- strcpy(buffer, "World");
1134
- EXPECT_STREQ("World", GetValueByPointerWithDefault(d, Pointer("/foo/world"), buffer).GetString());
1135
- memset(buffer, 0, sizeof(buffer));
1136
- }
1137
- EXPECT_STREQ("World", GetValueByPointer(d, Pointer("/foo/world"))->GetString());
1138
-
1139
- #if RAPIDJSON_HAS_STDSTRING
1140
- EXPECT_STREQ("C++", GetValueByPointerWithDefault(d, Pointer("/foo/C++"), std::string("C++")).GetString());
1141
- #endif
1142
- }
1143
-
1144
- TEST(Pointer, GetValueByPointerWithDefault_String_NoAllocator) {
1145
- Document d;
1146
- d.Parse(kJson);
1147
-
1148
- const Value v("qux");
1149
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, "/foo/0", v));
1150
- EXPECT_TRUE(Value("bar") == GetValueByPointerWithDefault(d, "/foo/0", v));
1151
- EXPECT_TRUE(Value("baz") == GetValueByPointerWithDefault(d, "/foo/1", v));
1152
- EXPECT_TRUE(Value("qux") == GetValueByPointerWithDefault(d, "/foo/2", v));
1153
- EXPECT_TRUE(Value("last") == GetValueByPointerWithDefault(d, "/foo/-", Value("last").Move()));
1154
- EXPECT_STREQ("last", d["foo"][3].GetString());
1155
-
1156
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/null", Value().Move()).IsNull());
1157
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/null", "x").IsNull());
1158
-
1159
- // Generic version
1160
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, "/foo/int", -1).GetInt());
1161
- EXPECT_EQ(-1, GetValueByPointerWithDefault(d, "/foo/int", -2).GetInt());
1162
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, "/foo/uint", 0x87654321).GetUint());
1163
- EXPECT_EQ(0x87654321, GetValueByPointerWithDefault(d, "/foo/uint", 0x12345678).GetUint());
1164
-
1165
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1166
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, "/foo/int64", i64).GetInt64());
1167
- EXPECT_EQ(i64, GetValueByPointerWithDefault(d, "/foo/int64", i64 + 1).GetInt64());
1168
-
1169
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1170
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, "/foo/uint64", u64).GetUint64());
1171
- EXPECT_EQ(u64, GetValueByPointerWithDefault(d, "/foo/uint64", u64 - 1).GetUint64());
1172
-
1173
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/true", true).IsTrue());
1174
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/true", false).IsTrue());
1175
-
1176
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/false", false).IsFalse());
1177
- EXPECT_TRUE(GetValueByPointerWithDefault(d, "/foo/false", true).IsFalse());
1178
-
1179
- // StringRef version
1180
- EXPECT_STREQ("Hello", GetValueByPointerWithDefault(d, "/foo/hello", "Hello").GetString());
1181
-
1182
- // Copy string version
1183
- {
1184
- char buffer[256];
1185
- strcpy(buffer, "World");
1186
- EXPECT_STREQ("World", GetValueByPointerWithDefault(d, "/foo/world", buffer).GetString());
1187
- memset(buffer, 0, sizeof(buffer));
1188
- }
1189
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1190
-
1191
- #if RAPIDJSON_HAS_STDSTRING
1192
- EXPECT_STREQ("C++", GetValueByPointerWithDefault(d, Pointer("/foo/C++"), std::string("C++")).GetString());
1193
- #endif
1194
- }
1195
-
1196
- TEST(Pointer, SetValueByPointer_Pointer) {
1197
- Document d;
1198
- d.Parse(kJson);
1199
- Document::AllocatorType& a = d.GetAllocator();
1200
-
1201
- // Value version
1202
- SetValueByPointer(d, Pointer("/foo/0"), Value(123).Move(), a);
1203
- EXPECT_EQ(123, d["foo"][0].GetInt());
1204
-
1205
- SetValueByPointer(d, Pointer("/foo/null"), Value().Move(), a);
1206
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
1207
-
1208
- // Const Value version
1209
- const Value foo(d["foo"], d.GetAllocator());
1210
- SetValueByPointer(d, Pointer("/clone"), foo, a);
1211
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
1212
-
1213
- // Generic version
1214
- SetValueByPointer(d, Pointer("/foo/int"), -1, a);
1215
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
1216
-
1217
- SetValueByPointer(d, Pointer("/foo/uint"), 0x87654321, a);
1218
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
1219
-
1220
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1221
- SetValueByPointer(d, Pointer("/foo/int64"), i64, a);
1222
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
1223
-
1224
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1225
- SetValueByPointer(d, Pointer("/foo/uint64"), u64, a);
1226
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
1227
-
1228
- SetValueByPointer(d, Pointer("/foo/true"), true, a);
1229
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
1230
-
1231
- SetValueByPointer(d, Pointer("/foo/false"), false, a);
1232
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
1233
-
1234
- // StringRef version
1235
- SetValueByPointer(d, Pointer("/foo/hello"), "Hello", a);
1236
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
1237
-
1238
- // Copy string version
1239
- {
1240
- char buffer[256];
1241
- strcpy(buffer, "World");
1242
- SetValueByPointer(d, Pointer("/foo/world"), buffer, a);
1243
- memset(buffer, 0, sizeof(buffer));
1244
- }
1245
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1246
-
1247
- #if RAPIDJSON_HAS_STDSTRING
1248
- SetValueByPointer(d, Pointer("/foo/c++"), std::string("C++"), a);
1249
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
1250
- #endif
1251
- }
1252
-
1253
- TEST(Pointer, SetValueByPointer_String) {
1254
- Document d;
1255
- d.Parse(kJson);
1256
- Document::AllocatorType& a = d.GetAllocator();
1257
-
1258
- // Value version
1259
- SetValueByPointer(d, "/foo/0", Value(123).Move(), a);
1260
- EXPECT_EQ(123, d["foo"][0].GetInt());
1261
-
1262
- SetValueByPointer(d, "/foo/null", Value().Move(), a);
1263
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
1264
-
1265
- // Const Value version
1266
- const Value foo(d["foo"], d.GetAllocator());
1267
- SetValueByPointer(d, "/clone", foo, a);
1268
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
1269
-
1270
- // Generic version
1271
- SetValueByPointer(d, "/foo/int", -1, a);
1272
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
1273
-
1274
- SetValueByPointer(d, "/foo/uint", 0x87654321, a);
1275
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
1276
-
1277
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1278
- SetValueByPointer(d, "/foo/int64", i64, a);
1279
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
1280
-
1281
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1282
- SetValueByPointer(d, "/foo/uint64", u64, a);
1283
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
1284
-
1285
- SetValueByPointer(d, "/foo/true", true, a);
1286
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
1287
-
1288
- SetValueByPointer(d, "/foo/false", false, a);
1289
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
1290
-
1291
- // StringRef version
1292
- SetValueByPointer(d, "/foo/hello", "Hello", a);
1293
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
1294
-
1295
- // Copy string version
1296
- {
1297
- char buffer[256];
1298
- strcpy(buffer, "World");
1299
- SetValueByPointer(d, "/foo/world", buffer, a);
1300
- memset(buffer, 0, sizeof(buffer));
1301
- }
1302
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1303
-
1304
- #if RAPIDJSON_HAS_STDSTRING
1305
- SetValueByPointer(d, "/foo/c++", std::string("C++"), a);
1306
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
1307
- #endif
1308
- }
1309
-
1310
- TEST(Pointer, SetValueByPointer_Pointer_NoAllocator) {
1311
- Document d;
1312
- d.Parse(kJson);
1313
-
1314
- // Value version
1315
- SetValueByPointer(d, Pointer("/foo/0"), Value(123).Move());
1316
- EXPECT_EQ(123, d["foo"][0].GetInt());
1317
-
1318
- SetValueByPointer(d, Pointer("/foo/null"), Value().Move());
1319
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
1320
-
1321
- // Const Value version
1322
- const Value foo(d["foo"], d.GetAllocator());
1323
- SetValueByPointer(d, Pointer("/clone"), foo);
1324
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
1325
-
1326
- // Generic version
1327
- SetValueByPointer(d, Pointer("/foo/int"), -1);
1328
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
1329
-
1330
- SetValueByPointer(d, Pointer("/foo/uint"), 0x87654321);
1331
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
1332
-
1333
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1334
- SetValueByPointer(d, Pointer("/foo/int64"), i64);
1335
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
1336
-
1337
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1338
- SetValueByPointer(d, Pointer("/foo/uint64"), u64);
1339
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
1340
-
1341
- SetValueByPointer(d, Pointer("/foo/true"), true);
1342
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
1343
-
1344
- SetValueByPointer(d, Pointer("/foo/false"), false);
1345
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
1346
-
1347
- // StringRef version
1348
- SetValueByPointer(d, Pointer("/foo/hello"), "Hello");
1349
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
1350
-
1351
- // Copy string version
1352
- {
1353
- char buffer[256];
1354
- strcpy(buffer, "World");
1355
- SetValueByPointer(d, Pointer("/foo/world"), buffer);
1356
- memset(buffer, 0, sizeof(buffer));
1357
- }
1358
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1359
-
1360
- #if RAPIDJSON_HAS_STDSTRING
1361
- SetValueByPointer(d, Pointer("/foo/c++"), std::string("C++"));
1362
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
1363
- #endif
1364
- }
1365
-
1366
- TEST(Pointer, SetValueByPointer_String_NoAllocator) {
1367
- Document d;
1368
- d.Parse(kJson);
1369
-
1370
- // Value version
1371
- SetValueByPointer(d, "/foo/0", Value(123).Move());
1372
- EXPECT_EQ(123, d["foo"][0].GetInt());
1373
-
1374
- SetValueByPointer(d, "/foo/null", Value().Move());
1375
- EXPECT_TRUE(GetValueByPointer(d, "/foo/null")->IsNull());
1376
-
1377
- // Const Value version
1378
- const Value foo(d["foo"], d.GetAllocator());
1379
- SetValueByPointer(d, "/clone", foo);
1380
- EXPECT_EQ(foo, *GetValueByPointer(d, "/clone"));
1381
-
1382
- // Generic version
1383
- SetValueByPointer(d, "/foo/int", -1);
1384
- EXPECT_EQ(-1, GetValueByPointer(d, "/foo/int")->GetInt());
1385
-
1386
- SetValueByPointer(d, "/foo/uint", 0x87654321);
1387
- EXPECT_EQ(0x87654321, GetValueByPointer(d, "/foo/uint")->GetUint());
1388
-
1389
- const int64_t i64 = static_cast<int64_t>(RAPIDJSON_UINT64_C2(0x80000000, 0));
1390
- SetValueByPointer(d, "/foo/int64", i64);
1391
- EXPECT_EQ(i64, GetValueByPointer(d, "/foo/int64")->GetInt64());
1392
-
1393
- const uint64_t u64 = RAPIDJSON_UINT64_C2(0xFFFFFFFFF, 0xFFFFFFFFF);
1394
- SetValueByPointer(d, "/foo/uint64", u64);
1395
- EXPECT_EQ(u64, GetValueByPointer(d, "/foo/uint64")->GetUint64());
1396
-
1397
- SetValueByPointer(d, "/foo/true", true);
1398
- EXPECT_TRUE(GetValueByPointer(d, "/foo/true")->IsTrue());
1399
-
1400
- SetValueByPointer(d, "/foo/false", false);
1401
- EXPECT_TRUE(GetValueByPointer(d, "/foo/false")->IsFalse());
1402
-
1403
- // StringRef version
1404
- SetValueByPointer(d, "/foo/hello", "Hello");
1405
- EXPECT_STREQ("Hello", GetValueByPointer(d, "/foo/hello")->GetString());
1406
-
1407
- // Copy string version
1408
- {
1409
- char buffer[256];
1410
- strcpy(buffer, "World");
1411
- SetValueByPointer(d, "/foo/world", buffer);
1412
- memset(buffer, 0, sizeof(buffer));
1413
- }
1414
- EXPECT_STREQ("World", GetValueByPointer(d, "/foo/world")->GetString());
1415
-
1416
- #if RAPIDJSON_HAS_STDSTRING
1417
- SetValueByPointer(d, "/foo/c++", std::string("C++"));
1418
- EXPECT_STREQ("C++", GetValueByPointer(d, "/foo/c++")->GetString());
1419
- #endif
1420
- }
1421
-
1422
- TEST(Pointer, SwapValueByPointer) {
1423
- Document d;
1424
- d.Parse(kJson);
1425
- Document::AllocatorType& a = d.GetAllocator();
1426
- SwapValueByPointer(d, Pointer("/foo/0"), *GetValueByPointer(d, "/foo/1"), a);
1427
- EXPECT_STREQ("baz", d["foo"][0].GetString());
1428
- EXPECT_STREQ("bar", d["foo"][1].GetString());
1429
-
1430
- SwapValueByPointer(d, "/foo/0", *GetValueByPointer(d, "/foo/1"), a);
1431
- EXPECT_STREQ("bar", d["foo"][0].GetString());
1432
- EXPECT_STREQ("baz", d["foo"][1].GetString());
1433
- }
1434
-
1435
- TEST(Pointer, SwapValueByPointer_NoAllocator) {
1436
- Document d;
1437
- d.Parse(kJson);
1438
- SwapValueByPointer(d, Pointer("/foo/0"), *GetValueByPointer(d, "/foo/1"));
1439
- EXPECT_STREQ("baz", d["foo"][0].GetString());
1440
- EXPECT_STREQ("bar", d["foo"][1].GetString());
1441
-
1442
- SwapValueByPointer(d, "/foo/0", *GetValueByPointer(d, "/foo/1"));
1443
- EXPECT_STREQ("bar", d["foo"][0].GetString());
1444
- EXPECT_STREQ("baz", d["foo"][1].GetString());
1445
- }
1446
-
1447
- TEST(Pointer, EraseValueByPointer_Pointer) {
1448
- Document d;
1449
- d.Parse(kJson);
1450
-
1451
- EXPECT_FALSE(EraseValueByPointer(d, Pointer("")));
1452
- EXPECT_FALSE(Pointer("/foo/nonexist").Erase(d));
1453
- EXPECT_TRUE(EraseValueByPointer(d, Pointer("/foo/0")));
1454
- EXPECT_EQ(1u, d["foo"].Size());
1455
- EXPECT_STREQ("baz", d["foo"][0].GetString());
1456
- EXPECT_TRUE(EraseValueByPointer(d, Pointer("/foo/0")));
1457
- EXPECT_TRUE(d["foo"].Empty());
1458
- EXPECT_TRUE(EraseValueByPointer(d, Pointer("/foo")));
1459
- EXPECT_TRUE(Pointer("/foo").Get(d) == 0);
1460
- }
1461
-
1462
- TEST(Pointer, EraseValueByPointer_String) {
1463
- Document d;
1464
- d.Parse(kJson);
1465
-
1466
- EXPECT_FALSE(EraseValueByPointer(d, ""));
1467
- EXPECT_FALSE(Pointer("/foo/nonexist").Erase(d));
1468
- EXPECT_TRUE(EraseValueByPointer(d, "/foo/0"));
1469
- EXPECT_EQ(1u, d["foo"].Size());
1470
- EXPECT_STREQ("baz", d["foo"][0].GetString());
1471
- EXPECT_TRUE(EraseValueByPointer(d, "/foo/0"));
1472
- EXPECT_TRUE(d["foo"].Empty());
1473
- EXPECT_TRUE(EraseValueByPointer(d, "/foo"));
1474
- EXPECT_TRUE(Pointer("/foo").Get(d) == 0);
1475
- }
1476
-
1477
- TEST(Pointer, Ambiguity) {
1478
- {
1479
- Document d;
1480
- d.Parse("{\"0\" : [123]}");
1481
- EXPECT_EQ(123, Pointer("/0/0").Get(d)->GetInt());
1482
- Pointer("/0/a").Set(d, 456); // Change array [123] to object {456}
1483
- EXPECT_EQ(456, Pointer("/0/a").Get(d)->GetInt());
1484
- }
1485
-
1486
- {
1487
- Document d;
1488
- EXPECT_FALSE(d.Parse("[{\"0\": 123}]").HasParseError());
1489
- EXPECT_EQ(123, Pointer("/0/0").Get(d)->GetInt());
1490
- Pointer("/0/1").Set(d, 456); // 1 is treated as "1" to index object
1491
- EXPECT_EQ(123, Pointer("/0/0").Get(d)->GetInt());
1492
- EXPECT_EQ(456, Pointer("/0/1").Get(d)->GetInt());
1493
- }
1494
- }
1495
-
1496
- // https://github.com/Tencent/rapidjson/issues/483
1497
- namespace myjson {
1498
-
1499
- class MyAllocator
1500
- {
1501
- public:
1502
- static const bool kNeedFree = true;
1503
- void * Malloc(size_t _size) { return malloc(_size); }
1504
- void * Realloc(void *_org_p, size_t _org_size, size_t _new_size) { (void)_org_size; return realloc(_org_p, _new_size); }
1505
- static void Free(void *_p) { return free(_p); }
1506
- };
1507
-
1508
- typedef rapidjson::GenericDocument<
1509
- rapidjson::UTF8<>,
1510
- rapidjson::MemoryPoolAllocator< MyAllocator >,
1511
- MyAllocator
1512
- > Document;
1513
-
1514
- typedef rapidjson::GenericPointer<
1515
- ::myjson::Document::ValueType,
1516
- MyAllocator
1517
- > Pointer;
1518
-
1519
- typedef ::myjson::Document::ValueType Value;
1520
-
1521
- }
1522
-
1523
- TEST(Pointer, Issue483) {
1524
- std::string mystr, path;
1525
- myjson::Document document;
1526
- myjson::Value value(rapidjson::kStringType);
1527
- value.SetString(mystr.c_str(), static_cast<SizeType>(mystr.length()), document.GetAllocator());
1528
- myjson::Pointer(path.c_str()).Set(document, value, document.GetAllocator());
1529
- }