forked from bblanchon/ArduinoJson
Compare commits
1401 Commits
v4.0
...
variant-im
Author | SHA1 | Date | |
---|---|---|---|
908a69213c | |||
242d3f2f35 | |||
be1e33f5ff | |||
cd2a4296af | |||
462fab6f01 | |||
2feb07dc15 | |||
7f0cca379a | |||
434e90025d | |||
19d2a8c555 | |||
29a1c5732f | |||
943f22d8f9 | |||
733bc4ee82 | |||
9aa77994b4 | |||
f051f8328d | |||
411424b74e | |||
5e5c287978 | |||
377cf63075 | |||
3252013509 | |||
deab127a2f | |||
96281de682 | |||
f0e84e4933 | |||
91397f9f06 | |||
7f75985e47 | |||
05b68fc7cc | |||
b06cee8f4d | |||
e03d8ae885 | |||
cb1dcfa5e4 | |||
67dd3120e6 | |||
9f3cf04415 | |||
01e49b33b7 | |||
8f7e793f37 | |||
254fa5712a | |||
de05814294 | |||
e33e78d202 | |||
ed5f890d28 | |||
8931651317 | |||
c078957282 | |||
cf084ae6b4 | |||
f02fcc96a2 | |||
594dc707cb | |||
5f8e3c0f0f | |||
afc0a29c2c | |||
a256ec7fff | |||
019e8326b7 | |||
bee1095042 | |||
de59dce527 | |||
57a9c50b38 | |||
5e7653b36a | |||
8110058729 | |||
7946ebe1a3 | |||
f9fe8557f1 | |||
e007d71b4f | |||
67a512a923 | |||
9cf4f3871d | |||
31253dbe13 | |||
1110d62128 | |||
c6c0649d70 | |||
61ec2c4f95 | |||
0dd6231b3f | |||
20219d74f0 | |||
64cbaa6ff7 | |||
2512993617 | |||
48ee4a178b | |||
cd4b2b2463 | |||
f806a42cc2 | |||
c1a507c158 | |||
a1809d0f31 | |||
d92eee8736 | |||
dd1d96e28f | |||
3b64197869 | |||
1f7a3f3174 | |||
fd6314e132 | |||
e4e2557b76 | |||
3b6bf45b8a | |||
65ba36622c | |||
33452c1f37 | |||
ee02c0d573 | |||
0278e94fce | |||
7643dadaec | |||
c0bebe35f1 | |||
b5bcb37657 | |||
b4a5b053ca | |||
e297932a98 | |||
e682337655 | |||
4ada3f849c | |||
5dd203bca4 | |||
362201241f | |||
2be24eded8 | |||
4327f72140 | |||
f7f1b9745d | |||
cec18177b0 | |||
f2894552f2 | |||
d3721cb122 | |||
ab72bb8601 | |||
09c89dcacf | |||
a2b09bfbd2 | |||
386105be90 | |||
83516e1740 | |||
bf99aeedb1 | |||
22dd4da3af | |||
55c3b9b3a7 | |||
d83515dcda | |||
e34c27723a | |||
b23ff65b99 | |||
556785dc1e | |||
e9c87858d1 | |||
208e7a3304 | |||
45611924f3 | |||
5b88b2c1f6 | |||
e4f3fd8c91 | |||
aec642be20 | |||
5a60c55be7 | |||
f99b2d63f9 | |||
1db803bcd3 | |||
04326d2655 | |||
9e0c56acc3 | |||
60f9f7eff6 | |||
0fe202af03 | |||
c41e8cc634 | |||
d486157a9e | |||
91aad55412 | |||
98fca74f66 | |||
60fb268d9a | |||
f1899d3049 | |||
4b779a7c1d | |||
5d1aa04e21 | |||
2f6db1edb0 | |||
aeb30ef307 | |||
1c5e5db071 | |||
68a13117dc | |||
071f718473 | |||
00949f8276 | |||
2c670e0148 | |||
002b07f0c5 | |||
5f5f927693 | |||
4d074840da | |||
82de20ee14 | |||
ece4d030a8 | |||
4d5c17b5f6 | |||
18a9a5b590 | |||
cd4bf33132 | |||
2cfefe22ac | |||
0d43e51d48 | |||
ef28064317 | |||
7c62cdb264 | |||
0ab4bdd691 | |||
af8c615266 | |||
bd13375729 | |||
5f8502ce9d | |||
1404b1ef70 | |||
36e1eecc7d | |||
ca2f80aeaf | |||
f17fc055d3 | |||
04ac53d114 | |||
483a2c9101 | |||
848c0cdc7e | |||
46a807bd30 | |||
cb0dc94db4 | |||
72642e3090 | |||
c98b05e207 | |||
2a87cc5839 | |||
296fe79bfd | |||
650d537b5d | |||
0435945a62 | |||
844a50296f | |||
1b143d383b | |||
94783fdd2a | |||
e41d5d4fa1 | |||
5dfa25d3dc | |||
a7bfc2212c | |||
315cc722e9 | |||
ca0dda7ac1 | |||
08cac13c43 | |||
44d2d47863 | |||
3571db6290 | |||
cc42373367 | |||
9dc43d14f3 | |||
3fa6b6e04f | |||
2d47b3931d | |||
0e8a236583 | |||
955815fbfa | |||
4cd03fbd26 | |||
f7dcea562f | |||
4774ca3d29 | |||
26b2ff4c0f | |||
7e6b89d21f | |||
d20e64187b | |||
86e06c901f | |||
6fe4b9c01d | |||
9b34069a3b | |||
30ea01bc31 | |||
92c9faf69f | |||
b20653ee1a | |||
750d53f8c7 | |||
7bd2ea1072 | |||
51c5f1a73a | |||
ac9b74df65 | |||
305e80c09d | |||
fc1f06822c | |||
a8c763c40e | |||
7ab6fc078c | |||
c98ba999af | |||
1d583f68da | |||
e93fd7657f | |||
78399c2d78 | |||
8cc645c40c | |||
11373af344 | |||
53d54ba9d7 | |||
2f31c932d7 | |||
93cb3d2fdc | |||
be5d5300a2 | |||
ea5b019552 | |||
bc6707b10c | |||
adea7f4131 | |||
7f459adc4b | |||
cdc1262127 | |||
f422b7b37d | |||
7a587ac2e2 | |||
38941d5807 | |||
57454cf97b | |||
af6954c224 | |||
3003756adb | |||
218a12ca46 | |||
752d01a7f1 | |||
43eed00cd9 | |||
bc8ea36781 | |||
8fb187baed | |||
db5b5f9ee2 | |||
9122d87f12 | |||
9a11d98117 | |||
30ec507989 | |||
7a76da3bc7 | |||
a8329564e2 | |||
00c9d8680a | |||
2fdacb1ca0 | |||
228c4cf9fa | |||
9d2d257851 | |||
5458e916ea | |||
1a14499612 | |||
f427706e06 | |||
8be0d57d24 | |||
8fcaebb44a | |||
bd2d232b40 | |||
b69a952e69 | |||
727a1013ca | |||
781e449e78 | |||
d4af8cffa7 | |||
0f3c73a211 | |||
0f319e7ca4 | |||
42b2840009 | |||
65c67d317a | |||
c4e5051a7a | |||
068c40d6ed | |||
c203c86a42 | |||
8aec448adf | |||
9538bc32af | |||
b2aa0029b9 | |||
57e9134540 | |||
fb4cb96c6c | |||
5e3f84c718 | |||
64922343e6 | |||
1d07abddcd | |||
21bf4973de | |||
da845ae01d | |||
5a9d3422f5 | |||
7a9feb4d6e | |||
39e8b63746 | |||
c37990d791 | |||
fac5b5a7a7 | |||
5ceb5d1813 | |||
ec4c73db0b | |||
f86b22cf4f | |||
78a74c4017 | |||
dae0182914 | |||
0f511b873d | |||
1d96826371 | |||
f6b014582f | |||
555f3dd5fe | |||
04973ca494 | |||
01b9b40bd2 | |||
c8517ee5b6 | |||
23b01a89b1 | |||
688e21e75f | |||
d921cd6d02 | |||
af8bdfbc8f | |||
68b1602c35 | |||
7bc73d7849 | |||
67bbb4c90d | |||
fffed4fba6 | |||
8d7bbffe10 | |||
488475fe16 | |||
ba8d102432 | |||
e96680eb29 | |||
4c0fb4eb55 | |||
db2fb01795 | |||
18ae8ab7b9 | |||
87c96f9306 | |||
262747b419 | |||
3e0ba2028c | |||
972f665b07 | |||
519e32badb | |||
d90b36c009 | |||
8147625921 | |||
2cf7fc5427 | |||
4871380060 | |||
2a663db3c7 | |||
437307a955 | |||
56b3b4d5a9 | |||
f5355a9eb5 | |||
779ee07de9 | |||
ab4e8547cb | |||
585795d002 | |||
68a167b167 | |||
78d4f721ff | |||
a97bcb6b2d | |||
2da1f2553d | |||
c267b55dec | |||
3a73ccf027 | |||
8ab45e6f82 | |||
da45c4bc4f | |||
48acf963fb | |||
ccccd1da11 | |||
78a30496be | |||
636c8c36eb | |||
5070fa6562 | |||
d9e035a288 | |||
aba8974148 | |||
044a4753d2 | |||
ff0deee793 | |||
37357086e2 | |||
9321f8fdab | |||
167ea08c53 | |||
5c0338970c | |||
6b4dd3ff2f | |||
fead19560c | |||
86772d33bc | |||
a035116018 | |||
806fa907ab | |||
95f5d9d134 | |||
03139a08af | |||
acfbf26e37 | |||
461cdaa818 | |||
dd46813dc0 | |||
5d796781fb | |||
f5e7570f84 | |||
003087406c | |||
b7c8e0d25c | |||
30c111fd3d | |||
9d0714efdf | |||
d8f3058efa | |||
7c0fa7c276 | |||
6eb4f45fb9 | |||
b3132cac3a | |||
d95a3bd19a | |||
22e4f216c3 | |||
e9850152a7 | |||
5e0e35615c | |||
c4b879645a | |||
6afa6b647c | |||
acd465b365 | |||
e858570afb | |||
0643c2e708 | |||
bcf1339e89 | |||
dc463a2f72 | |||
a7cdf638e7 | |||
57810af2ac | |||
2eb726b744 | |||
912137ccfb | |||
035c913c72 | |||
3f43c2b816 | |||
0328f66340 | |||
b3eada9c7f | |||
8516b368ad | |||
d0fff5a0b5 | |||
4c8d4b4e20 | |||
5faa3df43f | |||
540901e219 | |||
db9258bcd7 | |||
24aaab6e3e | |||
17a482a9b1 | |||
5edd435fe9 | |||
de9239caab | |||
c89a2025ce | |||
42ae8c3037 | |||
319ececf26 | |||
886254c41e | |||
4e7099dc73 | |||
26948cb83a | |||
0f8698e655 | |||
b2b995edb3 | |||
33a4773fbd | |||
daa87e12dc | |||
5abf512276 | |||
0dd4a68913 | |||
8971127b66 | |||
1b66a217bf | |||
34dd46110b | |||
8f7211a50f | |||
2be4ee732a | |||
3bdedc9a2f | |||
f699954f4d | |||
407fc2cd45 | |||
91fe6dcae8 | |||
62dea9d364 | |||
e0bdc4bff1 | |||
007b4f3362 | |||
94b2b3f9ce | |||
c2de812cbd | |||
669ee4dfe3 | |||
e054cba610 | |||
3d8287265c | |||
de7afc2015 | |||
ae0499fd57 | |||
b33966c755 | |||
d2cd13bf2e | |||
06b2263329 | |||
d4bb839ce9 | |||
6013a1a56f | |||
34b38e07c7 | |||
1ec16ca94f | |||
b350a96643 | |||
bf93779b4f | |||
dd0f7019ef | |||
175e5b3062 | |||
7885155634 | |||
1909ffe0f9 | |||
3345255f16 | |||
c49adfd6da | |||
5094b84a46 | |||
191fc5dff4 | |||
cb9c90f2d0 | |||
09f9bd6b8b | |||
67abbef818 | |||
7ed2559e9e | |||
ac8e5f01db | |||
396d2a7b3b | |||
de725e0a4e | |||
2a32803e9e | |||
d602232b9f | |||
b0730f04f7 | |||
ef8ed28aec | |||
b8eff868e6 | |||
d0b619ea93 | |||
652d70fe2c | |||
8228aec74b | |||
2f2e0e9415 | |||
3a9803679f | |||
dc42d93b0f | |||
dff07ebfe8 | |||
4c456a95a3 | |||
83e5d9d150 | |||
7079aa99d7 | |||
208a22e324 | |||
9afae963e8 | |||
1828dec658 | |||
afe2434baf | |||
e08f8d5b51 | |||
7e3b40f379 | |||
584770dc6f | |||
5d2a440c69 | |||
ac14f29e6c | |||
3d62fa8af2 | |||
0f85a55cac | |||
21db92af47 | |||
6447520b5b | |||
079ccadbee | |||
615f675840 | |||
2182c83b87 | |||
b8d1dccb21 | |||
c3d5e9382d | |||
ecb72f9a9d | |||
7004c39af6 | |||
057956225c | |||
b27990f780 | |||
61c6f8ba59 | |||
d8d37ba7ad | |||
92d6bae25c | |||
6e17c3e6f9 | |||
8ee67b0229 | |||
07b9153ae4 | |||
abfcac4674 | |||
cde8cd50f8 | |||
cf4436e581 | |||
2b6bb78a09 | |||
ffa7f8d22d | |||
f73be9cf0f | |||
8002722f3b | |||
62e83133cd | |||
1d21027e2a | |||
5705247e5f | |||
dde9e9fc26 | |||
a6da4ad452 | |||
e2a29eef24 | |||
043ee651a9 | |||
84b7037b3e | |||
c5838a876b | |||
750cd0be92 | |||
758580bfb6 | |||
04872b6db8 | |||
58c7c919f2 | |||
cd8373ad32 | |||
3b3ab8c4e1 | |||
5b06b1564e | |||
77b4270d97 | |||
7c2ca773ff | |||
e2bb2cec7b | |||
ff4e837df5 | |||
fb904033d3 | |||
e6cd16aec4 | |||
ee74c3bb1c | |||
37faa7ce13 | |||
3d6c328a4f | |||
5577d18377 | |||
1d103a1528 | |||
7b19a4b6e7 | |||
ac1d29fac0 | |||
98037e5742 | |||
d0e3808dd0 | |||
3760a643cb | |||
fc9d8aa31e | |||
ccfbb5fd1d | |||
c9fbc5e40a | |||
67b6797b6d | |||
8d9504239b | |||
bf5d0c790c | |||
f4379f97ae | |||
3dc67c5663 | |||
47f90b02c3 | |||
27c924746b | |||
7abf875071 | |||
e3e375f5cd | |||
ff06292d74 | |||
c1278797f2 | |||
421ecec0dd | |||
89ed54362b | |||
986f77fa15 | |||
f831ed395d | |||
a880614a75 | |||
ef8379df1b | |||
702f8c2e2f | |||
6806393285 | |||
dea8387586 | |||
6ea2815341 | |||
3c145f1782 | |||
21b2c76524 | |||
4f6244eef4 | |||
973858b835 | |||
ee12155617 | |||
4b4c68df5f | |||
fcae33d574 | |||
896f50eeb9 | |||
9693fd2d74 | |||
37f1c87338 | |||
4977de38fc | |||
9f4750637b | |||
0c65e13aa3 | |||
af18994deb | |||
8f9599cd19 | |||
78660c6e07 | |||
4f786db82d | |||
ad7b749dec | |||
29ba744d64 | |||
a2e1021d7d | |||
d20c3c65c8 | |||
8f029e6096 | |||
91ed68b4a6 | |||
67fc2d9897 | |||
055304bf01 | |||
c2800ace32 | |||
ec7ffa20f2 | |||
ada1f2a894 | |||
184a7c4fbd | |||
84e9447f12 | |||
ca073fda46 | |||
0f529a3587 | |||
e16767af92 | |||
3166356484 | |||
abdd9d81db | |||
3bf47761c8 | |||
f39d8f548f | |||
90d750e4d9 | |||
ca24ed48f5 | |||
51937778dd | |||
be70f6ddd7 | |||
a27398e445 | |||
43b2e2e774 | |||
62f9b94ab1 | |||
b06bbd9d2a | |||
2df1bc7d4f | |||
599e927590 | |||
0429016ff1 | |||
bd42b9638a | |||
b1a826b03a | |||
5ed5f3687b | |||
943a902a0b | |||
a7873389c6 | |||
acfa174333 | |||
8418845c8d | |||
df4a4b9e1d | |||
7f5497db55 | |||
e4658e963f | |||
7764515f56 | |||
7046c38c84 | |||
9e9bb30a57 | |||
41d1be24cc | |||
7d3b475e24 | |||
f82a227da6 | |||
fcd8159617 | |||
f51ccb5c3f | |||
e0cd5b6405 | |||
6a71f31820 | |||
3428ab1e89 | |||
956e4a7cbb | |||
669bad27d4 | |||
2c3ae1c181 | |||
f570fe8c37 | |||
1b74ad0731 | |||
6717700d3b | |||
b810833145 | |||
9d58e566fd | |||
6632fa8da1 | |||
5790f3c8f7 | |||
4073b52c00 | |||
f5c7a6478e | |||
ebf58320ca | |||
09ddb0f824 | |||
f02a699c26 | |||
67d0931c19 | |||
19d079c33c | |||
40723a4cc7 | |||
8a9a26588c | |||
219475630a | |||
52e856fa6f | |||
cb2c029e57 | |||
ef7579394b | |||
fc4f175300 | |||
a6fc9311b4 | |||
14639f129e | |||
9182c2068d | |||
cb1b3be723 | |||
5ccd62a789 | |||
145d45c746 | |||
f235157466 | |||
ba5cdab619 | |||
eab5ae2f07 | |||
2f0b3c0e63 | |||
4e261068a1 | |||
1d24caf066 | |||
dc76c5165f | |||
de11b36a98 | |||
c4a4ed5272 | |||
a24edac5a9 | |||
9dbf44388d | |||
6b8e93e05e | |||
6b5239b9d5 | |||
214c06b771 | |||
e32a8552be | |||
9bcb409648 | |||
3b10afd2ab | |||
af3bb131c8 | |||
622e7dd287 | |||
68082e6fc1 | |||
36bcc7b355 | |||
c7c0b729c1 | |||
6aeefda3b6 | |||
4780174ee1 | |||
ab23625091 | |||
a88cf8fab7 | |||
2be528a3fa | |||
337864618c | |||
526cad54d7 | |||
506cf7f438 | |||
4b89878c10 | |||
06fad301cb | |||
7be0c2c650 | |||
43f0db45ad | |||
892c37db08 | |||
d8a1d1a120 | |||
64e52e97ee | |||
2a777a659a | |||
898f429826 | |||
88fbe3ac34 | |||
4ddc674846 | |||
fc4f5fd05f | |||
a002393716 | |||
a889f6560c | |||
4db17ecd93 | |||
2a57f2b365 | |||
803e07c188 | |||
ff44d93e68 | |||
d5d2209d09 | |||
c81e8fc93a | |||
347ac422f4 | |||
d7f5b56ca4 | |||
53d6f0d492 | |||
e4ce75e20c | |||
9094179856 | |||
3aab36fec2 | |||
744d61f6fd | |||
05498aa178 | |||
b1eb273d5b | |||
8a3f8510d6 | |||
22904a48a6 | |||
1730304f46 | |||
1038fc35df | |||
71f44aaee1 | |||
cc7ebfd11e | |||
54d4b308f4 | |||
5234c8124b | |||
e22d4bf31f | |||
21f7b90f03 | |||
769e8440f5 | |||
33de2b6cf3 | |||
3975b07371 | |||
abd64102aa | |||
d2174d1580 | |||
c72eccdd35 | |||
ab902128dc | |||
c70a491f59 | |||
322d13de0d | |||
97b7161d78 | |||
1360b6a396 | |||
16e51b83ab | |||
aa7cc5351c | |||
30da920135 | |||
bcdf5b7e52 | |||
c711fe592d | |||
9d5c1b3742 | |||
6b26cd0977 | |||
10ec0f21b0 | |||
ff66182dc6 | |||
d02ce2f1bb | |||
2664a2d0da | |||
1f7350658e | |||
41132b701b | |||
712005219c | |||
0bd17aff8a | |||
f3f44d7812 | |||
8385d5fa3a | |||
726f8be341 | |||
fee029b86e | |||
c3504ddf0a | |||
6a878ee444 | |||
c4ec2ba88f | |||
c907ca6e5d | |||
8993a093e9 | |||
d04669d0cc | |||
05fc136915 | |||
8d37939086 | |||
6d2ad4539f | |||
5ab53f42b2 | |||
f448e805e9 | |||
67aa8efd5a | |||
61a5273aea | |||
35a39b8d8f | |||
96b6571352 | |||
74e7dd053f | |||
1f8636d762 | |||
e4cfa701d8 | |||
b85181a6db | |||
6841b80466 | |||
298864bafe | |||
4d7f03836c | |||
c63eb80b95 | |||
0c0bf80074 | |||
144ff3b06e | |||
d6c50c3596 | |||
51b177ce47 | |||
824b7a25ca | |||
2223d40640 | |||
4df29fbac1 | |||
6dc36125c2 | |||
40085609e2 | |||
ebb6d80092 | |||
764ff2cd53 | |||
8ef226bcb8 | |||
63606c0985 | |||
1600d39693 | |||
04c59985a1 | |||
7e58347fbe | |||
0e794a28a1 | |||
6fb52c3638 | |||
b72ef09451 | |||
f7de027617 | |||
bc4c2dde33 | |||
95f05dad66 | |||
3bb0a7aa8e | |||
dcf7eeef28 | |||
3b923b6e4e | |||
8050f7404b | |||
959b1d9e4c | |||
daa279d57b | |||
ae9b7926a2 | |||
1f7a5e6943 | |||
9e354803de | |||
3ea5eb3f3a | |||
ec43bf4fe9 | |||
2097ffaabf | |||
67e78f0751 | |||
1791dccbf2 | |||
40d1cfe7af | |||
4627f851ca | |||
fc9e609ab5 | |||
8b3d861a9d | |||
9ef864b27c | |||
275b80a462 | |||
763be4f266 | |||
5b812522fa | |||
9cb0ddb5e7 | |||
735bea1f47 | |||
0853b04589 | |||
c1b3705df1 | |||
2540b4e01b | |||
2641697e0b | |||
2996503b27 | |||
0214c9bcad | |||
a471aed6db | |||
af0edecddb | |||
300323cfd7 | |||
d8724e0a0b | |||
0001dabfd1 | |||
ad78001241 | |||
5a837a591e | |||
fd79d23910 | |||
1902c0ec93 | |||
85499be855 | |||
e6ddfc7afb | |||
58298ec5ba | |||
0814fc185f | |||
8f8c82d400 | |||
372b7d3d9d | |||
fbffadb2cf | |||
6e52f242b2 | |||
d2a67f362f | |||
66b12da4e7 | |||
42b0d6a83d | |||
94b1c75fd2 | |||
b04b549b34 | |||
09d4b2cd38 | |||
ddfe7d8b91 | |||
4a657ca87f | |||
1e3d478998 | |||
3aebef6d0a | |||
25879466da | |||
27ec1afb7a | |||
06a0d1a872 | |||
04fe7e1a27 | |||
f9cfea244a | |||
5ec062cc71 | |||
91b808381e | |||
8550418875 | |||
00c391320c | |||
9723682d20 | |||
8bf6f6e09f | |||
062c1c13b5 | |||
1b8107094f | |||
8721ac88b1 | |||
6da6f921cd | |||
ef63757b1a | |||
3a169df0a5 | |||
d4f819f1f0 | |||
16fe3c0acc | |||
fd8f4eb3a6 | |||
b261eca865 | |||
a37480eec9 | |||
713aaa3d68 | |||
7d1d0c4e67 | |||
4ad05dbaef | |||
38371aae62 | |||
498a2e4c1e | |||
2078871f36 | |||
140525b7a0 | |||
1a81d46a97 | |||
4c4c4688a9 | |||
b47ac27ac6 | |||
ed18e77655 | |||
fcbec6eb6d | |||
f5c25823bc | |||
f00dfd7bfe | |||
dcca4214f5 | |||
1e9cc285bb | |||
b9c4a0c5f6 | |||
0d339300f9 | |||
63d7d87080 | |||
2ee655f9ba | |||
61a4195ed4 | |||
a6f029ded0 | |||
b54de58e6b | |||
795e37278f | |||
7ce1039d7c | |||
aba42faf69 | |||
815326d42e | |||
7d40a541c9 | |||
2507ee2e56 | |||
a0a451195b | |||
ce247a5637 | |||
59f9c9747f | |||
fec088e3ed | |||
4980ee8fb9 | |||
2ed77d2cc3 | |||
630107ae8a | |||
4eb8074358 | |||
80a02cd90d | |||
7427888e05 | |||
90c1d549a8 | |||
2af003e4e2 | |||
eaf55e174b | |||
0588e578d5 | |||
12f9aac4ea | |||
81bb3fce97 | |||
6011a2f51a | |||
6071bd07ec | |||
1c814d3bb6 | |||
9862048a58 | |||
ebc52a5a65 | |||
eacad922df | |||
d910996613 | |||
2fc220fa33 | |||
8cabda551d | |||
afd033e9c9 | |||
6ec5ba521b | |||
c8e49a7e4e | |||
dee8c8e242 | |||
576543c4b4 | |||
746f2882f7 | |||
c4cbf9d0bb | |||
49bd51b5f9 | |||
e53ae0f9bb | |||
afdd913a2f | |||
3df4efd512 | |||
91dd45c387 | |||
136ee0d576 | |||
1ea8d92cc3 | |||
20fcb99830 | |||
f3265d2111 | |||
d6e7709866 | |||
d11019d9e1 | |||
cfd924622e | |||
27c08b785d | |||
77f38e4449 | |||
16ddfbc4e0 | |||
8dea900869 | |||
f342dee2b4 | |||
1d5721f3bd | |||
3170558d6d | |||
3530aa88d6 | |||
21998890d4 | |||
c9d6bd76c9 | |||
bc2ce178ea | |||
e22e62d184 | |||
4181de119c | |||
56bf24e1ec | |||
e9b4c6289b | |||
7ed92bebd3 | |||
c3f71c1a99 | |||
7050ef675d | |||
070cd5b6c0 | |||
2c2cc33c94 | |||
169c83431c | |||
5f72c68d87 | |||
b184af6d00 | |||
6f55d1e58f | |||
5aea1363cc | |||
0685a36f0e | |||
70739f5cfd | |||
933a66a070 | |||
4167b11434 | |||
2a3b51ac3a | |||
e633292df1 | |||
30b94493bb | |||
c51cc91f92 | |||
8b04046321 | |||
11bb5e26ff | |||
9ac2ac303c | |||
f0784d3b41 | |||
3d8ece8c8b | |||
b0fb71f7d8 | |||
a5cd1b1693 | |||
d8a1eec530 | |||
e20c47c57b | |||
b77b203935 | |||
1ad97ebf85 | |||
ef12c74771 | |||
0bc03e8071 | |||
04286f3228 | |||
1d942cdf41 | |||
aaf0d5c3c5 | |||
04e8acd844 | |||
8ff48dde73 | |||
41b2e629f7 | |||
a60162ba76 | |||
45f4e5ac20 | |||
637f7a5bfa | |||
399ccec645 | |||
2bd280df80 | |||
c832edbda3 | |||
b8d0041851 | |||
0a97d4c825 | |||
5eee947ffe | |||
720e6548c7 | |||
f375459d53 | |||
e842838a23 | |||
00aa038818 | |||
eb78077a0c | |||
d8d939660b | |||
ae089dcff7 | |||
1a4515c0b9 | |||
4eee8e8bdf | |||
9f1421e0a6 | |||
84f199f0dd | |||
8230f8fc9b | |||
02d809f3f4 | |||
b0560cbd99 | |||
d1003ff6c9 | |||
b11ad4077b | |||
5dc7dc1216 | |||
0d4a93018b | |||
3ca40db9f8 | |||
ce607196d1 | |||
0b3af166ae | |||
39e5660c4a | |||
6b985b2d1f | |||
527dc19794 | |||
29e71cbb16 | |||
2d54019f83 | |||
98c8e8e35a | |||
b106b1ed14 | |||
2998a55f0b | |||
e5c4778ff7 | |||
2ec9569b36 | |||
58303d0837 | |||
e3639918eb | |||
6d290bd001 | |||
7683667b3c | |||
9cbc891816 | |||
0454bd1ef6 | |||
f139100b23 | |||
3f666bd5f0 | |||
d53a93e0ae | |||
2059d610a8 | |||
9bbfbd0a6a | |||
6e4f1dc756 | |||
dc13882624 | |||
6bb17d5896 | |||
1a513cbd16 | |||
87fa87d87b | |||
fa1a40ac6e | |||
954428e341 | |||
765752261c | |||
037f90aada | |||
1397bec066 | |||
b105e6f7c4 | |||
4fe2b1100e | |||
c3403ed72d | |||
393f352b70 | |||
e86eb0cfdf | |||
a9a730fd74 | |||
4ff6809bc5 | |||
7b229e4c38 | |||
9ac9b533b6 | |||
f53fc3e06f | |||
0139354780 | |||
011aac43d2 | |||
eb20ae6a3f | |||
7c0af91844 | |||
fc2e3a4ab3 | |||
58cb793c96 | |||
4592f23260 | |||
ccb54136a2 | |||
4c9c047ddf | |||
1feb92679d | |||
a13b9e8bdc | |||
cb723840d9 | |||
923d3e8a84 | |||
0d1623edef | |||
cf149940ed | |||
ef55a6ba7c | |||
e3e4aa89ad | |||
3523296e3d | |||
b2a8085651 | |||
83d73c93f7 | |||
7a2a64803a | |||
baf5adcf33 | |||
689ae5c08d | |||
d9b1e7e810 | |||
b4eece01f8 | |||
cf5396aaed | |||
e390587e91 | |||
bae179ed67 | |||
7e4fcb0868 | |||
fbfdca1de9 | |||
0612eef69b | |||
ae0b7a3ebd | |||
e92612b511 | |||
5c33fd4b94 | |||
c3f51e2980 | |||
de47c0af9e | |||
e53e4e3dd9 | |||
36fe6535c4 | |||
b55e57a7cf | |||
7626db624e | |||
6d8329b255 | |||
461e30148c | |||
57d98e48f7 | |||
cf2babc598 | |||
d10277df31 | |||
d3a1203782 | |||
126f7ab819 | |||
221c2861fc | |||
66667382e1 | |||
a7e928d126 | |||
591fe7e92b | |||
d6e61cbcda | |||
5825366fe4 | |||
6df204cf40 | |||
3f7e1db549 | |||
a6091136b0 | |||
353bbd0e8c | |||
a428e125fa | |||
2e262b2689 | |||
a2d055e408 | |||
57defe00ee | |||
ac5a2676e7 | |||
ed98ea4e43 | |||
729bf0afd2 | |||
2ea7ea153c | |||
2772e66064 | |||
d41f7a8165 | |||
abfd3997eb | |||
788c9be016 | |||
c3d7a79a83 | |||
1782348275 | |||
edfe5c6622 | |||
2b9492317b | |||
5da41edf6a | |||
476e5aaa86 | |||
789fa507b5 | |||
508f936317 | |||
e9d88dda8e | |||
ecceb71a1e | |||
bff77abe6a | |||
98413089f6 | |||
a2446f6c68 | |||
c955049207 | |||
574c00c096 | |||
7415f206ea | |||
f76017a015 | |||
cda05aec04 | |||
639286f8b6 | |||
cc66618e70 | |||
9efc0ec40d | |||
34674fc282 | |||
01c3166043 | |||
bf2e3d5669 | |||
4e9f0b2e2e | |||
223f14710d | |||
f7ae91b85d | |||
445dff499b | |||
9afa05e2f4 | |||
c3e1677b7d | |||
024976cda2 | |||
df541a2a22 | |||
f2ef338cb8 | |||
8c6f64c111 | |||
5a16b2117b | |||
71edcaf20f | |||
ac89d91db5 | |||
e664c1ab05 | |||
adba668109 | |||
ad972725de | |||
185eccf6f5 | |||
c4567bac18 | |||
13409c433a | |||
20431debe0 | |||
797ea356ef | |||
2321473c34 | |||
0d5f65c5f3 | |||
c30241775a | |||
31827d03f9 | |||
7bcdf3e722 | |||
db9a76f7c6 | |||
3fd87e8e82 | |||
22a2786610 | |||
2b5a6df1e1 | |||
5fefeae404 | |||
d4f725d1fa | |||
a096098c1f | |||
cc8c0472ca | |||
fb554071dc | |||
17a17c8957 | |||
2e7d498865 | |||
567157b005 | |||
ec6cbc5135 | |||
8499f0b960 | |||
11432253a1 | |||
f17e1c4a80 | |||
6b2f6a4f87 | |||
671329a3e9 | |||
7e7074502f | |||
aa306d5573 | |||
55669e306e | |||
3f96e070ce | |||
8032a4b564 | |||
b923e8f4df | |||
c5388cf8e7 | |||
cb908a2373 | |||
cecbcd1929 | |||
90e0cc6091 | |||
45bbf6db86 | |||
432476c98a | |||
1f3e227a8b | |||
66c28020c5 | |||
6cfe2a58eb | |||
fc6ad51e68 | |||
d3bc52951a | |||
2f7232859e | |||
4a7232ac99 | |||
72d78432c9 | |||
f6cd42d916 | |||
542dff2a08 | |||
e75e843c88 | |||
146a76247c | |||
f28157cab7 | |||
1ce16ce449 | |||
c310e7e8b7 | |||
aa2ef79e55 | |||
7ad57f1c33 | |||
cbfd331e50 | |||
e6f55b1f6f | |||
bb805e93cb | |||
deb57b960b | |||
8a9b918bf4 | |||
2f6f3d0629 | |||
a60b35f41c | |||
6757f35a3a | |||
ffb9b6d1ba | |||
e401498e4a | |||
d30e940b3b | |||
05ea5e04c8 | |||
a7ef99d0fe | |||
f2a8b52c2c | |||
409ca7ee4e | |||
387b565705 | |||
96f486001d | |||
a498abc14a | |||
c64340a9bb | |||
79d80a5dbf | |||
7ebff5949f | |||
434080572c | |||
c87a0e97ab | |||
2dbd94951c | |||
1e044f50c7 | |||
a7aa98510c | |||
729ab56878 | |||
907b627e16 | |||
10fcca20f8 | |||
59cd1f1433 | |||
4a2c570270 | |||
8c7edbd9c3 | |||
0801e16327 | |||
0df2a365f5 | |||
c7d6d33e6c | |||
c705f3cfeb | |||
7fecb36aee | |||
657a2ea8d9 | |||
dd064f4c96 | |||
3bc05b97ea | |||
bbd515f6f6 | |||
9b3e3a3d9c | |||
a3a2ca4796 | |||
eab13dc565 | |||
bebd1c400c | |||
36d1bb2f52 | |||
ae32695c3e | |||
c5d19a4dbd | |||
78728c6547 | |||
a8032f81d9 | |||
a138791964 | |||
f9f002c8f7 | |||
f192d5c12e | |||
a6724bd03f | |||
c77c3f33ef | |||
623aeee9bf | |||
a241d53d28 | |||
11500d2ff5 | |||
85708bc94f | |||
ba6e8856f2 | |||
c8448b0abf | |||
e35248ffc4 | |||
b47a3b566a | |||
6ab23bd523 | |||
987afff0e9 | |||
564c62f3b3 | |||
8733f95e51 | |||
ce63e9c3c3 | |||
77b7124cf1 | |||
6a608d4b49 | |||
01924618bd | |||
666e2fd0ce | |||
0cfc25d751 | |||
b6d8e6c989 | |||
ab2502f7b8 | |||
c57e6f3bd8 | |||
b54f1ffc1d | |||
bd0ea42277 | |||
7ae43bc4f8 | |||
056682327b | |||
8b66a25f66 | |||
96245dd3b4 | |||
9cc49da68a | |||
224918b463 | |||
cbeefa2503 | |||
6d68806633 | |||
ba3617c22f | |||
b7d9bb2765 | |||
74b42e2251 | |||
c0cf9c3fcc | |||
9f3ce18f06 | |||
b9e3255c9e | |||
e657396f65 | |||
929f608f2f | |||
c6a4bfa886 | |||
d5e25b12b8 | |||
7cf6fe6d62 | |||
155dd653e7 | |||
b5c8cd1766 | |||
4967e389c5 | |||
ffbaebd198 | |||
04b8781c8d | |||
5a4d993f7d | |||
823a172681 | |||
a1943e21ed | |||
01c287bc89 | |||
0cf8249b14 | |||
a8265a799d | |||
18bb653f10 | |||
a003a31952 | |||
0a1c27f873 | |||
75f8e25aed | |||
39c506b419 | |||
ef2641b49b | |||
bce101578d | |||
10e466426a | |||
9b90aeffa5 | |||
601b51890f | |||
2524a00a96 | |||
e31d667bec | |||
c161f698fc | |||
92e687303d | |||
f5b83f9314 | |||
5e7b9ec688 | |||
78ae0b8aee | |||
283dffc035 | |||
0aded2a798 | |||
1b5be892b9 | |||
756c279cdc | |||
08d05df00e | |||
c385862be1 | |||
0eff567910 | |||
94d38c0680 | |||
81285f49fe | |||
877096d49d | |||
bfe60243a4 | |||
ca9d606e72 | |||
24d21467dd | |||
41651136bf | |||
5e5f060fc0 | |||
29ab5fc9c2 | |||
80913b8044 | |||
02960f28e4 | |||
8db338ba14 | |||
dadd8986dc | |||
e2016cf65b | |||
1b214a60fa | |||
8560583ee7 | |||
2932c4ee43 | |||
e8c127a894 | |||
d7ac7ff9a3 | |||
aef7e43c48 | |||
d855b0f98c | |||
c726506b47 | |||
c32e306be9 | |||
13e907c894 | |||
d19a34152f | |||
19cce08b2b | |||
3cd6f66067 | |||
ada588c112 | |||
0d57fe5a7e | |||
5a74beb7e2 | |||
e2d591b9ff | |||
8082185ac4 | |||
85ebc8a1ec | |||
9ca32e664e | |||
566b76121a | |||
562080f22d | |||
bb8bddc758 | |||
9eb8842dda | |||
97558abc29 | |||
160ce092ff | |||
d6974127b4 | |||
092660db52 |
12
.clang-format
Normal file
12
.clang-format
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# http://clang.llvm.org/docs/ClangFormatStyleOptions.html
|
||||||
|
|
||||||
|
BasedOnStyle: Google
|
||||||
|
Standard: c++11
|
||||||
|
AllowShortFunctionsOnASingleLine: Empty
|
||||||
|
IncludeBlocks: Preserve
|
||||||
|
IndentPPDirectives: AfterHash
|
||||||
|
DerivePointerAlignment: false
|
||||||
|
|
||||||
|
# Always break after if to get accurate coverage
|
||||||
|
AllowShortIfStatementsOnASingleLine: false
|
||||||
|
AllowShortLoopsOnASingleLine: false
|
18
.devcontainer/clang10/devcontainer.json
Normal file
18
.devcontainer/clang10/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 10",
|
||||||
|
"image": "conanio/clang10",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang10"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang11/devcontainer.json
Normal file
18
.devcontainer/clang11/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 11",
|
||||||
|
"image": "conanio/clang11",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang11"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
.devcontainer/clang13/Dockerfile
Normal file
5
.devcontainer/clang13/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git clang-13 libc++-13-dev libc++abi-13-dev
|
||||||
|
ENV CC=clang-13 CXX=clang++-13
|
20
.devcontainer/clang13/devcontainer.json
Normal file
20
.devcontainer/clang13/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 13",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile"
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang13"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
.devcontainer/clang14/Dockerfile
Normal file
5
.devcontainer/clang14/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git clang-14 libc++-14-dev libc++abi-14-dev
|
||||||
|
ENV CC=clang-14 CXX=clang++-14
|
20
.devcontainer/clang14/devcontainer.json
Normal file
20
.devcontainer/clang14/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 14",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile"
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang14"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
.devcontainer/clang15/Dockerfile
Normal file
5
.devcontainer/clang15/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git clang-15 libc++-15-dev libc++abi-15-dev
|
||||||
|
ENV CC=clang-15 CXX=clang++-15
|
20
.devcontainer/clang15/devcontainer.json
Normal file
20
.devcontainer/clang15/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 15",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile"
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang15"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
.devcontainer/clang16/Dockerfile
Normal file
5
.devcontainer/clang16/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git clang-16 libc++-16-dev libc++abi-16-dev
|
||||||
|
ENV CC=clang-16 CXX=clang++-16
|
20
.devcontainer/clang16/devcontainer.json
Normal file
20
.devcontainer/clang16/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 16",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile"
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang16"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
.devcontainer/clang17/Dockerfile
Normal file
5
.devcontainer/clang17/Dockerfile
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
FROM ubuntu:24.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git clang-17 libc++-17-dev libc++abi-17-dev
|
||||||
|
ENV CC=clang-17 CXX=clang++-17
|
20
.devcontainer/clang17/devcontainer.json
Normal file
20
.devcontainer/clang17/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 17",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile"
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang17"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang5/devcontainer.json
Normal file
18
.devcontainer/clang5/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 5",
|
||||||
|
"image": "conanio/clang50",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang5"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang6/devcontainer.json
Normal file
18
.devcontainer/clang6/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 6",
|
||||||
|
"image": "conanio/clang60",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang6"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang7/devcontainer.json
Normal file
18
.devcontainer/clang7/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 7",
|
||||||
|
"image": "conanio/clang7",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang7"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang8/devcontainer.json
Normal file
18
.devcontainer/clang8/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 8",
|
||||||
|
"image": "conanio/clang8",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang8"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/clang9/devcontainer.json
Normal file
18
.devcontainer/clang9/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "Clang 9",
|
||||||
|
"image": "conanio/clang9",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-clang9"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc10/devcontainer.json
Normal file
18
.devcontainer/gcc10/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 10",
|
||||||
|
"image": "conanio/gcc10",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc10"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc11/devcontainer.json
Normal file
18
.devcontainer/gcc11/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 11",
|
||||||
|
"image": "conanio/gcc11",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc11"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
4
.devcontainer/gcc12/Dockerfile
Normal file
4
.devcontainer/gcc12/Dockerfile
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y cmake git g++-12
|
20
.devcontainer/gcc12/devcontainer.json
Normal file
20
.devcontainer/gcc12/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 12",
|
||||||
|
"build": {
|
||||||
|
"dockerfile": "Dockerfile",
|
||||||
|
},
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc12"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
20
.devcontainer/gcc48/devcontainer.json
Normal file
20
.devcontainer/gcc48/devcontainer.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 4.8",
|
||||||
|
"image": "conanio/gcc48",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc48"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools",
|
||||||
|
"josetr.cmake-language-support-vscode",
|
||||||
|
"ms-vscode.cpptools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc5/devcontainer.json
Normal file
18
.devcontainer/gcc5/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 5",
|
||||||
|
"image": "conanio/gcc5",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc5"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc6/devcontainer.json
Normal file
18
.devcontainer/gcc6/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 6",
|
||||||
|
"image": "conanio/gcc6",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc6"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc7/devcontainer.json
Normal file
18
.devcontainer/gcc7/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 7",
|
||||||
|
"image": "conanio/gcc7",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc7"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc8/devcontainer.json
Normal file
18
.devcontainer/gcc8/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 8",
|
||||||
|
"image": "conanio/gcc8",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc8"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
18
.devcontainer/gcc9/devcontainer.json
Normal file
18
.devcontainer/gcc9/devcontainer.json
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
{
|
||||||
|
"name": "GCC 9",
|
||||||
|
"image": "conanio/gcc9",
|
||||||
|
"runArgs": [
|
||||||
|
"--name=ArduinoJson-gcc9"
|
||||||
|
],
|
||||||
|
"customizations": {
|
||||||
|
"vscode": {
|
||||||
|
"extensions": [
|
||||||
|
"ms-vscode.cmake-tools"
|
||||||
|
],
|
||||||
|
"settings": {
|
||||||
|
"cmake.generator": "Unix Makefiles",
|
||||||
|
"cmake.buildDirectory": "/tmp/build"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
2
.gitattributes
vendored
Normal file
2
.gitattributes
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
* text=auto
|
||||||
|
*.sh text eol=lf
|
4
.github/FUNDING.yml
vendored
Normal file
4
.github/FUNDING.yml
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
github: bblanchon
|
||||||
|
custom:
|
||||||
|
- https://arduinojson.org/book/
|
||||||
|
- https://donate.benoitblanchon.fr/
|
54
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
54
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
---
|
||||||
|
name: 🐛 Bug report
|
||||||
|
about: Report a bug in ArduinoJson
|
||||||
|
title: ''
|
||||||
|
labels: 'bug'
|
||||||
|
assignees: ''
|
||||||
|
---
|
||||||
|
|
||||||
|
<!-- ⚠️ IMPORTANT ⚠️
|
||||||
|
Before opening a bug report, please use the ArduinoJson Troubleshooter as it may find a solution to your issue; if not, please include the Troubleshooter's report in the description.
|
||||||
|
-->
|
||||||
|
|
||||||
|
**Describe the bug**
|
||||||
|
A clear and concise description of what the bug is.
|
||||||
|
|
||||||
|
**Troubleshooter report**
|
||||||
|
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v7/troubleshooter/):
|
||||||
|
[Paste the report here]
|
||||||
|
|
||||||
|
**Environment**
|
||||||
|
Here is the environment that I used:
|
||||||
|
* Microcontroller: [e.g. ESP8266]
|
||||||
|
* Core/runtime: [e.g. ESP8266 core for Arduino v3.0.2]
|
||||||
|
* IDE: [e.g. Arduino IDE 1.8.16]
|
||||||
|
|
||||||
|
**Reproduction**
|
||||||
|
Here is a small snippet that reproduces the issue.
|
||||||
|
|
||||||
|
```c++
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
|
||||||
|
[insert repro code here]
|
||||||
|
```
|
||||||
|
|
||||||
|
**Compiler output**
|
||||||
|
If relevant, include the complete compiler output (i.e. not just the line that contains the error.)
|
||||||
|
|
||||||
|
|
||||||
|
**Program output**
|
||||||
|
If relevant, include the repro program output.
|
||||||
|
|
||||||
|
Expected output:
|
||||||
|
|
||||||
|
```
|
||||||
|
[insert expected output here]
|
||||||
|
```
|
||||||
|
|
||||||
|
Actual output:
|
||||||
|
|
||||||
|
```
|
||||||
|
[insert actual output here]
|
||||||
|
```
|
8
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
8
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
blank_issues_enabled: true
|
||||||
|
contact_links:
|
||||||
|
- name: 👨🏫 ArduinoJson Assistant
|
||||||
|
url: https://arduinojson.org/v7/assistant/
|
||||||
|
about: An online tool that computes memory requirements and generates scaffolding code for your project.
|
||||||
|
- name: 👨⚕️ ArduinoJson Troubleshooter
|
||||||
|
url: https://arduinojson.org/v7/troubleshooter/
|
||||||
|
about: An online tool that helps you diagnose the most common issues with ArduinoJson.
|
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
---
|
||||||
|
name: 💡 Feature request
|
||||||
|
about: Suggest an idea for ArduinoJson
|
||||||
|
title: ''
|
||||||
|
labels: enhancement
|
||||||
|
assignees: ''
|
||||||
|
---
|
||||||
|
|
||||||
|
**Is your feature request related to a problem? Please describe.**
|
||||||
|
A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
|
||||||
|
|
||||||
|
**Describe the solution you'd like**
|
||||||
|
A clear and concise description of what you want to happen.
|
||||||
|
|
||||||
|
**Describe alternatives you've considered**
|
||||||
|
A clear and concise description of any alternative solutions or features you've considered.
|
||||||
|
|
||||||
|
**Additional context**
|
||||||
|
Add any other context or screenshots about the feature request here.
|
51
.github/ISSUE_TEMPLATE/help.md
vendored
Normal file
51
.github/ISSUE_TEMPLATE/help.md
vendored
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
---
|
||||||
|
name: 😭 Help!
|
||||||
|
about: Ask for help
|
||||||
|
title: ''
|
||||||
|
labels: 'question'
|
||||||
|
assignees: ''
|
||||||
|
---
|
||||||
|
|
||||||
|
<!-- ⚠️ IMPORTANT ⚠️
|
||||||
|
Before asking for help, please use the ArduinoJson Troubleshooter as it may find a solution to your issue; if not, please include the Troubleshooter's report in the description.
|
||||||
|
-->
|
||||||
|
|
||||||
|
**Describe the issue**
|
||||||
|
A clear and concise description of what you're trying to do.
|
||||||
|
You don't need to explain every aspect of your project: focus on the problem you're having.
|
||||||
|
|
||||||
|
**Troubleshooter report**
|
||||||
|
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v7/troubleshooter/):
|
||||||
|
[Paste the report here]
|
||||||
|
|
||||||
|
**Environment**
|
||||||
|
Here is the environment that I'm using':
|
||||||
|
* Microconroller: [e.g. ESP8266]
|
||||||
|
* Core/runtime: [e.g. ESP8266 core for Arduino v3.0.2]
|
||||||
|
* IDE: [e.g. Arduino IDE 1.8.16]
|
||||||
|
|
||||||
|
**Reproduction**
|
||||||
|
Here is a small snippet that demonstrate the problem.
|
||||||
|
|
||||||
|
```c++
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
|
||||||
|
// insert code here
|
||||||
|
```
|
||||||
|
|
||||||
|
**Program output**
|
||||||
|
If relevant, include the program output.
|
||||||
|
|
||||||
|
Expected output:
|
||||||
|
|
||||||
|
```
|
||||||
|
[insert expected output here]
|
||||||
|
```
|
||||||
|
|
||||||
|
Actual output:
|
||||||
|
|
||||||
|
```
|
||||||
|
[insert actual output here]
|
||||||
|
```
|
601
.github/workflows/ci.yml
vendored
Normal file
601
.github/workflows/ci.yml
vendored
Normal file
@ -0,0 +1,601 @@
|
|||||||
|
name: Continuous Integration
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lint:
|
||||||
|
name: Lint
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: sudo apt-get install -y clang-format
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Symlinks
|
||||||
|
run: find * -type l -printf "::error::%p is a symlink. This is forbidden by the Arduino Library Specification." -exec false {} +
|
||||||
|
- name: Clang-format
|
||||||
|
run: |
|
||||||
|
find src/ extras/ -name '*.[ch]pp' | xargs clang-format -i --verbose --style=file
|
||||||
|
git diff --exit-code
|
||||||
|
- name: Check URLs
|
||||||
|
run: |
|
||||||
|
grep -hREo "(http|https)://[a-zA-Z0-9./?=_%:-]*" src/ | sort -u | while read -r URL
|
||||||
|
do
|
||||||
|
STATUS=$(curl -s -o /dev/null -I -w "%{http_code}" "$URL")
|
||||||
|
[ "$STATUS" -ge 400 ] && echo "::warning title=HTTP $STATUS::$URL returned $STATUS"
|
||||||
|
done || true
|
||||||
|
|
||||||
|
gcc:
|
||||||
|
name: GCC
|
||||||
|
needs: lint
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- gcc: "4.8"
|
||||||
|
- gcc: "5"
|
||||||
|
- gcc: "6"
|
||||||
|
- gcc: "7"
|
||||||
|
cxxflags: -fsanitize=leak -fno-sanitize-recover=all
|
||||||
|
- gcc: "8"
|
||||||
|
cxxflags: -fsanitize=undefined -fno-sanitize-recover=all
|
||||||
|
- gcc: "9"
|
||||||
|
cxxflags: -fsanitize=address -fno-sanitize-recover=all
|
||||||
|
- gcc: "10"
|
||||||
|
cxxflags: -funsigned-char # Issue #1715
|
||||||
|
- gcc: "11"
|
||||||
|
- gcc: "12"
|
||||||
|
steps:
|
||||||
|
- name: Workaround for actions/runner-images#9491
|
||||||
|
run: sudo sysctl vm.mmap_rnd_bits=28
|
||||||
|
|
||||||
|
- name: Install
|
||||||
|
run: |
|
||||||
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 40976EAF437D05B5 3B4FE6ACC0B21F32
|
||||||
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ xenial main universe'
|
||||||
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ bionic main universe'
|
||||||
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ focal main universe'
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y gcc-${{ matrix.gcc }} g++-${{ matrix.gcc }}
|
||||||
|
timeout-minutes: 5
|
||||||
|
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
timeout-minutes: 1
|
||||||
|
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
env:
|
||||||
|
CC: gcc-${{ matrix.gcc }}
|
||||||
|
CXX: g++-${{ matrix.gcc }}
|
||||||
|
CXXFLAGS: ${{ matrix.cxxflags }}
|
||||||
|
timeout-minutes: 1
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: cmake --build .
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
|
- name: Test
|
||||||
|
run: ctest --output-on-failure -C Debug .
|
||||||
|
env:
|
||||||
|
UBSAN_OPTIONS: print_stacktrace=1
|
||||||
|
timeout-minutes: 2
|
||||||
|
|
||||||
|
clang:
|
||||||
|
name: Clang
|
||||||
|
needs: lint
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- clang: "7"
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
|
- clang: "8"
|
||||||
|
cxxflags: -fsanitize=leak -fno-sanitize-recover=all
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
|
- clang: "9"
|
||||||
|
cxxflags: -fsanitize=undefined -fno-sanitize-recover=all
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
|
- clang: "10"
|
||||||
|
cxxflags: -fsanitize=address -fno-sanitize-recover=all
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
|
- clang: "11"
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
- clang: "12"
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
- clang: "13"
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
- clang: 14
|
||||||
|
- clang: 15
|
||||||
|
- clang: 16
|
||||||
|
- clang: 17
|
||||||
|
- clang: 18
|
||||||
|
- clang: 19
|
||||||
|
runs-on: ${{ matrix.runner || 'ubuntu-latest' }}
|
||||||
|
steps:
|
||||||
|
- name: Add archive repositories
|
||||||
|
if: matrix.archive
|
||||||
|
run: |
|
||||||
|
sudo gpg --keyserver keyserver.ubuntu.com --recv-keys 3B4FE6ACC0B21F32
|
||||||
|
sudo gpg --export 3B4FE6ACC0B21F32 | sudo tee /etc/apt/trusted.gpg.d/ubuntu-keyring.gpg > /dev/null
|
||||||
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ ${{ matrix.archive }} main'
|
||||||
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ ${{ matrix.archive }} universe'
|
||||||
|
- name: Install Clang ${{ matrix.clang }}
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y clang-${{ matrix.clang }}
|
||||||
|
- name: Install libc++ ${{ matrix.clang }}
|
||||||
|
run: sudo apt-get install -y libc++-${{ matrix.clang }}-dev libc++abi-${{ matrix.clang }}-dev
|
||||||
|
- name: Install libunwind ${{ matrix.clang }}
|
||||||
|
if: matrix.clang == 12 # dependency is missing in Ubuntu 22.04
|
||||||
|
run: sudo apt-get install -y libunwind-${{ matrix.clang }}-dev
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
env:
|
||||||
|
CC: clang-${{ matrix.clang }}
|
||||||
|
CXX: clang++-${{ matrix.clang }}
|
||||||
|
CXXFLAGS: >-
|
||||||
|
${{ matrix.cxxflags }}
|
||||||
|
${{ matrix.clang < 11 && '-I/usr/lib/llvm-10/include/c++/v1/' || '' }}
|
||||||
|
- name: Build
|
||||||
|
run: cmake --build .
|
||||||
|
- name: Test
|
||||||
|
run: ctest --output-on-failure -C Debug .
|
||||||
|
env:
|
||||||
|
UBSAN_OPTIONS: print_stacktrace=1
|
||||||
|
|
||||||
|
conf_test:
|
||||||
|
name: Test configuration on Linux
|
||||||
|
needs: [gcc, clang]
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y g++-multilib gcc-avr avr-libc
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: AVR
|
||||||
|
run: avr-g++ -std=c++11 -Isrc extras/conf_test/avr.cpp
|
||||||
|
- name: GCC 32-bit
|
||||||
|
run: g++ -std=c++11 -m32 -Isrc extras/conf_test/x86.cpp
|
||||||
|
- name: GCC 64-bit
|
||||||
|
run: g++ -std=c++11 -m64 -Isrc extras/conf_test/x64.cpp
|
||||||
|
- name: Clang 32-bit
|
||||||
|
run: clang++ -std=c++11 -m32 -Isrc extras/conf_test/x86.cpp
|
||||||
|
- name: Clang 64-bit
|
||||||
|
run: clang++ -std=c++11 -m64 -Isrc extras/conf_test/x64.cpp
|
||||||
|
|
||||||
|
conf_test_windows:
|
||||||
|
name: Test configuration on Windows
|
||||||
|
runs-on: windows-2019
|
||||||
|
needs: [gcc, clang]
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: 32-bit
|
||||||
|
run: |
|
||||||
|
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars32.bat"
|
||||||
|
cl /Isrc extras/conf_test/x86.cpp
|
||||||
|
shell: cmd
|
||||||
|
- name: 64-bit
|
||||||
|
run: |
|
||||||
|
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars64.bat"
|
||||||
|
cl /Isrc extras/conf_test/x64.cpp
|
||||||
|
shell: cmd
|
||||||
|
|
||||||
|
xcode:
|
||||||
|
name: XCode
|
||||||
|
needs: clang
|
||||||
|
runs-on: macos-13
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- xcode: "14.1"
|
||||||
|
- xcode: "14.2"
|
||||||
|
- xcode: "14.3.1"
|
||||||
|
- xcode: "15.0.1"
|
||||||
|
- xcode: "15.1"
|
||||||
|
- xcode: "15.2"
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Select XCode version
|
||||||
|
run: sudo xcode-select --switch /Applications/Xcode_${{ matrix.xcode }}.app
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
- name: Build
|
||||||
|
run: cmake --build .
|
||||||
|
- name: Test
|
||||||
|
run: ctest --output-on-failure -C Debug .
|
||||||
|
|
||||||
|
# DISABLED: Running on AppVeyor instead because it supports older versions of the compiler
|
||||||
|
# msvc:
|
||||||
|
# name: Visual Studio
|
||||||
|
# strategy:
|
||||||
|
# fail-fast: false
|
||||||
|
# matrix:
|
||||||
|
# include:
|
||||||
|
# - os: windows-2016
|
||||||
|
# - os: windows-2019
|
||||||
|
# runs-on: ${{ matrix.os }}
|
||||||
|
# steps:
|
||||||
|
# - name: Checkout
|
||||||
|
# uses: actions/checkout@v4
|
||||||
|
# - name: Configure
|
||||||
|
# run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
# - name: Build
|
||||||
|
# run: cmake --build .
|
||||||
|
# - name: Test
|
||||||
|
# run: ctest --output-on-failure -C Debug .
|
||||||
|
|
||||||
|
arduino:
|
||||||
|
name: Arduino
|
||||||
|
needs: gcc
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- core: arduino:avr
|
||||||
|
board: arduino:avr:uno
|
||||||
|
- core: arduino:samd
|
||||||
|
board: arduino:samd:mkr1000
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install arduino-cli
|
||||||
|
run: curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | BINDIR=/usr/local/bin sh
|
||||||
|
- name: Install core
|
||||||
|
run: arduino-cli core install ${{ matrix.core }}
|
||||||
|
- name: Install libraries
|
||||||
|
run: arduino-cli lib install SD Ethernet
|
||||||
|
- name: Build JsonConfigFile
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonConfigFile/JsonConfigFile.ino"
|
||||||
|
- name: Build JsonFilterExample
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonFilterExample/JsonFilterExample.ino"
|
||||||
|
- name: Build JsonGeneratorExample
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonGeneratorExample/JsonGeneratorExample.ino"
|
||||||
|
- name: Build JsonHttpClient
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonHttpClient/JsonHttpClient.ino"
|
||||||
|
- name: Build JsonParserExample
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonParserExample/JsonParserExample.ino"
|
||||||
|
- name: Build JsonServer
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonServer/JsonServer.ino"
|
||||||
|
- name: Build JsonUdpBeacon
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/JsonUdpBeacon/JsonUdpBeacon.ino"
|
||||||
|
- name: Build MsgPackParser
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/MsgPackParser/MsgPackParser.ino"
|
||||||
|
- name: Build ProgmemExample
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/ProgmemExample/ProgmemExample.ino"
|
||||||
|
- name: Build StringExample
|
||||||
|
run: arduino-cli compile --library . --warnings all -b ${{ matrix.board }} "examples/StringExample/StringExample.ino"
|
||||||
|
|
||||||
|
platformio:
|
||||||
|
name: PlatformIO
|
||||||
|
needs: gcc
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- platform: atmelavr
|
||||||
|
board: leonardo
|
||||||
|
libraries:
|
||||||
|
- SD
|
||||||
|
- Ethernet
|
||||||
|
conf_test: avr
|
||||||
|
- platform: espressif8266
|
||||||
|
board: huzzah
|
||||||
|
conf_test: esp8266
|
||||||
|
- platform: espressif32
|
||||||
|
board: esp32dev
|
||||||
|
libraries:
|
||||||
|
- Ethernet
|
||||||
|
conf_test: esp8266
|
||||||
|
- platform: atmelsam
|
||||||
|
board: mkr1000USB
|
||||||
|
libraries:
|
||||||
|
- SD
|
||||||
|
- Ethernet
|
||||||
|
conf_test: esp8266
|
||||||
|
- platform: teensy
|
||||||
|
board: teensy31
|
||||||
|
conf_test: esp8266
|
||||||
|
- platform: ststm32
|
||||||
|
board: adafruit_feather_f405
|
||||||
|
libraries:
|
||||||
|
- SD
|
||||||
|
- Ethernet
|
||||||
|
conf_test: esp8266
|
||||||
|
- platform: nordicnrf52
|
||||||
|
board: adafruit_feather_nrf52840
|
||||||
|
libraries:
|
||||||
|
- SD
|
||||||
|
- Ethernet
|
||||||
|
conf_test: esp8266
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Set up cache for pip
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: ~/.cache/pip
|
||||||
|
key: ${{ runner.os }}-pip
|
||||||
|
- name: Set up Python 3.x
|
||||||
|
uses: actions/setup-python@v5
|
||||||
|
with:
|
||||||
|
python-version: "3.x"
|
||||||
|
- name: Install PlatformIO
|
||||||
|
run: pip install platformio
|
||||||
|
- name: Install adafruit-nrfutil
|
||||||
|
if: ${{ matrix.platform == 'nordicnrf52' }}
|
||||||
|
run: pip install adafruit-nrfutil
|
||||||
|
- name: Include Adafruit_TinyUSB.h # https://github.com/adafruit/Adafruit_nRF52_Arduino/issues/653
|
||||||
|
if: ${{ matrix.platform == 'nordicnrf52' }}
|
||||||
|
run: find examples/ -name '*.ino' -exec sed -i 's/\(#include <ArduinoJson.h>\)/\1\n#include <Adafruit_TinyUSB.h>/' {} +
|
||||||
|
- name: Set up cache for platformio
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: ~/.platformio
|
||||||
|
key: ${{ runner.os }}-platformio-${{ matrix.platform }}
|
||||||
|
- name: Install platform "${{ matrix.platform }}"
|
||||||
|
run: platformio platform install ${{ matrix.platform }}
|
||||||
|
- name: Install libraries
|
||||||
|
if: ${{ matrix.libraries }}
|
||||||
|
run: platformio lib install arduino-libraries/${{ join(matrix.libraries, ' arduino-libraries/') }}
|
||||||
|
- name: Test configuration
|
||||||
|
run: platformio ci "extras/conf_test/${{ matrix.conf_test }}.cpp" -l '.' -b ${{ matrix.board }}
|
||||||
|
if: ${{ matrix.conf_test }}
|
||||||
|
- name: Build JsonConfigFile
|
||||||
|
run: platformio ci "examples/JsonConfigFile/JsonConfigFile.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonFilterExample
|
||||||
|
run: platformio ci "examples/JsonFilterExample/JsonFilterExample.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonGeneratorExample
|
||||||
|
run: platformio ci "examples/JsonGeneratorExample/JsonGeneratorExample.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonHttpClient
|
||||||
|
run: platformio ci "examples/JsonHttpClient/JsonHttpClient.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonParserExample
|
||||||
|
run: platformio ci "examples/JsonParserExample/JsonParserExample.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonServer
|
||||||
|
if: ${{ matrix.platform != 'espressif32' }}
|
||||||
|
run: platformio ci "examples/JsonServer/JsonServer.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build JsonUdpBeacon
|
||||||
|
run: platformio ci "examples/JsonUdpBeacon/JsonUdpBeacon.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build MsgPackParser
|
||||||
|
run: platformio ci "examples/MsgPackParser/MsgPackParser.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build ProgmemExample
|
||||||
|
run: platformio ci "examples/ProgmemExample/ProgmemExample.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: Build StringExample
|
||||||
|
run: platformio ci "examples/StringExample/StringExample.ino" -l '.' -b ${{ matrix.board }}
|
||||||
|
- name: PlatformIO prune
|
||||||
|
if: ${{ always() }}
|
||||||
|
run: platformio system prune -f
|
||||||
|
|
||||||
|
particle:
|
||||||
|
name: Particle
|
||||||
|
needs: gcc
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
if: github.event_name == 'push'
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- board: argon
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install Particle CLI
|
||||||
|
run: sudo npm install -g particle-cli
|
||||||
|
- name: Login to Particle
|
||||||
|
run: particle login -t "${{ secrets.PARTICLE_TOKEN }}"
|
||||||
|
- name: Compile
|
||||||
|
run: extras/ci/particle.sh ${{ matrix.board }}
|
||||||
|
|
||||||
|
arm:
|
||||||
|
name: GCC for ARM processor
|
||||||
|
needs: gcc
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y g++-arm-linux-gnueabihf
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Configure
|
||||||
|
run: cmake .
|
||||||
|
env:
|
||||||
|
CC: arm-linux-gnueabihf-gcc
|
||||||
|
CXX: arm-linux-gnueabihf-g++
|
||||||
|
- name: Build
|
||||||
|
run: cmake --build .
|
||||||
|
|
||||||
|
coverage:
|
||||||
|
needs: gcc
|
||||||
|
name: Coverage
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: sudo apt-get install -y lcov ninja-build
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -G Ninja -DCOVERAGE=true .
|
||||||
|
- name: Build
|
||||||
|
run: ninja
|
||||||
|
- name: Test
|
||||||
|
run: ctest --output-on-failure -LE 'WillFail|Fuzzing' -T test
|
||||||
|
- name: lcov --capture
|
||||||
|
run: lcov --capture --no-external --directory . --output-file coverage.info
|
||||||
|
- name: lcov --remove
|
||||||
|
run: lcov --remove coverage.info "$(pwd)/extras/*" --output-file coverage_filtered.info
|
||||||
|
- name: genhtml
|
||||||
|
run: mkdir coverage && genhtml coverage_filtered.info -o coverage -t ArduinoJson
|
||||||
|
- name: Upload HTML report
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: Coverage report
|
||||||
|
path: coverage
|
||||||
|
- name: Upload to Coveralls
|
||||||
|
uses: coverallsapp/github-action@v2
|
||||||
|
with:
|
||||||
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
path-to-lcov: coverage_filtered.info
|
||||||
|
|
||||||
|
valgrind:
|
||||||
|
needs: gcc
|
||||||
|
name: Valgrind
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y valgrind ninja-build
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -G Ninja -D MEMORYCHECK_COMMAND_OPTIONS="--error-exitcode=1 --leak-check=full" .
|
||||||
|
- name: Build
|
||||||
|
run: ninja
|
||||||
|
- name: Memcheck
|
||||||
|
run: ctest --output-on-failure -LE WillFail -T memcheck
|
||||||
|
id: memcheck
|
||||||
|
- name: MemoryChecker.*.log
|
||||||
|
run: cat Testing/Temporary/MemoryChecker.*.log > $GITHUB_STEP_SUMMARY
|
||||||
|
if: failure()
|
||||||
|
|
||||||
|
clang-tidy:
|
||||||
|
needs: clang
|
||||||
|
name: Clang-Tidy
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: sudo apt-get install -y clang-tidy libc++-dev libc++abi-dev
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Configure
|
||||||
|
run: cmake -G Ninja -DCMAKE_CXX_CLANG_TIDY="clang-tidy;--warnings-as-errors=*" -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
env:
|
||||||
|
CC: clang
|
||||||
|
CXX: clang++
|
||||||
|
- name: Check
|
||||||
|
run: cmake --build . -- -k 0
|
||||||
|
|
||||||
|
amalgamate:
|
||||||
|
needs: gcc
|
||||||
|
name: Amalgamate ArduinoJson.h
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Setup
|
||||||
|
run: |
|
||||||
|
if [[ $GITHUB_REF == refs/tags/* ]]; then
|
||||||
|
VERSION=${GITHUB_REF#refs/tags/}
|
||||||
|
else
|
||||||
|
VERSION=${GITHUB_SHA::7}
|
||||||
|
fi
|
||||||
|
echo "ARDUINOJSON_H=ArduinoJson-$VERSION.h" >> $GITHUB_ENV
|
||||||
|
echo "ARDUINOJSON_HPP=ArduinoJson-$VERSION.hpp" >> $GITHUB_ENV
|
||||||
|
- name: Amalgamate ArduinoJson.h
|
||||||
|
run: extras/scripts/build-single-header.sh "src/ArduinoJson.h" "$ARDUINOJSON_H"
|
||||||
|
- name: Amalgamate ArduinoJson.hpp
|
||||||
|
run: extras/scripts/build-single-header.sh "src/ArduinoJson.hpp" "$ARDUINOJSON_HPP"
|
||||||
|
- name: Upload artifact
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: Single headers
|
||||||
|
path: |
|
||||||
|
${{ env.ARDUINOJSON_H }}
|
||||||
|
${{ env.ARDUINOJSON_HPP }}
|
||||||
|
- name: Smoke test ArduinoJson.h
|
||||||
|
run: |
|
||||||
|
g++ -x c++ - <<END
|
||||||
|
#include "$ARDUINOJSON_H"
|
||||||
|
int main() {
|
||||||
|
JsonDocument doc;
|
||||||
|
deserializeJson(doc, "{}");
|
||||||
|
}
|
||||||
|
END
|
||||||
|
- name: Smoke test ArduinoJson.hpp
|
||||||
|
run: |
|
||||||
|
g++ -x c++ - <<END
|
||||||
|
#include "$ARDUINOJSON_HPP"
|
||||||
|
int main() {
|
||||||
|
ArduinoJson::JsonDocument doc;
|
||||||
|
deserializeJson(doc, "{}");
|
||||||
|
}
|
||||||
|
END
|
||||||
|
|
||||||
|
esp-idf:
|
||||||
|
needs: gcc
|
||||||
|
name: ESP-IDF
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Setup cache
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: ~/.espressif
|
||||||
|
key: ${{ runner.os }}-esp-idf
|
||||||
|
- name: Checkout ArduinoJson
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Checkout ESP-IDF
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
repository: espressif/esp-idf
|
||||||
|
path: esp-idf
|
||||||
|
submodules: true
|
||||||
|
- name: Install ESP-IDF
|
||||||
|
run: ./esp-idf/install.sh
|
||||||
|
- name: Add component
|
||||||
|
# NOTE: we cannot commit the symlink because the Arduino Library Specification forbids it.
|
||||||
|
run: |
|
||||||
|
mkdir -p extras/ci/espidf/components
|
||||||
|
ln -s $PWD extras/ci/espidf/components/ArduinoJson
|
||||||
|
- name: Build example
|
||||||
|
run: |
|
||||||
|
source esp-idf/export.sh
|
||||||
|
cd extras/ci/espidf
|
||||||
|
idf.py build
|
||||||
|
|
||||||
|
codeql:
|
||||||
|
name: CodeQL
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
needs: gcc
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
actions: read
|
||||||
|
contents: read
|
||||||
|
security-events: write
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Initialize CodeQL
|
||||||
|
uses: github/codeql-action/init@v3
|
||||||
|
with:
|
||||||
|
languages: cpp
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: |
|
||||||
|
cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
|
cmake --build .
|
||||||
|
|
||||||
|
- name: Perform CodeQL Analysis
|
||||||
|
uses: github/codeql-action/analyze@v3
|
||||||
|
with:
|
||||||
|
category: "/language:cpp"
|
14
.github/workflows/lock.yml
vendored
Normal file
14
.github/workflows/lock.yml
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
name: Lock Threads
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '0 0 * * *'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lock:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: dessant/lock-threads@v5
|
||||||
|
with:
|
||||||
|
github-token: ${{ github.token }}
|
||||||
|
issue-inactive-days: 30
|
93
.github/workflows/release.yml
vendored
Normal file
93
.github/workflows/release.yml
vendored
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
name: Release
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- v*.*.*
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
release:
|
||||||
|
name: Create release
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: Set variables
|
||||||
|
id: init
|
||||||
|
run: |
|
||||||
|
echo "tag=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
|
||||||
|
echo "version=${GITHUB_REF#refs/tags/v}" >> $GITHUB_OUTPUT
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Write release body
|
||||||
|
id: body
|
||||||
|
run: |
|
||||||
|
FILENAME=RELEASE.md
|
||||||
|
tee $FILENAME <<END
|
||||||
|
## Changes
|
||||||
|
|
||||||
|
$(extras/scripts/extract_changes.awk CHANGELOG.md)
|
||||||
|
|
||||||
|
[View version history](https://github.com/bblanchon/ArduinoJson/blob/${{ steps.init.outputs.tag }}/CHANGELOG.md)
|
||||||
|
END
|
||||||
|
echo "filename=$FILENAME" >> $GITHUB_OUTPUT
|
||||||
|
- name: Amalgamate ArduinoJson.h
|
||||||
|
id: amalgamate_h
|
||||||
|
run: |
|
||||||
|
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.h
|
||||||
|
extras/scripts/build-single-header.sh src/ArduinoJson.h "$FILENAME"
|
||||||
|
echo "filename=$FILENAME" >> $GITHUB_OUTPUT
|
||||||
|
- name: Amalgamate ArduinoJson.hpp
|
||||||
|
id: amalgamate_hpp
|
||||||
|
run: |
|
||||||
|
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.hpp
|
||||||
|
extras/scripts/build-single-header.sh src/ArduinoJson.hpp "$FILENAME"
|
||||||
|
echo "filename=$FILENAME" >> $GITHUB_OUTPUT
|
||||||
|
- name: Create release
|
||||||
|
uses: ncipollo/release-action@v1
|
||||||
|
with:
|
||||||
|
bodyFile: ${{ steps.body.outputs.filename }}
|
||||||
|
name: ArduinoJson ${{ steps.init.outputs.version }}
|
||||||
|
artifacts: ${{ steps.amalgamate_h.outputs.filename }},${{ steps.amalgamate_hpp.outputs.filename }}
|
||||||
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
idf:
|
||||||
|
name: IDF Component Registry
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Upload component to the component registry
|
||||||
|
uses: espressif/upload-components-ci-action@v1
|
||||||
|
with:
|
||||||
|
name: ArduinoJson
|
||||||
|
namespace: bblanchon
|
||||||
|
api_token: ${{ secrets.IDF_COMPONENT_API_TOKEN }}
|
||||||
|
|
||||||
|
particle:
|
||||||
|
name: Particle
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Install
|
||||||
|
run: npm install -g particle-cli
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Login
|
||||||
|
run: particle login --token ${{ secrets.PARTICLE_TOKEN }}
|
||||||
|
- name: Publish
|
||||||
|
run: bash -eux extras/scripts/publish-particle-library.sh
|
||||||
|
|
||||||
|
platformio:
|
||||||
|
name: PlatformIO
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Set up Python 3.x
|
||||||
|
uses: actions/setup-python@v5
|
||||||
|
with:
|
||||||
|
python-version: "3.x"
|
||||||
|
- name: Install PlatformIO
|
||||||
|
run: pip install platformio
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Publish
|
||||||
|
run: pio pkg publish --no-interactive --no-notify
|
||||||
|
env:
|
||||||
|
PLATFORMIO_AUTH_TOKEN: ${{ secrets.PLATFORMIO_AUTH_TOKEN }}
|
15
.gitignore
vendored
15
.gitignore
vendored
@ -3,3 +3,18 @@
|
|||||||
/build
|
/build
|
||||||
/bin
|
/bin
|
||||||
/lib
|
/lib
|
||||||
|
/sftp-config.json
|
||||||
|
.tags
|
||||||
|
.tags_sorted_by_file
|
||||||
|
/extras/fuzzing/*_fuzzer
|
||||||
|
/extras/fuzzing/*_fuzzer.options
|
||||||
|
/extras/fuzzing/*_fuzzer_seed_corpus.zip
|
||||||
|
.vs/
|
||||||
|
/out/
|
||||||
|
|
||||||
|
# Used by CI for Particle
|
||||||
|
/src/*.ino
|
||||||
|
/project.properties
|
||||||
|
|
||||||
|
# Used by IDF
|
||||||
|
/dist/
|
||||||
|
4
.mbedignore
Normal file
4
.mbedignore
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
.devcontainer/
|
||||||
|
.github/
|
||||||
|
examples/
|
||||||
|
extras/
|
1
.prettierignore
Normal file
1
.prettierignore
Normal file
@ -0,0 +1 @@
|
|||||||
|
*.md
|
@ -1,6 +0,0 @@
|
|||||||
language: c++
|
|
||||||
compiler:
|
|
||||||
- gcc
|
|
||||||
- clang
|
|
||||||
before_script: cmake .
|
|
||||||
script: make && make test
|
|
17
.vscode/settings.json
vendored
Normal file
17
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"C_Cpp.default.configurationProvider": "ms-vscode.cmake-tools",
|
||||||
|
"git.inputValidationLength": 80,
|
||||||
|
"git.inputValidationSubjectLength": 72,
|
||||||
|
"files.insertFinalNewline": true,
|
||||||
|
"files.trimFinalNewlines": true,
|
||||||
|
"search.exclude": {
|
||||||
|
"/extras/tests/catch/*": true
|
||||||
|
},
|
||||||
|
"C_Cpp.default.includePath": [
|
||||||
|
"/src"
|
||||||
|
],
|
||||||
|
"[cmake]": {
|
||||||
|
"editor.detectIndentation": false,
|
||||||
|
"editor.insertSpaces": false,
|
||||||
|
}
|
||||||
|
}
|
5
ArduinoJson.h
Normal file
5
ArduinoJson.h
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include "src/ArduinoJson.h"
|
336
CHANGELOG.md
336
CHANGELOG.md
@ -1,112 +1,292 @@
|
|||||||
Arduino JSON: change log
|
ArduinoJson: change log
|
||||||
========================
|
=======================
|
||||||
|
|
||||||
v4.0
|
HEAD
|
||||||
----
|
----
|
||||||
|
|
||||||
* Unified parser and generator API (issue #23)
|
* Optimize storage of static strings
|
||||||
* Updated library layout, now requires Arduino 1.0.6 or newer
|
|
||||||
|
|
||||||
**BREAKING CHANGE**: API changed significantly, see `doc/Migrating to the new API.md`.
|
> ### BREAKING CHANGES
|
||||||
|
>
|
||||||
|
> Static string cannot contain NUL characters anymore (they could since 7.3.0).
|
||||||
|
> This is an extremely rare case, so you probably won't be affected.
|
||||||
|
>
|
||||||
|
> For example, the following code produces different output in 7.3 and 7.4:
|
||||||
|
>
|
||||||
|
> ```cpp
|
||||||
|
> JsonDocument doc;
|
||||||
|
> doc["a\0b"] = "c\0d";
|
||||||
|
> serializeJson(doc, Serial);
|
||||||
|
> // With Arduino 7.3 -> {"a\u0000b":"c\u0000d"}
|
||||||
|
> // With Arduino 7.4 -> {"a":"c"}
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> `JsonString` contructor now only accepts two arguments, not three.
|
||||||
|
> If your code uses `JsonString` to store a string as a pointer, you must remove the size argument.
|
||||||
|
>
|
||||||
|
> For example, if you have something like this:
|
||||||
|
>
|
||||||
|
> ```cpp
|
||||||
|
> doc["key"] = JsonString(str.c_str(), str.size(), true);
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> You must replace with either:
|
||||||
|
>
|
||||||
|
> ```cpp
|
||||||
|
> doc["key"] = JsonString(str.c_str(), true); // store as pointer, cannot contain NUL characters
|
||||||
|
> doc["key"] = JsonString(str.c_str(), str.size()); // store by copy, NUL characters allowed
|
||||||
|
> doc["key"] = str; // same as previous line for supported string classes (`String`, `std::string`, etc.)
|
||||||
|
> ```
|
||||||
|
|
||||||
|
v7.4.2 (2025-06-20)
|
||||||
|
------
|
||||||
|
|
||||||
v3.4
|
* Fix truncated strings on Arduino Due (issue #2181)
|
||||||
----
|
|
||||||
|
|
||||||
* Fixed escaped char parsing (issue #16)
|
v7.4.1 (2025-04-11)
|
||||||
|
------
|
||||||
|
|
||||||
v3.3
|
* Fix crash with tiny Flash strings (issue #2170)
|
||||||
----
|
|
||||||
|
|
||||||
* Added indented output for the JSON generator (issue #11), see example bellow.
|
v7.4.0 (2025-04-09)
|
||||||
* Added `IndentedPrint`, a decorator for `Print` to allow indented output
|
------
|
||||||
|
|
||||||
Example:
|
* Optimize storage of tiny strings (up to 3 characters)
|
||||||
|
* Fix support for `const char[]` (issue #2166)
|
||||||
|
|
||||||
JsonOject<2> json;
|
v7.3.1 (2025-02-27)
|
||||||
json["key"] = "value";
|
------
|
||||||
json.prettyPrintTo(Serial);
|
|
||||||
|
|
||||||
v3.2
|
* Fix conversion from static string to number
|
||||||
----
|
* Slightly reduce code size
|
||||||
|
|
||||||
* Fixed a bug when adding nested object in `JsonArray` (bug introduced in v3.1).
|
v7.3.0 (2024-12-29)
|
||||||
|
------
|
||||||
|
|
||||||
v3.1
|
* Fix support for NUL characters in `deserializeJson()`
|
||||||
----
|
* Make `ElementProxy` and `MemberProxy` non-copyable
|
||||||
|
* Change string copy policy: only string literal are stored by pointer
|
||||||
|
* `JsonString` is now stored by copy, unless specified otherwise
|
||||||
|
* Replace undocumented `JsonString::Ownership` with `bool`
|
||||||
|
* Rename undocumented `JsonString::isLinked()` to `isStatic()`
|
||||||
|
* Move public facing SFINAEs to template declarations
|
||||||
|
|
||||||
* Calling `Generator::JsonObject::add()` twice with the same `key` now replaces the `value`
|
> ### BREAKING CHANGES
|
||||||
* Added `Generator::JsonObject::operator[]`, see bellow the new API
|
>
|
||||||
* Added `Generator::JsonObject::remove()` (issue #9)
|
> In previous versions, `MemberProxy` (the class returned by `operator[]`) could lead to dangling pointers when used with a temporary string.
|
||||||
|
> To prevent this issue, `MemberProxy` and `ElementProxy` are now non-copyable.
|
||||||
|
>
|
||||||
|
> Your code is likely to be affected if you use `auto` to store the result of `operator[]`. For example, the following line won't compile anymore:
|
||||||
|
>
|
||||||
|
> ```cpp
|
||||||
|
> auto value = doc["key"];
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> To fix the issue, you must append either `.as<T>()` or `.to<T>()`, depending on the situation.
|
||||||
|
>
|
||||||
|
> For example, if you are extracting values from a JSON document, you should update like this:
|
||||||
|
>
|
||||||
|
> ```diff
|
||||||
|
> - auto config = doc["config"];
|
||||||
|
> + auto config = doc["config"].as<JsonObject>();
|
||||||
|
> const char* name = config["name"];
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> However, if you are building a JSON document, you should update like this:
|
||||||
|
>
|
||||||
|
> ```diff
|
||||||
|
> - auto config = doc["config"];
|
||||||
|
> + auto config = doc["config"].to<JsonObject>();
|
||||||
|
> config["name"] = "ArduinoJson";
|
||||||
|
> ```
|
||||||
|
|
||||||
Old generator API:
|
v7.2.1 (2024-11-15)
|
||||||
|
------
|
||||||
|
|
||||||
JsonObject<3> root;
|
* Forbid `deserializeJson(JsonArray|JsonObject, ...)` (issue #2135)
|
||||||
root.add("sensor", "gps");
|
* Fix VLA support in `JsonDocument::set()`
|
||||||
root.add("time", 1351824120);
|
* Fix `operator[](variant)` ignoring NUL characters
|
||||||
root.add("data", array);
|
|
||||||
|
|
||||||
New generator API:
|
v7.2.0 (2024-09-18)
|
||||||
|
------
|
||||||
|
|
||||||
JsonObject<3> root;
|
* Store object members with two slots: one for the key and one for the value
|
||||||
root["sensor"] = "gps";
|
* Store 64-bit numbers (`double` and `long long`) in an additional slot
|
||||||
root["time"] = 1351824120;
|
* Reduce the slot size (see table below)
|
||||||
root["data"] = array;
|
* Improve message when user forgets third arg of `serializeJson()` et al.
|
||||||
|
* Set `ARDUINOJSON_USE_DOUBLE` to `0` by default on 8-bit architectures
|
||||||
|
* Deprecate `containsKey()` in favor of `doc["key"].is<T>()`
|
||||||
|
* Add support for escape sequence `\'` (issue #2124)
|
||||||
|
|
||||||
v3.0
|
| Architecture | before | after |
|
||||||
----
|
|--------------|----------|----------|
|
||||||
|
| 8-bit | 8 bytes | 6 bytes |
|
||||||
|
| 32-bit | 16 bytes | 8 bytes |
|
||||||
|
| 64-bit | 24 bytes | 16 bytes |
|
||||||
|
|
||||||
* New parser API, see bellow
|
> ### BREAKING CHANGES
|
||||||
* Renamed `JsonHashTable` into `JsonObject`
|
>
|
||||||
* Added iterators for `JsonArray` and `JsonObject` (issue #4)
|
> After being on the death row for years, the `containsKey()` method has finally been deprecated.
|
||||||
|
> You should replace `doc.containsKey("key")` with `doc["key"].is<T>()`, which not only checks that the key exists but also that the value is of the expected type.
|
||||||
|
>
|
||||||
|
> ```cpp
|
||||||
|
> // Before
|
||||||
|
> if (doc.containsKey("value")) {
|
||||||
|
> int value = doc["value"];
|
||||||
|
> // ...
|
||||||
|
> }
|
||||||
|
>
|
||||||
|
> // After
|
||||||
|
> if (doc["value"].is<int>()) {
|
||||||
|
> int value = doc["value"];
|
||||||
|
> // ...
|
||||||
|
> }
|
||||||
|
> ```
|
||||||
|
|
||||||
Old parser API:
|
v7.1.0 (2024-06-27)
|
||||||
|
------
|
||||||
|
|
||||||
JsonHashTable root = parser.parseHashTable(json);
|
* Add `ARDUINOJSON_STRING_LENGTH_SIZE` to the namespace name
|
||||||
|
* Add support for MsgPack binary (PR #2078 by @Sanae6)
|
||||||
|
* Add support for MsgPack extension
|
||||||
|
* Make string support even more generic (PR #2084 by @d-a-v)
|
||||||
|
* Optimize `deserializeMsgPack()`
|
||||||
|
* Allow using a `JsonVariant` as a key or index (issue #2080)
|
||||||
|
Note: works only for reading, not for writing
|
||||||
|
* Support `ElementProxy` and `MemberProxy` in `JsonDocument`'s constructor
|
||||||
|
* Don't add partial objects when allocation fails (issue #2081)
|
||||||
|
* Read MsgPack's 64-bit integers even if `ARDUINOJSON_USE_LONG_LONG` is `0`
|
||||||
|
(they are set to `null` if they don't fit in a `long`)
|
||||||
|
|
||||||
char* sensor = root.getString("sensor");
|
v7.0.4 (2024-03-12)
|
||||||
long time = root.getLong("time");
|
------
|
||||||
double latitude = root.getArray("data").getDouble(0);
|
|
||||||
double longitude = root.getArray("data").getDouble(1);
|
|
||||||
|
|
||||||
New parser API:
|
* Make `JSON_STRING_SIZE(N)` return `N+1` to fix third-party code (issue #2054)
|
||||||
|
|
||||||
JsonObject root = parser.parse(json);
|
v7.0.3 (2024-02-05)
|
||||||
|
------
|
||||||
|
|
||||||
char* sensor = root["sensor"];
|
* Improve error messages when using `char` or `char*` (issue #2043)
|
||||||
long time = root["time"];
|
* Reduce stack consumption (issue #2046)
|
||||||
double latitude = root["data"][0];
|
* Fix compatibility with GCC 4.8 (issue #2045)
|
||||||
double longitude = root["data"][1];
|
|
||||||
|
|
||||||
v2.1
|
v7.0.2 (2024-01-19)
|
||||||
----
|
------
|
||||||
|
|
||||||
* Fixed case `#include "jsmn.cpp"` which caused an error in Linux (issue #6)
|
* Fix assertion `poolIndex < count_` after `JsonDocument::clear()` (issue #2034)
|
||||||
* Fixed a buffer overrun in JSON Parser (issue #5)
|
|
||||||
|
|
||||||
v2.0
|
v7.0.1 (2024-01-10)
|
||||||
----
|
------
|
||||||
|
|
||||||
* Added JSON encoding (issue #2)
|
* Fix "no matching function" with `JsonObjectConst::operator[]` (issue #2019)
|
||||||
* Renamed the library `ArduinoJsonParser` becomes `ArduinoJson`
|
* Remove unused files in the PlatformIO package
|
||||||
|
* Fix `volatile bool` serialized as `1` or `0` instead of `true` or `false` (issue #2029)
|
||||||
|
|
||||||
**Breaking change**: you need to add the following line at the top of your program.
|
v7.0.0 (2024-01-03)
|
||||||
|
------
|
||||||
|
|
||||||
using namespace ArduinoJson::Parser;
|
* Remove `BasicJsonDocument`
|
||||||
|
* Remove `StaticJsonDocument`
|
||||||
|
* Add abstract `Allocator` class
|
||||||
|
* Merge `DynamicJsonDocument` with `JsonDocument`
|
||||||
|
* Remove `JSON_ARRAY_SIZE()`, `JSON_OBJECT_SIZE()`, and `JSON_STRING_SIZE()`
|
||||||
|
* Remove `ARDUINOJSON_ENABLE_STRING_DEDUPLICATION` (string deduplication cannot be disabled anymore)
|
||||||
|
* Remove `JsonDocument::capacity()`
|
||||||
|
* Store the strings in the heap
|
||||||
|
* Reference-count shared strings
|
||||||
|
* Always store `serialized("string")` by copy (#1915)
|
||||||
|
* Remove the zero-copy mode of `deserializeJson()` and `deserializeMsgPack()`
|
||||||
|
* Fix double lookup in `to<JsonVariant>()`
|
||||||
|
* Fix double call to `size()` in `serializeMsgPack()`
|
||||||
|
* Include `ARDUINOJSON_SLOT_OFFSET_SIZE` in the namespace name
|
||||||
|
* Remove `JsonVariant::shallowCopy()`
|
||||||
|
* `JsonDocument`'s capacity grows as needed, no need to pass it to the constructor anymore
|
||||||
|
* `JsonDocument`'s allocator is not monotonic anymore, removed values get recycled
|
||||||
|
* Show a link to the documentation when user passes an unsupported input type
|
||||||
|
* Remove `JsonDocument::memoryUsage()`
|
||||||
|
* Remove `JsonDocument::garbageCollect()`
|
||||||
|
* Add `deserializeJson(JsonVariant, ...)` and `deserializeMsgPack(JsonVariant, ...)` (#1226)
|
||||||
|
* Call `shrinkToFit()` in `deserializeJson()` and `deserializeMsgPack()`
|
||||||
|
* `serializeJson()` and `serializeMsgPack()` replace the content of `std::string` and `String` instead of appending to it
|
||||||
|
* Replace `add()` with `add<T>()` (`add(T)` is still supported)
|
||||||
|
* Remove `createNestedArray()` and `createNestedObject()` (use `to<JsonArray>()` and `to<JsonObject>()` instead)
|
||||||
|
|
||||||
v1.2
|
> ### BREAKING CHANGES
|
||||||
----
|
>
|
||||||
|
> As every major release, ArduinoJson 7 introduces several breaking changes.
|
||||||
* Fixed error in JSON parser example (issue #1)
|
> I added some stubs so that most existing programs should compile, but I highty recommend you upgrade your code.
|
||||||
|
>
|
||||||
v1.1
|
> #### `JsonDocument`
|
||||||
----
|
>
|
||||||
|
> In ArduinoJson 6, you could allocate the memory pool on the stack (with `StaticJsonDocument`) or in the heap (with `DynamicJsonDocument`).
|
||||||
* Example: changed `char* json` into `char[] json` so that the bytes are not write protected
|
> In ArduinoJson 7, the memory pool is always allocated in the heap, so `StaticJsonDocument` and `DynamicJsonDocument` have been merged into `JsonDocument`.
|
||||||
* Fixed parsing bug when the JSON contains multi-dimensional arrays
|
>
|
||||||
|
> In ArduinoJson 6, `JsonDocument` had a fixed capacity; in ArduinoJson 7, it has an elastic capacity that grows as needed.
|
||||||
v1.0
|
> Therefore, you don't need to specify the capacity anymore, so the macros `JSON_ARRAY_SIZE()`, `JSON_OBJECT_SIZE()`, and `JSON_STRING_SIZE()` have been removed.
|
||||||
----
|
>
|
||||||
|
> ```c++
|
||||||
Initial release
|
> // ArduinoJson 6
|
||||||
|
> StaticJsonDocument<256> doc;
|
||||||
|
> // or
|
||||||
|
> DynamicJsonDocument doc(256);
|
||||||
|
>
|
||||||
|
> // ArduinoJson 7
|
||||||
|
> JsonDocument doc;
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> In ArduinoJson 7, `JsonDocument` reuses released memory, so `garbageCollect()` has been removed.
|
||||||
|
> `shrinkToFit()` is still available and releases the over-allocated memory.
|
||||||
|
>
|
||||||
|
> Due to a change in the implementation, it's not possible to store a pointer to a variant from another `JsonDocument`, so `shallowCopy()` has been removed.
|
||||||
|
>
|
||||||
|
> In ArduinoJson 6, the meaning of `memoryUsage()` was clear: it returned the number of bytes used in the memory pool.
|
||||||
|
> In ArduinoJson 7, the meaning of `memoryUsage()` would be ambiguous, so it has been removed.
|
||||||
|
>
|
||||||
|
> #### Custom allocators
|
||||||
|
>
|
||||||
|
> In ArduinoJson 6, you could specify a custom allocator class as a template parameter of `BasicJsonDocument`.
|
||||||
|
> In ArduinoJson 7, you must inherit from `ArduinoJson::Allocator` and pass a pointer to an instance of your class to the constructor of `JsonDocument`.
|
||||||
|
>
|
||||||
|
> ```c++
|
||||||
|
> // ArduinoJson 6
|
||||||
|
> class MyAllocator {
|
||||||
|
> // ...
|
||||||
|
> };
|
||||||
|
> BasicJsonDocument<MyAllocator> doc(256);
|
||||||
|
>
|
||||||
|
> // ArduinoJson 7
|
||||||
|
> class MyAllocator : public ArduinoJson::Allocator {
|
||||||
|
> // ...
|
||||||
|
> };
|
||||||
|
> MyAllocator myAllocator;
|
||||||
|
> JsonDocument doc(&myAllocator);
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> #### `createNestedArray()` and `createNestedObject()`
|
||||||
|
>
|
||||||
|
> In ArduinoJson 6, you could create a nested array or object with `createNestedArray()` and `createNestedObject()`.
|
||||||
|
> In ArduinoJson 7, you must use `add<T>()` or `to<T>()` instead.
|
||||||
|
>
|
||||||
|
> For example, to create `[[],{}]`, you would write:
|
||||||
|
>
|
||||||
|
> ```c++
|
||||||
|
> // ArduinoJson 6
|
||||||
|
> arr.createNestedArray();
|
||||||
|
> arr.createNestedObject();
|
||||||
|
>
|
||||||
|
> // ArduinoJson 7
|
||||||
|
> arr.add<JsonArray>();
|
||||||
|
> arr.add<JsonObject>();
|
||||||
|
> ```
|
||||||
|
>
|
||||||
|
> And to create `{"array":[],"object":{}}`, you would write:
|
||||||
|
>
|
||||||
|
> ```c++
|
||||||
|
> // ArduinoJson 6
|
||||||
|
> obj.createNestedArray("array");
|
||||||
|
> obj.createNestedObject("object");
|
||||||
|
>
|
||||||
|
> // ArduinoJson 7
|
||||||
|
> obj["array"].to<JsonArray>();
|
||||||
|
> obj["object"].to<JsonObject>();
|
||||||
|
> ```
|
||||||
|
@ -1,15 +1,25 @@
|
|||||||
cmake_minimum_required(VERSION 2.8.4)
|
# ArduinoJson - https://arduinojson.org
|
||||||
project(ArduinoJson)
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
# MIT License
|
||||||
|
|
||||||
enable_testing()
|
cmake_minimum_required(VERSION 3.15)
|
||||||
|
|
||||||
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/lib)
|
if(ESP_PLATFORM)
|
||||||
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/lib)
|
# Build ArduinoJson as an ESP-IDF component
|
||||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/bin)
|
idf_component_register(INCLUDE_DIRS src)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
if(MSVC)
|
project(ArduinoJson VERSION 7.4.2)
|
||||||
add_definitions(-D_CRT_SECURE_NO_WARNINGS -W4)
|
|
||||||
|
if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME)
|
||||||
|
include(CTest)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(src)
|
add_subdirectory(src)
|
||||||
add_subdirectory(test)
|
|
||||||
|
if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME AND BUILD_TESTING)
|
||||||
|
include(extras/CompileOptions.cmake)
|
||||||
|
add_subdirectory(extras/tests)
|
||||||
|
add_subdirectory(extras/fuzzing)
|
||||||
|
endif()
|
||||||
|
10
CONTRIBUTING.md
Normal file
10
CONTRIBUTING.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# Contribution to ArduinoJson
|
||||||
|
|
||||||
|
First, thank you for taking the time to contribute to this project.
|
||||||
|
|
||||||
|
You can submit changes via GitHub Pull Requests.
|
||||||
|
|
||||||
|
Please:
|
||||||
|
|
||||||
|
1. Update the test suite for any change of behavior
|
||||||
|
2. Use clang-format in "file" mode to format the code
|
@ -1,10 +1,10 @@
|
|||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
Copyright © 2014 Benoit BLANCHON
|
Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
226
README.md
226
README.md
@ -1,79 +1,153 @@
|
|||||||
Arduino JSON library
|
<p align="center">
|
||||||
====================
|
<a href="https://arduinojson.org/"><img alt="ArduinoJson" src="https://arduinojson.org/images/logo.svg" width="200" /></a>
|
||||||
|
</p>
|
||||||
[](https://travis-ci.org/bblanchon/ArduinoJson)
|
|
||||||
|
|
||||||
*An elegant and efficient JSON library for embedded systems.*
|
|
||||||
|
|
||||||
It's design to have the most intuitive API, the smallest footprint and works without any allocation on the heap (no malloc).
|
|
||||||
|
|
||||||
It has been written with Arduino in mind, but it isn't linked to Arduino libraries so you can use this library in any other C++ project.
|
|
||||||
|
|
||||||
Features
|
|
||||||
--------
|
|
||||||
|
|
||||||
* JSON decoding
|
|
||||||
* JSON encoding (with optional indentation)
|
|
||||||
* Elegant API, very easy to use
|
|
||||||
* Fixed memory allocation (no malloc)
|
|
||||||
* Small footprint
|
|
||||||
* MIT License
|
|
||||||
|
|
||||||
Quick start
|
|
||||||
-----------
|
|
||||||
|
|
||||||
#### Decoding / Parsing
|
|
||||||
|
|
||||||
char json[] = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
|
||||||
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
|
||||||
|
|
||||||
JsonObject& root = jsonBuffer.parseObject(json);
|
|
||||||
|
|
||||||
const char* sensor = root["sensor"];
|
|
||||||
long time = root["time"];
|
|
||||||
double latitude = root["data"][0];
|
|
||||||
double longitude = root["data"][1];
|
|
||||||
|
|
||||||
[See complete guide](/doc/Decoding JSON.md)
|
|
||||||
|
|
||||||
#### Encoding / Generating
|
|
||||||
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
|
||||||
|
|
||||||
JsonObject& root = jsonBuffer.createObject();
|
|
||||||
root["sensor"] = "gps";
|
|
||||||
root["time"] = 1351824120;
|
|
||||||
|
|
||||||
JsonArray& data = root.createNestedArray("data");
|
|
||||||
data.add(48.756080, 6); // 6 is the number of decimals to print
|
|
||||||
data.add(2.302038, 6); // if not specified, 2 digits are printed
|
|
||||||
|
|
||||||
root.printTo(Serial);
|
|
||||||
// This prints:
|
|
||||||
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
|
||||||
|
|
||||||
[See complete guide](/doc/Encoding JSON.md)
|
|
||||||
|
|
||||||
Testimonials
|
|
||||||
------------
|
|
||||||
|
|
||||||
From Arduino's Forum user `jflaplante`:
|
|
||||||
> I tried aJson json-arduino before trying your library. I always ran into memory problem after a while.
|
|
||||||
> I have no such problem so far with your library. It is working perfectly with my web services.
|
|
||||||
|
|
||||||
From Arduino's Forum user `gbathree`:
|
|
||||||
> Thanks so much - this is an awesome library! If you want to see what we're doing with it - the project is located at www.photosynq.org.
|
|
||||||
|
|
||||||
From StackOverflow user `thegreendroid`:
|
|
||||||
> It has a really elegant, simple API and it works like a charm on embedded and Windows/Linux platforms. We recently started using this on an embedded project and I can vouch for its quality.
|
|
||||||
|
|
||||||
From GitHub user `zacsketches`:
|
|
||||||
|
|
||||||
> Thanks for a great library!!!
|
|
||||||
> I've been watching you consistently develop this library over the past six months, and I used it today for a publish and subscribe architecture designed to help hobbyists move into more advanced robotics. Your library allowed me to implement remote subscription in order to facilitate multi-processor robots.
|
|
||||||
> ArduinoJson saved me a week's worth of time!!
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
Found this library useful? [Help me back with a donation!](https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=donate%40benoitblanchon%2efr&lc=GB&item_name=Benoit%20Blanchon&item_number=Arduino%20JSON¤cy_code=EUR&bn=PP%2dDonationsBF%3abtn_donate_LG%2egif%3aNonHosted) :smile:
|
[](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22+branch%3A7.x)
|
||||||
|
[](https://ci.appveyor.com/project/bblanchon/arduinojson/branch/7.x)
|
||||||
|
[](https://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened&can=1&q=proj:arduinojson)
|
||||||
|
[](https://coveralls.io/github/bblanchon/ArduinoJson?branch=7.x)
|
||||||
|
[](https://github.com/bblanchon/ArduinoJson/stargazers)
|
||||||
|
[](https://github.com/sponsors/bblanchon)
|
||||||
|
|
||||||
|
ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).
|
||||||
|
|
||||||
|
## Features
|
||||||
|
|
||||||
|
* [JSON deserialization](https://arduinojson.org/v7/api/json/deserializejson/)
|
||||||
|
* [Optionally decodes UTF-16 escape sequences to UTF-8](https://arduinojson.org/v7/api/config/decode_unicode/)
|
||||||
|
* [Optionally supports comments in the input](https://arduinojson.org/v7/api/config/enable_comments/)
|
||||||
|
* [Optionally filters the input to keep only desired values](https://arduinojson.org/v7/api/json/deserializejson/#filtering)
|
||||||
|
* Supports single quotes as a string delimiter
|
||||||
|
* Compatible with [NDJSON](http://ndjson.org/) and [JSON Lines](https://jsonlines.org/)
|
||||||
|
* [JSON serialization](https://arduinojson.org/v7/api/json/serializejson/)
|
||||||
|
* [Can write to a buffer or a stream](https://arduinojson.org/v7/api/json/serializejson/)
|
||||||
|
* [Optionally indents the document (prettified JSON)](https://arduinojson.org/v7/api/json/serializejsonpretty/)
|
||||||
|
* [MessagePack serialization](https://arduinojson.org/v7/api/msgpack/serializemsgpack/)
|
||||||
|
* [MessagePack deserialization](https://arduinojson.org/v7/api/msgpack/deserializemsgpack/)
|
||||||
|
* Efficient
|
||||||
|
* [Twice smaller than the "official" Arduino_JSON library](https://arduinojson.org/2019/11/19/arduinojson-vs-arduino_json/)
|
||||||
|
* [Almost 10% faster than the "official" Arduino_JSON library](https://arduinojson.org/2019/11/19/arduinojson-vs-arduino_json/)
|
||||||
|
* [Consumes roughly 10% less RAM than the "official" Arduino_JSON library](https://arduinojson.org/2019/11/19/arduinojson-vs-arduino_json/)
|
||||||
|
* [Deduplicates strings](https://arduinojson.org/news/2020/08/01/version-6-16-0/)
|
||||||
|
* Versatile
|
||||||
|
* Supports [custom allocators (to use external RAM chip, for example)](https://arduinojson.org/v7/how-to/use-external-ram-on-esp32/)
|
||||||
|
* Supports [`String`](https://arduinojson.org/v7/api/config/enable_arduino_string/), [`std::string`](https://arduinojson.org/v7/api/config/enable_std_string/), and [`std::string_view`](https://arduinojson.org/v7/api/config/enable_string_view/)
|
||||||
|
* Supports [`Stream`](https://arduinojson.org/v7/api/config/enable_arduino_stream/) and [`std::istream`/`std::ostream`](https://arduinojson.org/v7/api/config/enable_std_stream/)
|
||||||
|
* Supports [Flash strings](https://arduinojson.org/v7/api/config/enable_progmem/)
|
||||||
|
* Supports [custom readers](https://arduinojson.org/v7/api/json/deserializejson/#custom-reader) and [custom writers](https://arduinojson.org/v7/api/json/serializejson/#custom-writer)
|
||||||
|
* Supports [custom converters](https://arduinojson.org/news/2021/05/04/version-6-18-0/)
|
||||||
|
* Portable
|
||||||
|
* Usable on any C++ project (not limited to Arduino)
|
||||||
|
* Compatible with C++11, C++14 and C++17
|
||||||
|
* Support for C++98/C++03 available on [ArduinoJson 6.20.x](https://github.com/bblanchon/ArduinoJson/tree/6.20.x)
|
||||||
|
* Zero warnings with `-Wall -Wextra -pedantic` and `/W4`
|
||||||
|
* [Header-only library](https://en.wikipedia.org/wiki/Header-only)
|
||||||
|
* Works with virtually any board
|
||||||
|
* Arduino boards: [Uno](https://amzn.to/38aL2ik), [Due](https://amzn.to/36YkWi2), [Micro](https://amzn.to/35WkdwG), [Nano](https://amzn.to/2QTvwRX), [Mega](https://amzn.to/36XWhuf), [Yun](https://amzn.to/30odURc), [Leonardo](https://amzn.to/36XWjlR)...
|
||||||
|
* Espressif chips: [ESP8266](https://amzn.to/36YluV8), [ESP32](https://amzn.to/2G4pRCB)
|
||||||
|
* Lolin (WeMos) boards: [D1 mini](https://amzn.to/2QUpz7q), [D1 Mini Pro](https://amzn.to/36UsGSs)...
|
||||||
|
* Teensy boards: [4.0](https://amzn.to/30ljXGq), [3.2](https://amzn.to/2FT0EuC), [2.0](https://amzn.to/2QXUMXj)
|
||||||
|
* Particle boards: [Argon](https://amzn.to/2FQHa9X), [Boron](https://amzn.to/36WgLUd), [Electron](https://amzn.to/30vEc4k), [Photon](https://amzn.to/387F9Cd)...
|
||||||
|
* Texas Instruments boards: [MSP430](https://amzn.to/30nJWgg)...
|
||||||
|
* Soft cores: [Nios II](https://en.wikipedia.org/wiki/Nios_II)...
|
||||||
|
* Tested on all major development environments
|
||||||
|
* [Arduino IDE](https://www.arduino.cc/en/Main/Software)
|
||||||
|
* [Atmel Studio](http://www.atmel.com/microsite/atmel-studio/)
|
||||||
|
* [Atollic TrueSTUDIO](https://atollic.com/truestudio/)
|
||||||
|
* [Energia](http://energia.nu/)
|
||||||
|
* [IAR Embedded Workbench](https://www.iar.com/iar-embedded-workbench/)
|
||||||
|
* [Keil uVision](http://www.keil.com/)
|
||||||
|
* [MPLAB X IDE](http://www.microchip.com/mplab/mplab-x-ide)
|
||||||
|
* [Particle](https://www.particle.io/)
|
||||||
|
* [PlatformIO](http://platformio.org/)
|
||||||
|
* [Sloeber plugin for Eclipse](https://eclipse.baeyens.it/)
|
||||||
|
* [Visual Micro](http://www.visualmicro.com/)
|
||||||
|
* [Visual Studio](https://www.visualstudio.com/)
|
||||||
|
* [Even works with online compilers like wandbox.org](https://wandbox.org/permlink/RlZSKy17DjJ6HcdN)
|
||||||
|
* [CMake friendly](https://arduinojson.org/v7/how-to/use-arduinojson-with-cmake/)
|
||||||
|
* Well designed
|
||||||
|
* [Elegant API](http://arduinojson.org/v7/example/)
|
||||||
|
* [Thread-safe](https://en.wikipedia.org/wiki/Thread_safety)
|
||||||
|
* Self-contained (no external dependency)
|
||||||
|
* `const` friendly
|
||||||
|
* [`for` friendly](https://arduinojson.org/v7/api/jsonobject/begin_end/)
|
||||||
|
* [TMP friendly](https://en.wikipedia.org/wiki/Template_metaprogramming)
|
||||||
|
* Handles [integer overflows](https://arduinojson.org/v7/api/jsonvariant/as/#integer-overflows)
|
||||||
|
* Well tested
|
||||||
|
* [Unit test coverage close to 100%](https://coveralls.io/github/bblanchon/ArduinoJson?branch=7.x)
|
||||||
|
* Continuously tested on
|
||||||
|
* [Visual Studio 2017, 2019, 2022](https://ci.appveyor.com/project/bblanchon/arduinojson/branch/7.x)
|
||||||
|
* [GCC 4.8, 5, 6, 7, 8, 9, 10, 11, 12](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22)
|
||||||
|
* [Clang 7 to 19](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22)
|
||||||
|
* [Continuously fuzzed with Google OSS Fuzz](https://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened&can=1&q=proj:arduinojson)
|
||||||
|
* Passes all default checks of [clang-tidy](https://releases.llvm.org/10.0.0/tools/clang/tools/extra/docs/clang-tidy/)
|
||||||
|
* Well documented
|
||||||
|
* [Tutorials](https://arduinojson.org/v7/doc/deserialization/)
|
||||||
|
* [Examples](https://arduinojson.org/v7/example/)
|
||||||
|
* [How-tos](https://arduinojson.org/v7/example/)
|
||||||
|
* [FAQ](https://arduinojson.org/v7/faq/)
|
||||||
|
* [Troubleshooter](https://arduinojson.org/v7/troubleshooter/)
|
||||||
|
* [Book](https://arduinojson.org/book/)
|
||||||
|
* [Changelog](CHANGELOG.md)
|
||||||
|
* Vibrant user community
|
||||||
|
* Most popular of all Arduino libraries on [GitHub](https://github.com/search?o=desc&q=arduino+library&s=stars&type=Repositories)
|
||||||
|
* [Used in hundreds of projects](https://www.hackster.io/search?i=projects&q=arduinojson)
|
||||||
|
* [Responsive support](https://github.com/bblanchon/ArduinoJson/issues?q=is%3Aissue+is%3Aclosed)
|
||||||
|
|
||||||
|
## Quickstart
|
||||||
|
|
||||||
|
### Deserialization
|
||||||
|
|
||||||
|
Here is a program that parses a JSON document with ArduinoJson.
|
||||||
|
|
||||||
|
```c++
|
||||||
|
const char* json = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
|
||||||
|
JsonDocument doc;
|
||||||
|
deserializeJson(doc, json);
|
||||||
|
|
||||||
|
const char* sensor = doc["sensor"];
|
||||||
|
long time = doc["time"];
|
||||||
|
double latitude = doc["data"][0];
|
||||||
|
double longitude = doc["data"][1];
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [tutorial on arduinojson.org](https://arduinojson.org/v7/doc/deserialization/)
|
||||||
|
|
||||||
|
### Serialization
|
||||||
|
|
||||||
|
Here is a program that generates a JSON document with ArduinoJson:
|
||||||
|
|
||||||
|
```c++
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
doc["sensor"] = "gps";
|
||||||
|
doc["time"] = 1351824120;
|
||||||
|
doc["data"][0] = 48.756080;
|
||||||
|
doc["data"][1] = 2.302038;
|
||||||
|
|
||||||
|
serializeJson(doc, Serial);
|
||||||
|
// This prints:
|
||||||
|
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [tutorial on arduinojson.org](https://arduinojson.org/v7/doc/serialization/)
|
||||||
|
|
||||||
|
## Sponsors
|
||||||
|
|
||||||
|
ArduinoJson is thankful to its sponsors. Please give them a visit; they deserve it!
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<a href="https://github.com/1technophile" rel="sponsored">
|
||||||
|
<img alt="1technophile" src="https://avatars.githubusercontent.com/u/12672732?s=40&v=4">
|
||||||
|
</a>
|
||||||
|
<a href="https://github.com/LArkema" rel="sponsored">
|
||||||
|
<img alt="LArkema" src="https://avatars.githubusercontent.com/u/38381313?s=40&v=4">
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
If you run a commercial project that embeds ArduinoJson, think about [sponsoring the library's development](https://github.com/sponsors/bblanchon): it ensures the code that your products rely on stays actively maintained. It can also give your project some exposure to the makers' community.
|
||||||
|
|
||||||
|
If you are an individual user and want to support the development (or give a sign of appreciation), consider purchasing the book [Mastering ArduinoJson](https://arduinojson.org/book/) ❤, or simply [cast a star](https://github.com/bblanchon/ArduinoJson/stargazers) ⭐.
|
||||||
|
27
SUPPORT.md
Normal file
27
SUPPORT.md
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
# ArduinoJson Support
|
||||||
|
|
||||||
|
First off, thank you very much for using ArduinoJson.
|
||||||
|
|
||||||
|
We'll be very happy to help you, but first please read the following.
|
||||||
|
|
||||||
|
## Before asking for help
|
||||||
|
|
||||||
|
1. Read the [FAQ](https://arduinojson.org/faq/?utm_source=github&utm_medium=support)
|
||||||
|
2. Search in the [API Reference](https://arduinojson.org/api/?utm_source=github&utm_medium=support)
|
||||||
|
|
||||||
|
If you did not find the answer, please create a [new issue on GitHub](https://github.com/bblanchon/ArduinoJson/issues/new).
|
||||||
|
|
||||||
|
It is OK to add a comment to a currently opened issue, but please avoid adding comments to a closed issue.
|
||||||
|
|
||||||
|
## Before hitting the Submit button
|
||||||
|
|
||||||
|
Please provide all the relevant information:
|
||||||
|
|
||||||
|
* Good title
|
||||||
|
* Short description of the problem
|
||||||
|
* Target platform
|
||||||
|
* Compiler model and version
|
||||||
|
* [MVCE](https://stackoverflow.com/help/mcve)
|
||||||
|
* Compiler output
|
||||||
|
|
||||||
|
Good questions get fast answers!
|
28
appveyor.yml
Normal file
28
appveyor.yml
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
version: 7.4.2.{build}
|
||||||
|
environment:
|
||||||
|
matrix:
|
||||||
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2022
|
||||||
|
CMAKE_GENERATOR: Visual Studio 17 2022
|
||||||
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
|
||||||
|
CMAKE_GENERATOR: Visual Studio 16 2019
|
||||||
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
|
CMAKE_GENERATOR: Visual Studio 15 2017
|
||||||
|
- CMAKE_GENERATOR: Ninja
|
||||||
|
MINGW32: i686-6.3.0-posix-dwarf-rt_v5-rev1 # MinGW-w64 6.3.0 i686
|
||||||
|
- CMAKE_GENERATOR: Ninja
|
||||||
|
MINGW64: x86_64-6.3.0-posix-seh-rt_v5-rev1 # MinGW-w64 6.3.0 x86_64
|
||||||
|
- CMAKE_GENERATOR: Ninja
|
||||||
|
MINGW64: x86_64-7.3.0-posix-seh-rt_v5-rev0 # MinGW-w64 7.3.0 x86_64
|
||||||
|
- CMAKE_GENERATOR: Ninja
|
||||||
|
MINGW64: x86_64-8.1.0-posix-seh-rt_v6-rev0 # MinGW-w64 8.1.0 x86_64
|
||||||
|
configuration: Debug
|
||||||
|
before_build:
|
||||||
|
- set PATH=%PATH:C:\Program Files\Git\usr\bin;=% # Workaround for CMake not wanting sh.exe on PATH for MinGW
|
||||||
|
- if defined MINGW set PATH=C:\%MINGW%\bin;%PATH%
|
||||||
|
- if defined MINGW32 set PATH=C:\mingw-w64\%MINGW32%\mingw32\bin;%PATH%
|
||||||
|
- if defined MINGW64 set PATH=C:\mingw-w64\%MINGW64%\mingw64\bin;%PATH%
|
||||||
|
- cmake -DCMAKE_BUILD_TYPE=%CONFIGURATION% -G "%CMAKE_GENERATOR%" .
|
||||||
|
build_script:
|
||||||
|
- cmake --build . --config %CONFIGURATION%
|
||||||
|
test_script:
|
||||||
|
- ctest -C %CONFIGURATION% --output-on-failure .
|
1
component.mk
Normal file
1
component.mk
Normal file
@ -0,0 +1 @@
|
|||||||
|
COMPONENT_ADD_INCLUDEDIRS := src
|
@ -1,102 +0,0 @@
|
|||||||
Avoiding common pitfalls in Arduino JSON
|
|
||||||
========================================
|
|
||||||
|
|
||||||
As `StaticJsonBuffer` is the corner stone of this library, you'll see that every pitfall listed here are related to a wrong understanding of the memory model.
|
|
||||||
|
|
||||||
Make sure you read [Arduino JSON memory model](Memory model.md) before going further.
|
|
||||||
|
|
||||||
## 1. Make `StaticJsonBuffer` big enough
|
|
||||||
|
|
||||||
By design, the library has no way to tell you why `parseArray()` or `parseObject()` failed.
|
|
||||||
|
|
||||||
There are basically two reasons why they may fail:
|
|
||||||
|
|
||||||
1. the JSON string is invalid,
|
|
||||||
2. the JSON string contains more values that the buffer can store.
|
|
||||||
|
|
||||||
So, if you are sure the JSON string is correct and you still can't parse it, you should try to increase the size of the `StaticJsonBuffer`.
|
|
||||||
|
|
||||||
## 2. Make sure everything fits in memory
|
|
||||||
|
|
||||||
You may go into unpredictable trouble if you allocate more memory than your processor really has.
|
|
||||||
It's a very common issue in embedded development.
|
|
||||||
|
|
||||||
To diagnose this, look at every big objects in you code and sum their size to check that they fit in RAM.
|
|
||||||
|
|
||||||
For example, don't do this:
|
|
||||||
|
|
||||||
char json[1024]; // 1 KB
|
|
||||||
StaticJsonBuffer<512> buffer; // 514 B
|
|
||||||
|
|
||||||
because it may be too big for a processor with only 2 KB: you need free memory to store other variables and the call stack.
|
|
||||||
|
|
||||||
That is why an 8-bit processor is not able to parse long and complex JSON strings.
|
|
||||||
|
|
||||||
## 3. Keep the `StaticJsonBuffer` in memory long enough
|
|
||||||
|
|
||||||
Remember that `StaticJsonBuffer`'s function return references.
|
|
||||||
References don't contain data, they are just pointer to the actual.
|
|
||||||
So they can only work if the actual data is in memory.
|
|
||||||
|
|
||||||
For example, don't do this:
|
|
||||||
|
|
||||||
JsonArray& getArray(char* json)
|
|
||||||
{
|
|
||||||
StaticJsonBuffer<200> buffer;
|
|
||||||
return buffer.parseArray(json);
|
|
||||||
}
|
|
||||||
|
|
||||||
because the local variable `buffer` will be *removed* from memory when the function `parseArray()` returns, and the `JsonArray&` will point to an invalid location.
|
|
||||||
|
|
||||||
## 4. Don't reuse the same `StaticJsonBuffer`
|
|
||||||
|
|
||||||
During is lifetime a `StaticJsonBuffer` growth until it's discarded. If you try to reuse the same instance several time, it will rapidly get full.
|
|
||||||
|
|
||||||
For this reason, you should not use a global variable for your `StaticJsonBuffer`. I don't think there is any scenario in which a global `StaticJsonBuffer` would be a valid option.
|
|
||||||
|
|
||||||
The best practice is to declare it in a local scope, so that it's discarded as soon as possible. My advice it to declare it in a function which unique role is to handle the JSON serialization.
|
|
||||||
|
|
||||||
## 5. Keep the JSON string in memory long enough
|
|
||||||
|
|
||||||
The library never make memory duplication.
|
|
||||||
This has an important implication on string values, it means that the library will return pointer to chunks of the string.
|
|
||||||
|
|
||||||
For instance, let's imagine that you parse `["hello","world"]`, like this:
|
|
||||||
|
|
||||||
char[] json = "[\"hello\",\"world\"]";
|
|
||||||
StaticJsonBuffer<32> buffer;
|
|
||||||
JsonArray& array = buffer.parseArray(json);
|
|
||||||
|
|
||||||
const char* first = array[0];
|
|
||||||
const char* second = array[1];
|
|
||||||
|
|
||||||
In that case, both `first` and `second` are pointers to the content of the original string `json`.
|
|
||||||
So this will only work if `json` is still in memory.
|
|
||||||
|
|
||||||
## 6. JSON string is altered
|
|
||||||
|
|
||||||
If you read carefully the previous section, you may have come to the conclusion that the JSON parser modifies the JSON string.
|
|
||||||
|
|
||||||
Indeed, the parser modifies the string for two reasons:
|
|
||||||
|
|
||||||
1. it inserts `\0` to terminate substrings,
|
|
||||||
2. it translate escaped characters like `\n` or `\t`.
|
|
||||||
|
|
||||||
Most of the time this wont be an issue, but there are some corner cases that can be problematic.
|
|
||||||
|
|
||||||
Let take the example bellow:
|
|
||||||
|
|
||||||
char[] json = "[\"hello\",\"world\"]";
|
|
||||||
StaticJsonBuffer<32> buffer;
|
|
||||||
JsonArray& array = buffer.parseArray(json);
|
|
||||||
|
|
||||||
If you replace it by:
|
|
||||||
|
|
||||||
char* json = "[\"hello\",\"world\"]";
|
|
||||||
StaticJsonBuffer<32> buffer;
|
|
||||||
JsonArray& array = buffer.parseArray(json);
|
|
||||||
|
|
||||||
Depending on your platform, you may have an exception because the parser tries to write at a location that is read-only.
|
|
||||||
In the first case `char json[]` declares an array of `char` initialized to the specified string.
|
|
||||||
In the second case `char* json` declares a pointer to a read-only string, in fact it should be a `const char*` instead of a `char*`.
|
|
||||||
|
|
@ -1,15 +0,0 @@
|
|||||||
Contributing to Arduino JSON
|
|
||||||
============================
|
|
||||||
|
|
||||||
If you want to contribute to the project, please:
|
|
||||||
|
|
||||||
1. Use GitHub pull request feature
|
|
||||||
2. Follow the coding conventions
|
|
||||||
3. Write tests
|
|
||||||
|
|
||||||
About the coding conventions: I try to follow the [Google C++ Style Guide](http://google-styleguide.googlecode.com/svn/trunk/cppguide.html) with few variations to match the Arduino conventions.
|
|
||||||
|
|
||||||
I use [ClangFormat](http://clang.llvm.org/docs/ClangFormat.html) to format the code for me.
|
|
||||||
I use [CppLint](http://google-styleguide.googlecode.com/svn/trunk/cpplint/cpplint.py) to detect non-compliant stuff.
|
|
||||||
|
|
||||||
You should have a look at the `scripts/` folder as it contains a few helpers scripts.
|
|
@ -1,148 +0,0 @@
|
|||||||
Decoding JSON with Arduino JSON
|
|
||||||
===============================
|
|
||||||
|
|
||||||
Before writing any code, don't forget to include the header:
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
For instructions on how to install the library, please read [Using the library with Arduino](Using the library with Arduino.md) or [Using the library without Arduino](Using the library without Arduino.md).
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
Here an example that parse the string `{"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}`:
|
|
||||||
|
|
||||||
char json[] = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 1: Reserve memory space
|
|
||||||
//
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 2: Deserialize the JSON string
|
|
||||||
//
|
|
||||||
JsonObject& root = jsonBuffer.parseObject(json);
|
|
||||||
|
|
||||||
if (!root.success())
|
|
||||||
{
|
|
||||||
Serial.println("parseObject() failed");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 3: Retrieve the values
|
|
||||||
//
|
|
||||||
const char* sensor = root["sensor"];
|
|
||||||
long time = root["time"];
|
|
||||||
double latitude = root["data"][0];
|
|
||||||
double longitude = root["data"][1];
|
|
||||||
|
|
||||||
## Step 1: Reserve memory space
|
|
||||||
|
|
||||||
Arduino JSON uses a preallocated memory pool to store the object tree, this is done by the `StaticJsonBuffer`.
|
|
||||||
|
|
||||||
Before continuing please read the page [Arduino JSON memory model](Memory model.md) that explains everything you need to know about `StaticJsonBuffer`.
|
|
||||||
|
|
||||||
## Step 2: Parse the JSON string
|
|
||||||
|
|
||||||
You invoke the JSON parser through the instance of `StaticJsonBuffer`.
|
|
||||||
It exposes two functions for parsing JSON:
|
|
||||||
|
|
||||||
1. `parseArray()` that returns a reference to a `JsonArray`
|
|
||||||
2. `parseObject()` that returns a reference to a `JsonObject`
|
|
||||||
|
|
||||||
Let's see an example.
|
|
||||||
Say we want to parse `{"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}`, it's an object so we call `parseObject()` as follows:
|
|
||||||
|
|
||||||
char json[] = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
|
||||||
|
|
||||||
JsonObject& root = jsonBuffer.parseObject(json);
|
|
||||||
|
|
||||||
As you can see `parseObject()` takes a `char*` as a parameter.
|
|
||||||
Be careful, it's not a `const char*`, the memory must be writable.
|
|
||||||
Indeed, the parser will modify the string in two cases:
|
|
||||||
|
|
||||||
1. to insert string endings (character `\0`),
|
|
||||||
2. to translate escaped characters (like `\n` or `\t`).
|
|
||||||
|
|
||||||
Another thing that you must keep in mind is that the string (`char json[]` in the example above) must stay in memory during the whole parsing process.
|
|
||||||
That is because the in memory object tree will store pointer to chunks of the string, so as to avoid any memory duplication.
|
|
||||||
|
|
||||||
Now, to check if the parsing was successful, you can call `JsonObject::success()`:
|
|
||||||
|
|
||||||
if (!root.success())
|
|
||||||
{
|
|
||||||
// Parsing fail
|
|
||||||
}
|
|
||||||
|
|
||||||
The result can be `false` for tree reasons:
|
|
||||||
|
|
||||||
1. the JSON string is invalid,
|
|
||||||
2. the JSON string doesn't represent an object,
|
|
||||||
3. the `StaticJsonBuffer` is too small.
|
|
||||||
|
|
||||||
We just saw how to parse an object, there is nothing more to say for arrays, the procedure is exactly the same.
|
|
||||||
|
|
||||||
## Step 3: Retrieve the values
|
|
||||||
|
|
||||||
Now that the object or array is in memory, you can extract the data very easily.
|
|
||||||
|
|
||||||
In this section, we'll see how to do it with a `JsonObject`.
|
|
||||||
Once again, there is nothing more to say about arrays, `JsonArray` works exactly the same as `JsonObject`.
|
|
||||||
|
|
||||||
#### Subscript operator
|
|
||||||
|
|
||||||
The simplest way is to use the subscript operator of `JsonObject`:
|
|
||||||
|
|
||||||
const char* sensor = root["sensor"];
|
|
||||||
long time = root["time"];
|
|
||||||
|
|
||||||
You can chain the subscript operator if you have nested arrays or objects:
|
|
||||||
|
|
||||||
double latitude = root["data"][0];
|
|
||||||
double longitude = root["data"][1];
|
|
||||||
|
|
||||||
But alternatively, you can get a reference to the nested array:
|
|
||||||
|
|
||||||
JsonArray& nestedArray = root["data"];
|
|
||||||
|
|
||||||
#### Casting values
|
|
||||||
|
|
||||||
In the previous examples, the values were implicitly casted to the target type.
|
|
||||||
You can also do this explicitly
|
|
||||||
|
|
||||||
const char* sensor = root["sensor"].asString();
|
|
||||||
long time = root["time"].as<long>();
|
|
||||||
JsonArray& nestedArray = root["data"].asArray();
|
|
||||||
|
|
||||||
If the actual value doesn't match the target type, a default value will be return:
|
|
||||||
|
|
||||||
1. `false` for boolean values
|
|
||||||
2. `0` for integer values
|
|
||||||
3. `NULL` for string values
|
|
||||||
4. `JsonArray::invalid()` for nested arrays
|
|
||||||
5. `JsonObject::invalid()` for nested object
|
|
||||||
|
|
||||||
#### Check values
|
|
||||||
|
|
||||||
If you want to know if some value is present, call `containsKey()`:
|
|
||||||
|
|
||||||
if (root.contains("extra"))
|
|
||||||
{
|
|
||||||
// root["extra"] is valid
|
|
||||||
}
|
|
||||||
|
|
||||||
If you want to check the type value has a certain type, call `is<T>()`:
|
|
||||||
|
|
||||||
if (root["extra"].is<JsonArray&>())
|
|
||||||
{
|
|
||||||
// root["extra"] is an array
|
|
||||||
}
|
|
||||||
|
|
||||||
You can also iterate through the key-value pairs of the object:
|
|
||||||
|
|
||||||
for (JsonObject::itertor it=root.begin(); it!=root.end(); ++it)
|
|
||||||
{
|
|
||||||
Serial.println(it->key);
|
|
||||||
Serial.println(i->value.asString());
|
|
||||||
}
|
|
@ -1,140 +0,0 @@
|
|||||||
Encoding JSON with Arduino JSON
|
|
||||||
===============================
|
|
||||||
|
|
||||||
Before writing any code, don't forget to include the header:
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
For instructions on how to install the library, please read [Using the library with Arduino](Using the library with Arduino.md) or [Using the library without Arduino](Using the library without Arduino.md).
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
Here is an example to generate `{"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}`
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 1: Reserve memory space
|
|
||||||
//
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 2: Build object tree in memory
|
|
||||||
//
|
|
||||||
JsonObject& root = jsonBuffer.createObject();
|
|
||||||
root["sensor"] = "gps";
|
|
||||||
root["time"] = 1351824120;
|
|
||||||
|
|
||||||
JsonArray& data = root.createNestedArray("data");
|
|
||||||
data.add(48.756080, 6); // 6 is the number of decimals to print
|
|
||||||
data.add(2.302038, 6); // if not specified, 2 digits are printed
|
|
||||||
|
|
||||||
//
|
|
||||||
// Step 3: Generate the JSON string
|
|
||||||
//
|
|
||||||
root.printTo(Serial);
|
|
||||||
|
|
||||||
## Step 1: Reserve memory space
|
|
||||||
|
|
||||||
Arduino JSON uses a preallocated memory pool to store the object tree, this is done by the `StaticJsonBuffer`.
|
|
||||||
|
|
||||||
Before continuing please read the page [Arduino JSON memory model](Memory model.md) that explains everything you need to know about `StaticJsonBuffer`.
|
|
||||||
|
|
||||||
## Step 2: Build object tree in memory
|
|
||||||
|
|
||||||
Now that you have enough memory hold by the `StaticJsonBuffer`, you can use it to build your in-memory representation of the JSON string.
|
|
||||||
|
|
||||||
#### Arrays
|
|
||||||
|
|
||||||
You create an array like this:
|
|
||||||
|
|
||||||
JsonArray& array = jsonBuffer.createArray();
|
|
||||||
|
|
||||||
Don't forget the `&` after `JsonArray`, it needs to be a reference to the array.
|
|
||||||
|
|
||||||
Then you can add strings, integer, booleans, etc:
|
|
||||||
|
|
||||||
array.add("bazinga!");
|
|
||||||
array.add(42);
|
|
||||||
array.add(true);
|
|
||||||
|
|
||||||
There are two syntaxes for floating point values:
|
|
||||||
|
|
||||||
array.add(3.1415, 4); // 4 digits: "3.1415"
|
|
||||||
array.add(3.1415); // 2 digits: "3.14"
|
|
||||||
|
|
||||||
> ##### About floating point precision
|
|
||||||
> The overload of `add()` with 2 parameters allows you to specify the number of decimals to save in the JSON string.
|
|
||||||
> When you use the overload with one parameter, you use the default number of decimals which is 2.
|
|
||||||
> Note that this behavior is the exact same as Arduino's `Print::print(double,int);` which is implemented by `Serial`, so you may already be familiar with this behavior.
|
|
||||||
|
|
||||||
You can add a nested array or object if you have a reference to it.
|
|
||||||
Or simpler, you can create nested array or nested objects from the array:
|
|
||||||
|
|
||||||
JsonArray& nestedArray = array.createNestedArray();
|
|
||||||
JsonObject& nestedObject = array.createNestedObject();
|
|
||||||
|
|
||||||
#### Objects
|
|
||||||
|
|
||||||
You create an object like this:
|
|
||||||
|
|
||||||
JsonObject& object = jsonBuffer.createObject();
|
|
||||||
|
|
||||||
Again, don't forget the `&` after `JsonObject`, it needs to be a reference to the object.
|
|
||||||
|
|
||||||
Then you can add strings, integer, booleans, etc:
|
|
||||||
|
|
||||||
object["key1"] = "bazinga!";
|
|
||||||
object["key2"] = 42;
|
|
||||||
object["key3"] = true;
|
|
||||||
|
|
||||||
As for the arrays, there are two syntaxes for the floating point values:
|
|
||||||
|
|
||||||
object["key4"].set(3.1415, 4); // 4 digits "3.1415"
|
|
||||||
object["key5"] = 3.1415; // default: 2 digits "3.14"
|
|
||||||
|
|
||||||
You can add a nested array or object if you have a reference to it.
|
|
||||||
Or simpler, you can create nested array or nested objects from the object:
|
|
||||||
|
|
||||||
JsonArray& nestedArray = object.createNestedArray("key6");
|
|
||||||
JsonObject& nestedObject = object.createNestedObject("key7");
|
|
||||||
|
|
||||||
> ##### Other JsonObject functions
|
|
||||||
> * `object.add(key, value)` is a synonym for `object[key] = value`
|
|
||||||
> * `object.containsKey(key)` returns `true` is the `key` is present in `object`
|
|
||||||
> * `object.remove(key)` removes the `value` associated with `key`
|
|
||||||
|
|
||||||
## Step 3: Generate the JSON string
|
|
||||||
|
|
||||||
There are two ways tho get the resulting JSON string.
|
|
||||||
|
|
||||||
Depending on your project, you may need to dump the string in a classic `char[]` or send it to a `Print` implementation like `Serial` or `EthernetClient `.
|
|
||||||
|
|
||||||
Both ways are the easy way :-)
|
|
||||||
|
|
||||||
#### Use a classic `char[]`
|
|
||||||
|
|
||||||
Whether you have a `JsonArray&` or a `JsonObject&`, simply call `printTo()` with the destination buffer, like so:
|
|
||||||
|
|
||||||
char buffer[256];
|
|
||||||
array.printTo(buffer, sizeof(buffer));
|
|
||||||
|
|
||||||
> ##### Want an indented output?
|
|
||||||
> By default the generated JSON is as small as possible. It contains no extra space, nor line break.
|
|
||||||
> But if you want an indented, more readable output, you can.
|
|
||||||
> Simply call `prettyPrintTo` instead of `printTo()`:
|
|
||||||
>
|
|
||||||
> array.prettyPrintTo(buffer, sizeof(buffer));
|
|
||||||
|
|
||||||
#### Send to a `Print` implementation
|
|
||||||
|
|
||||||
It's very likely that the generated JSON will end up in a stream like `Serial` or `EthernetClient `, so you can save some time and memory by doing this:
|
|
||||||
|
|
||||||
array.printTo(Serial);
|
|
||||||
|
|
||||||
And, of course if you need an indented JSON string:
|
|
||||||
|
|
||||||
array.prettyPrintTo(Serial);
|
|
||||||
|
|
||||||
> ##### About the Print interface
|
|
||||||
> The library is designed to send the JSON string to an implementation of the `Print` interface that is part of Arduino.
|
|
||||||
> In the example above we used `Serial`, but they are many other implementations that would work as well, including: `HardwareSerial`, `SoftwareSerial`, `LiquidCrystal`, `EthernetClient`, `WiFiClient`, `Wire`...
|
|
||||||
> When you use this library out of the Arduino environment, it will use it's own implementation of `Print` and everything will be the same.
|
|
@ -1,58 +0,0 @@
|
|||||||
Arduino JSON memory model
|
|
||||||
=========================
|
|
||||||
|
|
||||||
## Fixed memory allocation
|
|
||||||
|
|
||||||
### Introducing `StaticJsonBuffer`
|
|
||||||
|
|
||||||
Arduino JSON uses a preallocated memory pool to store the object tree, this is done by the `StaticJsonBuffer` class.
|
|
||||||
|
|
||||||
Before using any function of the library you need to create a `StaticJsonBuffer`. Then you can use this instance to create arrays and objects, or parse a JSON string.
|
|
||||||
|
|
||||||
`StaticJsonBuffer` has a template parameter that determines its capacity. For example, the following line create a `StaticJsonBuffer` with a capacity of 200 bytes:
|
|
||||||
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
|
||||||
|
|
||||||
The bigger the buffer is, the more complex the object tree can be, but also the more memory you need.
|
|
||||||
|
|
||||||
### How to determine the buffer size?
|
|
||||||
|
|
||||||
So the big question you should have in mind right now is *How can I determine the size?*.
|
|
||||||
|
|
||||||
There are basically two approaches here:
|
|
||||||
|
|
||||||
1. either you can predict the content of the object tree,
|
|
||||||
2. or, you know how much memory is available.
|
|
||||||
|
|
||||||
In the first case, you know some constraints on the object tree. For instance, let's say that your know in advance (and by that I mean "at compilation time") that you want to generate an object with 3 values, one of them being an array with 2 values, like the following:
|
|
||||||
|
|
||||||
{"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
|
||||||
|
|
||||||
To determine the memory usage of this object tree, you use the two macros `JSON_ARRAY_SIZE(n)` and `JSON_OBJECT_SIZE(n)`, both take the number of elements as an argument.
|
|
||||||
For the example above, it would be:
|
|
||||||
|
|
||||||
const int BUFFER_SIZE = JSON_OBJECT_SIZE(3) + JSON_ARRAY_SIZE(2);
|
|
||||||
StaticJsonBuffer<BUFFER_SIZE> jsonBuffer;
|
|
||||||
|
|
||||||
In the second case, let's say you dynamically generate a JSON object tree of a random complexity so you can't put a limit based on that. But on the other hand, you don't want your program to crash because the object tree doesn't fit in memory.
|
|
||||||
The solution here is to determine how much memory is available, or in other words how much memory you can afford for the JSON object tree.
|
|
||||||
|
|
||||||
### Why choosing fixed allocation?
|
|
||||||
|
|
||||||
This fixed allocation approach may seem a bit strange, especially if your a desktop application developer used to dynamic allocation, but it make a lot of sense in an embedded context:
|
|
||||||
|
|
||||||
1. the code is smaller
|
|
||||||
2. it uses less memory
|
|
||||||
3. it doesn't create memory fragmentation
|
|
||||||
4. it predictable
|
|
||||||
|
|
||||||
Don't forget that the memory is "freed" as soon as the `StaticJsonBuffer` is out of scope, like any other variable. It only hold the memory for a short amount of time.
|
|
||||||
|
|
||||||
## Memory usage
|
|
||||||
|
|
||||||
#### Object size for 8-bit AVR
|
|
||||||
|
|
||||||
| Type | Size |
|
|
||||||
|-------------------------|------------|
|
|
||||||
| JsonArray of N element | 4 + 8 * N |
|
|
||||||
| JsonObject of N element | 4 + 10 * N |
|
|
@ -1,80 +0,0 @@
|
|||||||
Migrating code written for Arduino JSON v3 to v4
|
|
||||||
================================================
|
|
||||||
|
|
||||||
Arduino JSON v4 was a major rewrite of the library, and the API changed significantly.
|
|
||||||
|
|
||||||
## Includes
|
|
||||||
|
|
||||||
Arduino JSON v3 had two include files:
|
|
||||||
|
|
||||||
#include <JsonParser.h>
|
|
||||||
#include <JsonGenerator.h>
|
|
||||||
|
|
||||||
Arduino JSON v4 only has one:
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
## Namespaces
|
|
||||||
|
|
||||||
Arduino JSON v3 had two namespaces:
|
|
||||||
|
|
||||||
using namespace ArduinoJson::Parser;
|
|
||||||
using namespace ArduinoJson::Generator;
|
|
||||||
|
|
||||||
Arduino JSON v4 doesn't require the `using namespace` statement.
|
|
||||||
It has a namespace but the `using namespace` is done in the header file.
|
|
||||||
|
|
||||||
## StaticJsonBuffer
|
|
||||||
|
|
||||||
Arduino JSON v3 had different memory allocation models for the parser:
|
|
||||||
|
|
||||||
JsonParser<16> parser; // 16 being the capacity in "tokens"
|
|
||||||
|
|
||||||
and for the generator:
|
|
||||||
|
|
||||||
JsonArray<4> array; // 4 being the number of element
|
|
||||||
JsonObject<4> object;
|
|
||||||
|
|
||||||
Arduino JSON v4 only has one memory allocation model:
|
|
||||||
|
|
||||||
StaticJsonBuffer<128> buffer; // 128 being the capacity in bytes
|
|
||||||
|
|
||||||
## Return values for the parser
|
|
||||||
|
|
||||||
Arduino JSON v3 returned value types:
|
|
||||||
|
|
||||||
JsonArray array = parser.parseArray(json);
|
|
||||||
JsonObject object = parser.parseObject(json);
|
|
||||||
|
|
||||||
Arduino JSON v4 returns references types:
|
|
||||||
|
|
||||||
JsonArray& array = buffer.parseArray(json);
|
|
||||||
JsonObject& object = buffer.parseObject(json);
|
|
||||||
|
|
||||||
Everything else is compatible
|
|
||||||
|
|
||||||
## Creating arrays and objects
|
|
||||||
|
|
||||||
Arduino JSON v3 allowed to create `JsonArray` and `JsonObject` directly:
|
|
||||||
|
|
||||||
JsonArray<4> array;
|
|
||||||
JsonObject<4> object;
|
|
||||||
|
|
||||||
Arduino JSON v4 requires that you use a `StaticJsonBuffer` for that:
|
|
||||||
|
|
||||||
JsonArray& array = buffer.createArray();
|
|
||||||
JsonObject& object = buffer.createObject();
|
|
||||||
|
|
||||||
Note: you don't have to specify the capacity anymore.
|
|
||||||
|
|
||||||
## Printable interface
|
|
||||||
|
|
||||||
Arduino JSON v3 used to implement the Printable interface, which allowed statements like:
|
|
||||||
|
|
||||||
Serial.print(array);
|
|
||||||
|
|
||||||
But Arduino JSON v4 doesn't, instead you need to write this:
|
|
||||||
|
|
||||||
array.printTo(Serial);
|
|
||||||
|
|
||||||
Note: there was a good reason for removing that feature, and it's reducing the size of `JsonArray` and `JsonObject`.
|
|
@ -1,30 +0,0 @@
|
|||||||
Using the library with Arduino
|
|
||||||
==============================
|
|
||||||
|
|
||||||
This library is primarily design to be used with the Arduino IDE and therefore has a simplified setup procedure for that environment.
|
|
||||||
If you don't use the Arduino IDE, please read [Using the library without Arduino](Using the library without Arduino.md).
|
|
||||||
|
|
||||||
## Install the library
|
|
||||||
|
|
||||||
[Download the zip package](https://github.com/bblanchon/ArduinoJson/releases) and extract it to:
|
|
||||||
|
|
||||||
<your Arduino Sketch folder>/libraries/ArduinoJson
|
|
||||||
|
|
||||||
Then restart the Arduino IDE.
|
|
||||||
|
|
||||||
## Run the examples sketches
|
|
||||||
|
|
||||||
Click `File` / `Example` / `ArduinoJson`.
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
## Use the library in your sketches
|
|
||||||
|
|
||||||
Just add the following line at the top of your program:
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
Then follow the instructions:
|
|
||||||
|
|
||||||
1. [Parsing JSON](Parsin JSON.md)
|
|
||||||
2. [Generating JSON](Generating JSON.md)
|
|
@ -1,37 +0,0 @@
|
|||||||
Using the library without Arduino
|
|
||||||
=================================
|
|
||||||
|
|
||||||
This library is primarily design to be used with the Arduino IDE and therefore has a simplified setup procedure for that environment.
|
|
||||||
If you use the Arduino IDE, please read [Using the library with Arduino](Using the library with Arduino.md).
|
|
||||||
|
|
||||||
However, it can be used without Arduino IDE with very little effort.
|
|
||||||
|
|
||||||
## Compiling the library
|
|
||||||
|
|
||||||
Step 1: Download source code:
|
|
||||||
|
|
||||||
git clone https://github.com/bblanchon/ArduinoJson.git
|
|
||||||
|
|
||||||
Step 2: Generate the `Makefile` for your environment
|
|
||||||
|
|
||||||
cd ArduinoJson
|
|
||||||
cmake .
|
|
||||||
|
|
||||||
Step 3: Build
|
|
||||||
|
|
||||||
make
|
|
||||||
|
|
||||||
## File paths
|
|
||||||
|
|
||||||
Assuming you installed the library into `<arduino-json>`, you need to add:
|
|
||||||
|
|
||||||
1. `<arduino-json>/include` to your include path
|
|
||||||
2. `<arduino-json>/lib` to your library path
|
|
||||||
|
|
||||||
|
|
||||||
----------
|
|
||||||
|
|
||||||
You are now ready to follow the instructions:
|
|
||||||
|
|
||||||
1. [Parsing JSON](Parsin JSON.md)
|
|
||||||
2. [Generating JSON](Generating JSON.md)
|
|
@ -1,30 +0,0 @@
|
|||||||
/*
|
|
||||||
* Arduino JSON library - IndentedPrint example
|
|
||||||
* Benoit Blanchon 2014 - MIT License
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
using namespace ArduinoJson::Internals;
|
|
||||||
|
|
||||||
void setup() {
|
|
||||||
Serial.begin(9600);
|
|
||||||
|
|
||||||
IndentedPrint serial(Serial);
|
|
||||||
serial.setTabSize(4);
|
|
||||||
|
|
||||||
serial.println("This is at indentation 0");
|
|
||||||
serial.indent();
|
|
||||||
serial.println("This is at indentation 1");
|
|
||||||
serial.println("This is also at indentation 1");
|
|
||||||
serial.indent();
|
|
||||||
serial.println("This is at indentation 2");
|
|
||||||
|
|
||||||
serial.unindent();
|
|
||||||
serial.unindent();
|
|
||||||
serial.println("This is back at indentation 0");
|
|
||||||
}
|
|
||||||
|
|
||||||
void loop() {
|
|
||||||
// not used in this example
|
|
||||||
}
|
|
152
examples/JsonConfigFile/JsonConfigFile.ino
Normal file
152
examples/JsonConfigFile/JsonConfigFile.ino
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to store your project configuration in a file.
|
||||||
|
// It uses the SD library but can be easily modified for any other file-system.
|
||||||
|
//
|
||||||
|
// The file contains a JSON document with the following content:
|
||||||
|
// {
|
||||||
|
// "hostname": "examples.com",
|
||||||
|
// "port": 2731
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// To run this program, you need an SD card connected to the SPI bus as follows:
|
||||||
|
// * MOSI <-> pin 11
|
||||||
|
// * MISO <-> pin 12
|
||||||
|
// * CLK <-> pin 13
|
||||||
|
// * CS <-> pin 4
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/config/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <SD.h>
|
||||||
|
#include <SPI.h>
|
||||||
|
|
||||||
|
// Our configuration structure.
|
||||||
|
struct Config {
|
||||||
|
char hostname[64];
|
||||||
|
int port;
|
||||||
|
};
|
||||||
|
|
||||||
|
const char* filename = "/config.txt"; // <- SD library uses 8.3 filenames
|
||||||
|
Config config; // <- global configuration object
|
||||||
|
|
||||||
|
// Loads the configuration from a file
|
||||||
|
void loadConfiguration(const char* filename, Config& config) {
|
||||||
|
// Open file for reading
|
||||||
|
File file = SD.open(filename);
|
||||||
|
|
||||||
|
// Allocate a temporary JsonDocument
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// Deserialize the JSON document
|
||||||
|
DeserializationError error = deserializeJson(doc, file);
|
||||||
|
if (error)
|
||||||
|
Serial.println(F("Failed to read file, using default configuration"));
|
||||||
|
|
||||||
|
// Copy values from the JsonDocument to the Config
|
||||||
|
config.port = doc["port"] | 2731;
|
||||||
|
strlcpy(config.hostname, // <- destination
|
||||||
|
doc["hostname"] | "example.com", // <- source
|
||||||
|
sizeof(config.hostname)); // <- destination's capacity
|
||||||
|
|
||||||
|
// Close the file (Curiously, File's destructor doesn't close the file)
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Saves the configuration to a file
|
||||||
|
void saveConfiguration(const char* filename, const Config& config) {
|
||||||
|
// Delete existing file, otherwise the configuration is appended to the file
|
||||||
|
SD.remove(filename);
|
||||||
|
|
||||||
|
// Open file for writing
|
||||||
|
File file = SD.open(filename, FILE_WRITE);
|
||||||
|
if (!file) {
|
||||||
|
Serial.println(F("Failed to create file"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Allocate a temporary JsonDocument
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// Set the values in the document
|
||||||
|
doc["hostname"] = config.hostname;
|
||||||
|
doc["port"] = config.port;
|
||||||
|
|
||||||
|
// Serialize JSON to file
|
||||||
|
if (serializeJson(doc, file) == 0) {
|
||||||
|
Serial.println(F("Failed to write to file"));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Close the file
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Prints the content of a file to the Serial
|
||||||
|
void printFile(const char* filename) {
|
||||||
|
// Open file for reading
|
||||||
|
File file = SD.open(filename);
|
||||||
|
if (!file) {
|
||||||
|
Serial.println(F("Failed to read file"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract each characters by one by one
|
||||||
|
while (file.available()) {
|
||||||
|
Serial.print((char)file.read());
|
||||||
|
}
|
||||||
|
Serial.println();
|
||||||
|
|
||||||
|
// Close the file
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Initialize SD library
|
||||||
|
const int chipSelect = 4;
|
||||||
|
while (!SD.begin(chipSelect)) {
|
||||||
|
Serial.println(F("Failed to initialize SD library"));
|
||||||
|
delay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Should load default config if run for the first time
|
||||||
|
Serial.println(F("Loading configuration..."));
|
||||||
|
loadConfiguration(filename, config);
|
||||||
|
|
||||||
|
// Create configuration file
|
||||||
|
Serial.println(F("Saving configuration..."));
|
||||||
|
saveConfiguration(filename, config);
|
||||||
|
|
||||||
|
// Dump config file
|
||||||
|
Serial.println(F("Print config file..."));
|
||||||
|
printFile(filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
||||||
|
|
||||||
|
// Performance issue?
|
||||||
|
// ------------------
|
||||||
|
//
|
||||||
|
// File is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization or deserialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a case study of a project that has
|
||||||
|
// a complex configuration with nested members.
|
||||||
|
// Contrary to this example, the project in the book uses the SPIFFS filesystem.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
64
examples/JsonFilterExample/JsonFilterExample.ino
Normal file
64
examples/JsonFilterExample/JsonFilterExample.ino
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to use DeserializationOption::Filter
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/filter/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// The huge input: an extract from OpenWeatherMap response
|
||||||
|
auto input_json = F(
|
||||||
|
"{\"cod\":\"200\",\"message\":0,\"list\":[{\"dt\":1581498000,\"main\":{"
|
||||||
|
"\"temp\":3.23,\"feels_like\":-3.63,\"temp_min\":3.23,\"temp_max\":4.62,"
|
||||||
|
"\"pressure\":1014,\"sea_level\":1014,\"grnd_level\":1010,\"humidity\":"
|
||||||
|
"58,\"temp_kf\":-1.39},\"weather\":[{\"id\":800,\"main\":\"Clear\","
|
||||||
|
"\"description\":\"clear "
|
||||||
|
"sky\",\"icon\":\"01d\"}],\"clouds\":{\"all\":0},\"wind\":{\"speed\":6."
|
||||||
|
"19,\"deg\":266},\"sys\":{\"pod\":\"d\"},\"dt_txt\":\"2020-02-12 "
|
||||||
|
"09:00:00\"},{\"dt\":1581508800,\"main\":{\"temp\":6.09,\"feels_like\":-"
|
||||||
|
"1.07,\"temp_min\":6.09,\"temp_max\":7.13,\"pressure\":1015,\"sea_"
|
||||||
|
"level\":1015,\"grnd_level\":1011,\"humidity\":48,\"temp_kf\":-1.04},"
|
||||||
|
"\"weather\":[{\"id\":800,\"main\":\"Clear\",\"description\":\"clear "
|
||||||
|
"sky\",\"icon\":\"01d\"}],\"clouds\":{\"all\":9},\"wind\":{\"speed\":6."
|
||||||
|
"64,\"deg\":268},\"sys\":{\"pod\":\"d\"},\"dt_txt\":\"2020-02-12 "
|
||||||
|
"12:00:00\"}],\"city\":{\"id\":2643743,\"name\":\"London\",\"coord\":{"
|
||||||
|
"\"lat\":51.5085,\"lon\":-0.1257},\"country\":\"GB\",\"population\":"
|
||||||
|
"1000000,\"timezone\":0,\"sunrise\":1581492085,\"sunset\":1581527294}}");
|
||||||
|
|
||||||
|
// The filter: it contains "true" for each value we want to keep
|
||||||
|
JsonDocument filter;
|
||||||
|
filter["list"][0]["dt"] = true;
|
||||||
|
filter["list"][0]["main"]["temp"] = true;
|
||||||
|
|
||||||
|
// Deserialize the document
|
||||||
|
JsonDocument doc;
|
||||||
|
deserializeJson(doc, input_json, DeserializationOption::Filter(filter));
|
||||||
|
|
||||||
|
// Print the result
|
||||||
|
serializeJsonPretty(doc, Serial);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// deserialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on deserialization.
|
||||||
|
// It begins with a simple example, like the one above, and then adds more
|
||||||
|
// features like deserializing directly from a file or an HTTP request.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
@ -1,32 +1,42 @@
|
|||||||
// Copyright Benoit Blanchon 2014
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// Arduino JSON library
|
// This example shows how to generate a JSON document with ArduinoJson.
|
||||||
// https://github.com/bblanchon/ArduinoJson
|
//
|
||||||
|
// https://arduinojson.org/v7/example/generator/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
// Initialize Serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
// Allocate the JSON document
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
JsonObject& root = jsonBuffer.createObject();
|
// Add values in the document
|
||||||
root["sensor"] = "gps";
|
doc["sensor"] = "gps";
|
||||||
root["time"] = 1351824120;
|
doc["time"] = 1351824120;
|
||||||
|
|
||||||
JsonArray& data = root.createNestedArray("data");
|
// Add an array
|
||||||
data.add(48.756080, 6); // 6 is the number of decimals to print
|
JsonArray data = doc["data"].to<JsonArray>();
|
||||||
data.add(2.302038, 6); // if not specified, 2 digits are printed
|
data.add(48.756080);
|
||||||
|
data.add(2.302038);
|
||||||
|
|
||||||
root.printTo(Serial);
|
// Generate the minified JSON and send it to the Serial port
|
||||||
// This prints:
|
serializeJson(doc, Serial);
|
||||||
|
// The above line prints:
|
||||||
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
||||||
|
|
||||||
|
// Start a new line
|
||||||
Serial.println();
|
Serial.println();
|
||||||
|
|
||||||
root.prettyPrintTo(Serial);
|
// Generate the prettified JSON and send it to the Serial port
|
||||||
// This prints:
|
serializeJsonPretty(doc, Serial);
|
||||||
|
// The above line prints:
|
||||||
// {
|
// {
|
||||||
// "sensor": "gps",
|
// "sensor": "gps",
|
||||||
// "time": 1351824120,
|
// "time": 1351824120,
|
||||||
@ -39,4 +49,17 @@ void setup() {
|
|||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
|
// It begins with a simple example, like the one above, and then adds more
|
||||||
|
// features like serializing directly to a file or an HTTP request.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
||||||
|
125
examples/JsonHttpClient/JsonHttpClient.ino
Normal file
125
examples/JsonHttpClient/JsonHttpClient.ino
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to parse a JSON document in an HTTP response.
|
||||||
|
// It uses the Ethernet library, but can be easily adapted for Wifi.
|
||||||
|
//
|
||||||
|
// It performs a GET resquest on https://arduinojson.org/example.json
|
||||||
|
// Here is the expected response:
|
||||||
|
// {
|
||||||
|
// "sensor": "gps",
|
||||||
|
// "time": 1351824120,
|
||||||
|
// "data": [
|
||||||
|
// 48.756080,
|
||||||
|
// 2.302038
|
||||||
|
// ]
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/http-client/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <Ethernet.h>
|
||||||
|
#include <SPI.h>
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize Serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Initialize Ethernet library
|
||||||
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
|
if (!Ethernet.begin(mac)) {
|
||||||
|
Serial.println(F("Failed to configure Ethernet"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
delay(1000);
|
||||||
|
|
||||||
|
Serial.println(F("Connecting..."));
|
||||||
|
|
||||||
|
// Connect to HTTP server
|
||||||
|
EthernetClient client;
|
||||||
|
client.setTimeout(10000);
|
||||||
|
if (!client.connect("arduinojson.org", 80)) {
|
||||||
|
Serial.println(F("Connection failed"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Serial.println(F("Connected!"));
|
||||||
|
|
||||||
|
// Send HTTP request
|
||||||
|
client.println(F("GET /example.json HTTP/1.0"));
|
||||||
|
client.println(F("Host: arduinojson.org"));
|
||||||
|
client.println(F("Connection: close"));
|
||||||
|
if (client.println() == 0) {
|
||||||
|
Serial.println(F("Failed to send request"));
|
||||||
|
client.stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check HTTP status
|
||||||
|
char status[32] = {0};
|
||||||
|
client.readBytesUntil('\r', status, sizeof(status));
|
||||||
|
// It should be "HTTP/1.0 200 OK" or "HTTP/1.1 200 OK"
|
||||||
|
if (strcmp(status + 9, "200 OK") != 0) {
|
||||||
|
Serial.print(F("Unexpected response: "));
|
||||||
|
Serial.println(status);
|
||||||
|
client.stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Skip HTTP headers
|
||||||
|
char endOfHeaders[] = "\r\n\r\n";
|
||||||
|
if (!client.find(endOfHeaders)) {
|
||||||
|
Serial.println(F("Invalid response"));
|
||||||
|
client.stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Allocate the JSON document
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// Parse JSON object
|
||||||
|
DeserializationError error = deserializeJson(doc, client);
|
||||||
|
if (error) {
|
||||||
|
Serial.print(F("deserializeJson() failed: "));
|
||||||
|
Serial.println(error.f_str());
|
||||||
|
client.stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract values
|
||||||
|
Serial.println(F("Response:"));
|
||||||
|
Serial.println(doc["sensor"].as<const char*>());
|
||||||
|
Serial.println(doc["time"].as<long>());
|
||||||
|
Serial.println(doc["data"][0].as<float>(), 6);
|
||||||
|
Serial.println(doc["data"][1].as<float>(), 6);
|
||||||
|
|
||||||
|
// Disconnect
|
||||||
|
client.stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
||||||
|
|
||||||
|
// Performance issue?
|
||||||
|
// ------------------
|
||||||
|
//
|
||||||
|
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on deserialization
|
||||||
|
// showing how to parse the response from GitHub's API. In the last chapter,
|
||||||
|
// it shows how to parse the huge documents from OpenWeatherMap
|
||||||
|
// and Reddit.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
@ -1,31 +1,46 @@
|
|||||||
// Copyright Benoit Blanchon 2014
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// Arduino JSON library
|
// This example shows how to deserialize a JSON document with ArduinoJson.
|
||||||
// https://github.com/bblanchon/ArduinoJson
|
//
|
||||||
|
// https://arduinojson.org/v7/example/parser/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
StaticJsonBuffer<200> jsonBuffer;
|
// Allocate the JSON document
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
char json[] =
|
// JSON input string.
|
||||||
|
const char* json =
|
||||||
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
|
||||||
JsonObject& root = jsonBuffer.parseObject(json);
|
// Deserialize the JSON document
|
||||||
|
DeserializationError error = deserializeJson(doc, json);
|
||||||
|
|
||||||
if (!root.success()) {
|
// Test if parsing succeeds
|
||||||
Serial.println("parseObject() failed");
|
if (error) {
|
||||||
|
Serial.print(F("deserializeJson() failed: "));
|
||||||
|
Serial.println(error.f_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* sensor = root["sensor"];
|
// Fetch the values
|
||||||
long time = root["time"];
|
//
|
||||||
double latitude = root["data"][0];
|
// Most of the time, you can rely on the implicit casts.
|
||||||
double longitude = root["data"][1];
|
// In other case, you can do doc["time"].as<long>();
|
||||||
|
const char* sensor = doc["sensor"];
|
||||||
|
long time = doc["time"];
|
||||||
|
double latitude = doc["data"][0];
|
||||||
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
|
// Print the values
|
||||||
Serial.println(sensor);
|
Serial.println(sensor);
|
||||||
Serial.println(time);
|
Serial.println(time);
|
||||||
Serial.println(latitude, 6);
|
Serial.println(latitude, 6);
|
||||||
@ -34,4 +49,17 @@ void setup() {
|
|||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
// not used in this example
|
// not used in this example
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// deserialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on deserialization.
|
||||||
|
// It begins with a simple example, like the one above, and then adds more
|
||||||
|
// features like deserializing directly from a file or an HTTP request.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
||||||
|
118
examples/JsonServer/JsonServer.ino
Normal file
118
examples/JsonServer/JsonServer.ino
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to implement an HTTP server that sends a JSON document
|
||||||
|
// in the response.
|
||||||
|
// It uses the Ethernet library but can be easily adapted for Wifi.
|
||||||
|
//
|
||||||
|
// The JSON document contains the values of the analog and digital pins.
|
||||||
|
// It looks like that:
|
||||||
|
// {
|
||||||
|
// "analog": [0, 76, 123, 158, 192, 205],
|
||||||
|
// "digital": [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0]
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/http-server/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <Ethernet.h>
|
||||||
|
#include <SPI.h>
|
||||||
|
|
||||||
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
|
EthernetServer server(80);
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Initialize Ethernet libary
|
||||||
|
if (!Ethernet.begin(mac)) {
|
||||||
|
Serial.println(F("Failed to initialize Ethernet library"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start to listen
|
||||||
|
server.begin();
|
||||||
|
|
||||||
|
Serial.println(F("Server is ready."));
|
||||||
|
Serial.print(F("Please connect to http://"));
|
||||||
|
Serial.println(Ethernet.localIP());
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// Wait for an incomming connection
|
||||||
|
EthernetClient client = server.available();
|
||||||
|
|
||||||
|
// Do we have a client?
|
||||||
|
if (!client)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Serial.println(F("New client"));
|
||||||
|
|
||||||
|
// Read the request (we ignore the content in this example)
|
||||||
|
while (client.available())
|
||||||
|
client.read();
|
||||||
|
|
||||||
|
// Allocate a temporary JsonDocument
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// Create the "analog" array
|
||||||
|
JsonArray analogValues = doc["analog"].to<JsonArray>();
|
||||||
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
|
// Read the analog input
|
||||||
|
int value = analogRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
analogValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the "digital" array
|
||||||
|
JsonArray digitalValues = doc["digital"].to<JsonArray>();
|
||||||
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
|
// Read the digital input
|
||||||
|
int value = digitalRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
digitalValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
Serial.print(F("Sending: "));
|
||||||
|
serializeJson(doc, Serial);
|
||||||
|
Serial.println();
|
||||||
|
|
||||||
|
// Write response headers
|
||||||
|
client.println(F("HTTP/1.0 200 OK"));
|
||||||
|
client.println(F("Content-Type: application/json"));
|
||||||
|
client.println(F("Connection: close"));
|
||||||
|
client.print(F("Content-Length: "));
|
||||||
|
client.println(measureJsonPretty(doc));
|
||||||
|
client.println();
|
||||||
|
|
||||||
|
// Write JSON document
|
||||||
|
serializeJsonPretty(doc, client);
|
||||||
|
|
||||||
|
// Disconnect
|
||||||
|
client.stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Performance issue?
|
||||||
|
// ------------------
|
||||||
|
//
|
||||||
|
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
|
// It begins with a simple example, then adds more features like serializing
|
||||||
|
// directly to a file or an HTTP client.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
106
examples/JsonUdpBeacon/JsonUdpBeacon.ino
Normal file
106
examples/JsonUdpBeacon/JsonUdpBeacon.ino
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to send a JSON document to a UDP socket.
|
||||||
|
// At regular interval, it sends a UDP packet that contains the status of
|
||||||
|
// analog and digital pins.
|
||||||
|
// It looks like that:
|
||||||
|
// {
|
||||||
|
// "analog": [0, 76, 123, 158, 192, 205],
|
||||||
|
// "digital": [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0]
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// If you want to test this program, you need to be able to receive the UDP
|
||||||
|
// packets.
|
||||||
|
// For example, you can run netcat on your computer
|
||||||
|
// $ ncat -ulp 8888
|
||||||
|
// See https://nmap.org/ncat/
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/udp-beacon/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <Ethernet.h>
|
||||||
|
#include <SPI.h>
|
||||||
|
|
||||||
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
|
IPAddress remoteIp(192, 168, 0, 108); // <- EDIT!!!!
|
||||||
|
unsigned short remotePort = 8888;
|
||||||
|
unsigned short localPort = 8888;
|
||||||
|
EthernetUDP udp;
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Initialize Ethernet libary
|
||||||
|
if (!Ethernet.begin(mac)) {
|
||||||
|
Serial.println(F("Failed to initialize Ethernet library"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enable UDP
|
||||||
|
udp.begin(localPort);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// Allocate a temporary JsonDocument
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// Create the "analog" array
|
||||||
|
JsonArray analogValues = doc["analog"].to<JsonArray>();
|
||||||
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
|
// Read the analog input
|
||||||
|
int value = analogRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
analogValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create the "digital" array
|
||||||
|
JsonArray digitalValues = doc["digital"].to<JsonArray>();
|
||||||
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
|
// Read the digital input
|
||||||
|
int value = digitalRead(pin);
|
||||||
|
|
||||||
|
// Add the value at the end of the array
|
||||||
|
digitalValues.add(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Log
|
||||||
|
Serial.print(F("Sending to "));
|
||||||
|
Serial.print(remoteIp);
|
||||||
|
Serial.print(F(" on port "));
|
||||||
|
Serial.println(remotePort);
|
||||||
|
serializeJson(doc, Serial);
|
||||||
|
|
||||||
|
// Send UDP packet
|
||||||
|
udp.beginPacket(remoteIp, remotePort);
|
||||||
|
serializeJson(doc, udp);
|
||||||
|
udp.println();
|
||||||
|
udp.endPacket();
|
||||||
|
|
||||||
|
// Wait
|
||||||
|
delay(10000);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Performance issue?
|
||||||
|
// ------------------
|
||||||
|
//
|
||||||
|
// EthernetUDP is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any
|
||||||
|
// serialization problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a tutorial on serialization.
|
||||||
|
// It begins with a simple example, then adds more features like serializing
|
||||||
|
// directly to a file or any stream.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
61
examples/MsgPackParser/MsgPackParser.ino
Normal file
61
examples/MsgPackParser/MsgPackParser.ino
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows how to deserialize a MessagePack document with
|
||||||
|
// ArduinoJson.
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/msgpack-parser/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
// Initialize serial port
|
||||||
|
Serial.begin(9600);
|
||||||
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Allocate the JSON document
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// The MessagePack input string
|
||||||
|
uint8_t input[] = {131, 166, 115, 101, 110, 115, 111, 114, 163, 103, 112, 115,
|
||||||
|
164, 116, 105, 109, 101, 206, 80, 147, 50, 248, 164, 100,
|
||||||
|
97, 116, 97, 146, 203, 64, 72, 96, 199, 58, 188, 148,
|
||||||
|
112, 203, 64, 2, 106, 146, 230, 33, 49, 169};
|
||||||
|
// This MessagePack document contains:
|
||||||
|
// {
|
||||||
|
// "sensor": "gps",
|
||||||
|
// "time": 1351824120,
|
||||||
|
// "data": [48.75608, 2.302038]
|
||||||
|
// }
|
||||||
|
|
||||||
|
// Parse the input
|
||||||
|
DeserializationError error = deserializeMsgPack(doc, input);
|
||||||
|
|
||||||
|
// Test if parsing succeeded
|
||||||
|
if (error) {
|
||||||
|
Serial.print("deserializeMsgPack() failed: ");
|
||||||
|
Serial.println(error.f_str());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fetch the values
|
||||||
|
//
|
||||||
|
// Most of the time, you can rely on the implicit casts.
|
||||||
|
// In other case, you can do doc["time"].as<long>();
|
||||||
|
const char* sensor = doc["sensor"];
|
||||||
|
long time = doc["time"];
|
||||||
|
double latitude = doc["data"][0];
|
||||||
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
|
// Print the values
|
||||||
|
Serial.println(sensor);
|
||||||
|
Serial.println(time);
|
||||||
|
Serial.println(latitude, 6);
|
||||||
|
Serial.println(longitude, 6);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
63
examples/ProgmemExample/ProgmemExample.ino
Normal file
63
examples/ProgmemExample/ProgmemExample.ino
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows the different ways you can use Flash strings with
|
||||||
|
// ArduinoJson.
|
||||||
|
//
|
||||||
|
// Use Flash strings sparingly, because ArduinoJson duplicates them in the
|
||||||
|
// JsonDocument. Prefer plain old char*, as they are more efficient in term of
|
||||||
|
// code size, speed, and memory usage.
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/progmem/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// You can use a Flash String as your JSON input.
|
||||||
|
// WARNING: the strings in the input will be duplicated in the JsonDocument.
|
||||||
|
deserializeJson(doc, F("{\"sensor\":\"gps\",\"time\":1351824120,"
|
||||||
|
"\"data\":[48.756080,2.302038]}"));
|
||||||
|
|
||||||
|
// You can use a Flash String as a key to get a member from JsonDocument
|
||||||
|
// No duplication is done.
|
||||||
|
long time = doc[F("time")];
|
||||||
|
|
||||||
|
// You can use a Flash String as a key to set a member of a JsonDocument
|
||||||
|
// WARNING: the content of the Flash String will be duplicated in the
|
||||||
|
// JsonDocument.
|
||||||
|
doc[F("time")] = time;
|
||||||
|
|
||||||
|
// You can set a Flash String as the content of a JsonVariant
|
||||||
|
// WARNING: the content of the Flash String will be duplicated in the
|
||||||
|
// JsonDocument.
|
||||||
|
doc["sensor"] = F("gps");
|
||||||
|
|
||||||
|
// It works with serialized() too:
|
||||||
|
doc["sensor"] = serialized(F("\"gps\""));
|
||||||
|
doc["sensor"] = serialized(F("\xA3gps"), 3);
|
||||||
|
|
||||||
|
// You can compare the content of a JsonVariant to a Flash String
|
||||||
|
if (doc["sensor"] == F("gps")) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any memory
|
||||||
|
// problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a quick C++ course that explains
|
||||||
|
// how your microcontroller stores strings in memory. It also tells why you
|
||||||
|
// should not abuse Flash strings with ArduinoJson.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
76
examples/StringExample/StringExample.ino
Normal file
76
examples/StringExample/StringExample.ino
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
//
|
||||||
|
// This example shows the different ways you can use String with ArduinoJson.
|
||||||
|
//
|
||||||
|
// Use String objects sparingly, because ArduinoJson duplicates them in the
|
||||||
|
// JsonDocument. Prefer plain old char[], as they are more efficient in term of
|
||||||
|
// code size, speed, and memory usage.
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/v7/example/string/
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
// You can use a String as your JSON input.
|
||||||
|
// WARNING: the string in the input will be duplicated in the JsonDocument.
|
||||||
|
String input =
|
||||||
|
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
deserializeJson(doc, input);
|
||||||
|
|
||||||
|
// You can use a String as a key to get a member from JsonDocument
|
||||||
|
// No duplication is done.
|
||||||
|
long time = doc[String("time")];
|
||||||
|
|
||||||
|
// You can use a String as a key to set a member of a JsonDocument
|
||||||
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
|
doc[String("time")] = time;
|
||||||
|
|
||||||
|
// You can get the content of a JsonVariant as a String
|
||||||
|
// No duplication is done, at least not in the JsonDocument.
|
||||||
|
String sensor = doc["sensor"];
|
||||||
|
|
||||||
|
// Unfortunately, the following doesn't work (issue #118):
|
||||||
|
// sensor = doc["sensor"]; // <- error "ambiguous overload for 'operator='"
|
||||||
|
// As a workaround, you need to replace by:
|
||||||
|
sensor = doc["sensor"].as<String>();
|
||||||
|
|
||||||
|
// You can set a String as the content of a JsonVariant
|
||||||
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
|
doc["sensor"] = sensor;
|
||||||
|
|
||||||
|
// It works with serialized() too:
|
||||||
|
doc["sensor"] = serialized(sensor);
|
||||||
|
|
||||||
|
// You can also concatenate strings
|
||||||
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
|
doc[String("sen") + "sor"] = String("gp") + "s";
|
||||||
|
|
||||||
|
// You can compare the content of a JsonObject with a String
|
||||||
|
if (doc["sensor"] == sensor) {
|
||||||
|
// ...
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lastly, you can print the resulting JSON to a String
|
||||||
|
String output;
|
||||||
|
serializeJson(doc, output);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
// not used in this example
|
||||||
|
}
|
||||||
|
|
||||||
|
// See also
|
||||||
|
// --------
|
||||||
|
//
|
||||||
|
// https://arduinojson.org/ contains the documentation for all the functions
|
||||||
|
// used above. It also includes an FAQ that will help you solve any problem.
|
||||||
|
//
|
||||||
|
// The book "Mastering ArduinoJson" contains a quick C++ course that explains
|
||||||
|
// how your microcontroller stores strings in memory. On several occasions, it
|
||||||
|
// shows how you can avoid String in your program.
|
||||||
|
// Learn more at https://arduinojson.org/book/
|
||||||
|
// Use the coupon code TWENTY for a 20% discount ❤❤❤❤❤
|
4
extras/ArduinoJsonConfig.cmake.in
Normal file
4
extras/ArduinoJsonConfig.cmake.in
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
@PACKAGE_INIT@
|
||||||
|
|
||||||
|
include("${CMAKE_CURRENT_LIST_DIR}/@PROJECT_NAME@Targets.cmake")
|
||||||
|
check_required_components("@PROJECT_NAME@")
|
112
extras/CompileOptions.cmake
Normal file
112
extras/CompileOptions.cmake
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
if(NOT DEFINED COVERAGE)
|
||||||
|
set(COVERAGE OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
||||||
|
add_compile_options(
|
||||||
|
-pedantic
|
||||||
|
-Wall
|
||||||
|
-Wcast-align
|
||||||
|
-Wcast-qual
|
||||||
|
-Wconversion
|
||||||
|
-Wctor-dtor-privacy
|
||||||
|
-Wdisabled-optimization
|
||||||
|
-Werror
|
||||||
|
-Wextra
|
||||||
|
-Wformat=2
|
||||||
|
-Winit-self
|
||||||
|
-Wmissing-include-dirs
|
||||||
|
-Wnon-virtual-dtor
|
||||||
|
-Wold-style-cast
|
||||||
|
-Woverloaded-virtual
|
||||||
|
-Wparentheses
|
||||||
|
-Wredundant-decls
|
||||||
|
-Wshadow
|
||||||
|
-Wsign-conversion
|
||||||
|
-Wsign-promo
|
||||||
|
-Wstrict-aliasing
|
||||||
|
-Wundef
|
||||||
|
)
|
||||||
|
|
||||||
|
if(${COVERAGE})
|
||||||
|
set(CMAKE_CXX_FLAGS "-fprofile-arcs -ftest-coverage")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
||||||
|
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.9) AND(NOT ${COVERAGE}))
|
||||||
|
add_compile_options(-g -Og)
|
||||||
|
else() # GCC 4.8
|
||||||
|
add_compile_options(
|
||||||
|
-g
|
||||||
|
-O0 # GCC 4.8 doesn't support -Og
|
||||||
|
-Wno-shadow # allow the same name for a function parameter and a member functions
|
||||||
|
-Wp,-w # Disable preprocessing warnings (see below)
|
||||||
|
)
|
||||||
|
# GCC 4.8 doesn't support __has_include, so we need to help him
|
||||||
|
add_definitions(
|
||||||
|
-DARDUINOJSON_ENABLE_STD_STRING=1
|
||||||
|
-DARDUINOJSON_ENABLE_STD_STREAM=1
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_compile_options(
|
||||||
|
-Wstrict-null-sentinel
|
||||||
|
-Wno-vla # Allow VLA in tests
|
||||||
|
)
|
||||||
|
add_definitions(-DHAS_VARIABLE_LENGTH_ARRAY)
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.5)
|
||||||
|
add_compile_options(-Wlogical-op) # the flag exists in 4.4 but is buggy
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.6)
|
||||||
|
add_compile_options(-Wnoexcept)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
|
add_compile_options(
|
||||||
|
-Wc++11-compat
|
||||||
|
-Wdeprecated-register
|
||||||
|
-Wno-vla-extension # Allow VLA in tests
|
||||||
|
)
|
||||||
|
add_definitions(
|
||||||
|
-DHAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
-DSUBSCRIPT_CONFLICTS_WITH_BUILTIN_OPERATOR
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
||||||
|
add_compile_options(-stdlib=libc++)
|
||||||
|
link_libraries(c++ m)
|
||||||
|
|
||||||
|
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.0) AND(NOT ${COVERAGE}))
|
||||||
|
add_compile_options(-g -Og)
|
||||||
|
else()
|
||||||
|
add_compile_options(-g -O0)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "AppleClang")
|
||||||
|
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 9.0) AND(NOT ${COVERAGE}))
|
||||||
|
add_compile_options(-g -Og)
|
||||||
|
else()
|
||||||
|
add_compile_options(-g -O0)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(MSVC)
|
||||||
|
add_definitions(-D_CRT_SECURE_NO_WARNINGS)
|
||||||
|
add_compile_options(
|
||||||
|
/W4 # Set warning level
|
||||||
|
/WX # Treats all compiler warnings as errors.
|
||||||
|
/Zc:__cplusplus # Enable updated __cplusplus macro
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(MINGW)
|
||||||
|
# Static link on MinGW to avoid linking with the wrong DLLs when multiple
|
||||||
|
# versions are installed.
|
||||||
|
add_link_options(-static)
|
||||||
|
endif()
|
8
extras/ci/espidf/CMakeLists.txt
Normal file
8
extras/ci/espidf/CMakeLists.txt
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# ArduinoJson - https://arduinojson.org
|
||||||
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
# MIT License
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.5)
|
||||||
|
|
||||||
|
include($ENV{IDF_PATH}/tools/cmake/project.cmake)
|
||||||
|
project(example)
|
8
extras/ci/espidf/main/CMakeLists.txt
Normal file
8
extras/ci/espidf/main/CMakeLists.txt
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# ArduinoJson - https://arduinojson.org
|
||||||
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
# MIT License
|
||||||
|
|
||||||
|
idf_component_register(
|
||||||
|
SRCS "main.cpp"
|
||||||
|
INCLUDE_DIRS ""
|
||||||
|
)
|
4
extras/ci/espidf/main/component.mk
Normal file
4
extras/ci/espidf/main/component.mk
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#
|
||||||
|
# "main" pseudo-component makefile.
|
||||||
|
#
|
||||||
|
# (Uses default behaviour of compiling all source files in directory, adding 'include' to include path.)
|
16
extras/ci/espidf/main/main.cpp
Normal file
16
extras/ci/espidf/main/main.cpp
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
extern "C" void app_main() {
|
||||||
|
char buffer[256];
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
doc["hello"] = "world";
|
||||||
|
serializeJson(doc, buffer);
|
||||||
|
deserializeJson(doc, buffer);
|
||||||
|
serializeMsgPack(doc, buffer);
|
||||||
|
deserializeMsgPack(doc, buffer);
|
||||||
|
}
|
10
extras/ci/particle.sh
Executable file
10
extras/ci/particle.sh
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh -ex
|
||||||
|
|
||||||
|
BOARD=$1
|
||||||
|
|
||||||
|
cd "$(dirname "$0")/../../"
|
||||||
|
|
||||||
|
cp extras/particle/src/smocktest.ino src/
|
||||||
|
cp extras/particle/project.properties ./
|
||||||
|
|
||||||
|
particle compile "$BOARD"
|
18
extras/conf_test/avr.cpp
Normal file
18
extras/conf_test/avr.cpp
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_ENABLE_PROGMEM == 1, "ARDUINOJSON_ENABLE_PROGMEM");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 0, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 1, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 16, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_DOUBLE == 0, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 6, "slot size");
|
||||||
|
|
||||||
|
void setup() {}
|
||||||
|
void loop() {}
|
16
extras/conf_test/esp8266.cpp
Normal file
16
extras/conf_test/esp8266.cpp
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 2, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 128, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 8, "slot size");
|
||||||
|
|
||||||
|
void setup() {}
|
||||||
|
void loop() {}
|
15
extras/conf_test/x64.cpp
Normal file
15
extras/conf_test/x64.cpp
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 4, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 256, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 16, "slot size");
|
||||||
|
|
||||||
|
int main() {}
|
15
extras/conf_test/x86.cpp
Normal file
15
extras/conf_test/x86.cpp
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 2, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 128, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 8, "slot size");
|
||||||
|
|
||||||
|
int main() {}
|
67
extras/fuzzing/CMakeLists.txt
Normal file
67
extras/fuzzing/CMakeLists.txt
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
# ArduinoJson - https://arduinojson.org
|
||||||
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
# MIT License
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 11)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
|
if(MSVC)
|
||||||
|
add_compile_options(-D_CRT_SECURE_NO_WARNINGS)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_executable(msgpack_reproducer
|
||||||
|
msgpack_fuzzer.cpp
|
||||||
|
reproducer.cpp
|
||||||
|
)
|
||||||
|
target_link_libraries(msgpack_reproducer
|
||||||
|
ArduinoJson
|
||||||
|
)
|
||||||
|
|
||||||
|
add_executable(json_reproducer
|
||||||
|
json_fuzzer.cpp
|
||||||
|
reproducer.cpp
|
||||||
|
)
|
||||||
|
target_link_libraries(json_reproducer
|
||||||
|
ArduinoJson
|
||||||
|
)
|
||||||
|
|
||||||
|
macro(add_fuzzer name)
|
||||||
|
set(FUZZER "${name}_fuzzer")
|
||||||
|
set(CORPUS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/${name}_corpus")
|
||||||
|
set(SEED_CORPUS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/${name}_seed_corpus")
|
||||||
|
add_executable("${FUZZER}"
|
||||||
|
"${name}_fuzzer.cpp"
|
||||||
|
)
|
||||||
|
target_link_libraries("${FUZZER}"
|
||||||
|
ArduinoJson
|
||||||
|
)
|
||||||
|
set_target_properties("${FUZZER}"
|
||||||
|
PROPERTIES
|
||||||
|
COMPILE_FLAGS "-fprofile-instr-generate -fcoverage-mapping -fsanitize=fuzzer -fno-sanitize-recover=all"
|
||||||
|
LINK_FLAGS "-fprofile-instr-generate -fcoverage-mapping -fsanitize=fuzzer -fno-sanitize-recover=all"
|
||||||
|
)
|
||||||
|
|
||||||
|
add_test(
|
||||||
|
NAME "${FUZZER}"
|
||||||
|
COMMAND "${FUZZER}" "${CORPUS_DIR}" "${SEED_CORPUS_DIR}" -max_total_time=5 -timeout=1
|
||||||
|
)
|
||||||
|
|
||||||
|
set_tests_properties("${FUZZER}"
|
||||||
|
PROPERTIES
|
||||||
|
LABELS "Fuzzing"
|
||||||
|
)
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
# Needs Clang 6+ to compile
|
||||||
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang" AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 6)
|
||||||
|
if(DEFINED ENV{GITHUB_ACTIONS} AND CMAKE_CXX_COMPILER_VERSION MATCHES "^11\\.")
|
||||||
|
# Clang 11 fails on GitHub Actions with the following error:
|
||||||
|
# > ERROR: UndefinedBehaviorSanitizer failed to allocate 0x0 (0) bytes of SetAlternateSignalStack (error code: 22)
|
||||||
|
# > Sanitizer CHECK failed: /build/llvm-toolchain-11-mnvtwk/llvm-toolchain-11-11.1.0/compiler-rt/lib/sanitizer_common/sanitizer_common.cpp:54 ((0 && "unable to mmap")) != (0) (0, 0)
|
||||||
|
message(WARNING "Fuzzing is disabled on GitHub Actions to workaround a bug in Clang 11")
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_fuzzer(json)
|
||||||
|
add_fuzzer(msgpack)
|
||||||
|
endif()
|
22
extras/fuzzing/Makefile
Normal file
22
extras/fuzzing/Makefile
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# CAUTION: this file is invoked by https://github.com/google/oss-fuzz
|
||||||
|
|
||||||
|
CXXFLAGS += -I../../src -DARDUINOJSON_DEBUG=1 -std=c++11
|
||||||
|
|
||||||
|
all: \
|
||||||
|
$(OUT)/json_fuzzer \
|
||||||
|
$(OUT)/json_fuzzer_seed_corpus.zip \
|
||||||
|
$(OUT)/json_fuzzer.options \
|
||||||
|
$(OUT)/msgpack_fuzzer \
|
||||||
|
$(OUT)/msgpack_fuzzer_seed_corpus.zip \
|
||||||
|
$(OUT)/msgpack_fuzzer.options
|
||||||
|
|
||||||
|
$(OUT)/%_fuzzer: %_fuzzer.cpp $(shell find ../../src -type f)
|
||||||
|
$(CXX) $(CXXFLAGS) $< -o$@ $(LIB_FUZZING_ENGINE)
|
||||||
|
|
||||||
|
$(OUT)/%_fuzzer_seed_corpus.zip: %_seed_corpus/*
|
||||||
|
zip -j $@ $?
|
||||||
|
|
||||||
|
$(OUT)/%_fuzzer.options:
|
||||||
|
@echo "[libfuzzer]" > $@
|
||||||
|
@echo "max_len = 256" >> $@
|
||||||
|
@echo "timeout = 10" >> $@
|
2
extras/fuzzing/json_corpus/.gitignore
vendored
Normal file
2
extras/fuzzing/json_corpus/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
11
extras/fuzzing/json_fuzzer.cpp
Normal file
11
extras/fuzzing/json_fuzzer.cpp
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||||
|
JsonDocument doc;
|
||||||
|
DeserializationError error = deserializeJson(doc, data, size);
|
||||||
|
if (!error) {
|
||||||
|
std::string json;
|
||||||
|
serializeJson(doc, json);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
10
extras/fuzzing/json_seed_corpus/Comments.json
Normal file
10
extras/fuzzing/json_seed_corpus/Comments.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
//comment
|
||||||
|
/*comment*/
|
||||||
|
[ //comment
|
||||||
|
/*comment*/"comment"/*comment*/,//comment
|
||||||
|
/*comment*/{//comment
|
||||||
|
/* comment*/"key"//comment
|
||||||
|
: //comment
|
||||||
|
"value"//comment
|
||||||
|
}/*comment*/
|
||||||
|
]//comment
|
1
extras/fuzzing/json_seed_corpus/EmptyArray.json
Normal file
1
extras/fuzzing/json_seed_corpus/EmptyArray.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
[]
|
1
extras/fuzzing/json_seed_corpus/EmptyObject.json
Normal file
1
extras/fuzzing/json_seed_corpus/EmptyObject.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
1
extras/fuzzing/json_seed_corpus/ExcessiveNesting.json
Normal file
1
extras/fuzzing/json_seed_corpus/ExcessiveNesting.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
[1,[2,[3,[4,[5,[6,[7,[8,[9,[10,[11,[12,[13,[14,[15,[16,[17,[18,[19,[20,[21,[22,[23,[24,[25,[26,[27,[28,[29,[30,[31,[32,[33,[34,[35,[36,[37,[38,[39,[40,[41,[42,[43,[44,[45,[46,[47,[48,[49,[50,[51,[52,[53,[54,[55,[56,[57,[58,[59,[60,[61,[62,[63,[64,[65,[66,[67,[68,[69,[70,[71,[72,[73,[74,[75,[76,[77,[78,[79,[80,[81,[82,[83,[84,[85,[86,[87,[88,[89,[90,[91,[92,[93,[94,[95,[96,[97,[98,[99,[100,[101,[102,[103,[104,[105,[106,[107,[108,[109,[110,[111,[112,[113,[114,[115,[116,[117,[118,[119,[120]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]]
|
1
extras/fuzzing/json_seed_corpus/IntegerOverflow.json
Normal file
1
extras/fuzzing/json_seed_corpus/IntegerOverflow.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
9720730739393920739
|
24
extras/fuzzing/json_seed_corpus/Numbers.json
Normal file
24
extras/fuzzing/json_seed_corpus/Numbers.json
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
[
|
||||||
|
123,
|
||||||
|
-123,
|
||||||
|
123.456,
|
||||||
|
-123.456,
|
||||||
|
12e34,
|
||||||
|
12e-34,
|
||||||
|
12e+34,
|
||||||
|
12E34,
|
||||||
|
12E-34,
|
||||||
|
12E+34,
|
||||||
|
12.34e56,
|
||||||
|
12.34e-56,
|
||||||
|
12.34e+56,
|
||||||
|
12.34E56,
|
||||||
|
12.34E-56,
|
||||||
|
12.34E+56,
|
||||||
|
NaN,
|
||||||
|
-NaN,
|
||||||
|
+NaN,
|
||||||
|
Infinity,
|
||||||
|
+Infinity,
|
||||||
|
-Infinity
|
||||||
|
]
|
53
extras/fuzzing/json_seed_corpus/OpenWeatherMap.json
Normal file
53
extras/fuzzing/json_seed_corpus/OpenWeatherMap.json
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
{
|
||||||
|
"coord": {
|
||||||
|
"lon": -0.13,
|
||||||
|
"lat": 51.51
|
||||||
|
},
|
||||||
|
"weather": [
|
||||||
|
{
|
||||||
|
"id": 301,
|
||||||
|
"main": "Drizzle",
|
||||||
|
"description": "drizzle",
|
||||||
|
"icon": "09n"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 701,
|
||||||
|
"main": "Mist",
|
||||||
|
"description": "mist",
|
||||||
|
"icon": "50n"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 741,
|
||||||
|
"main": "Fog",
|
||||||
|
"description": "fog",
|
||||||
|
"icon": "50n"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"base": "stations",
|
||||||
|
"main": {
|
||||||
|
"temp": 281.87,
|
||||||
|
"pressure": 1032,
|
||||||
|
"humidity": 100,
|
||||||
|
"temp_min": 281.15,
|
||||||
|
"temp_max": 283.15
|
||||||
|
},
|
||||||
|
"visibility": 2900,
|
||||||
|
"wind": {
|
||||||
|
"speed": 1.5
|
||||||
|
},
|
||||||
|
"clouds": {
|
||||||
|
"all": 90
|
||||||
|
},
|
||||||
|
"dt": 1483820400,
|
||||||
|
"sys": {
|
||||||
|
"type": 1,
|
||||||
|
"id": 5091,
|
||||||
|
"message": 0.0226,
|
||||||
|
"country": "GB",
|
||||||
|
"sunrise": 1483776245,
|
||||||
|
"sunset": 1483805443
|
||||||
|
},
|
||||||
|
"id": 2643743,
|
||||||
|
"name": "London",
|
||||||
|
"cod": 200
|
||||||
|
}
|
8
extras/fuzzing/json_seed_corpus/Strings.json
Normal file
8
extras/fuzzing/json_seed_corpus/Strings.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
[
|
||||||
|
"hello",
|
||||||
|
'hello',
|
||||||
|
hello,
|
||||||
|
{"hello":"world"},
|
||||||
|
{'hello':'world'},
|
||||||
|
{hello:world}
|
||||||
|
]
|
90
extras/fuzzing/json_seed_corpus/WeatherUnderground.json
Normal file
90
extras/fuzzing/json_seed_corpus/WeatherUnderground.json
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
{
|
||||||
|
"response": {
|
||||||
|
"version": "0.1",
|
||||||
|
"termsofService": "http://www.wunderground.com/weather/api/d/terms.html",
|
||||||
|
"features": {
|
||||||
|
"conditions": 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"current_observation": {
|
||||||
|
"image": {
|
||||||
|
"url": "http://icons-ak.wxug.com/graphics/wu2/logo_130x80.png",
|
||||||
|
"title": "Weather Underground",
|
||||||
|
"link": "http://www.wunderground.com"
|
||||||
|
},
|
||||||
|
"display_location": {
|
||||||
|
"full": "San Francisco, CA",
|
||||||
|
"city": "San Francisco",
|
||||||
|
"state": "CA",
|
||||||
|
"state_name": "California",
|
||||||
|
"country": "US",
|
||||||
|
"country_iso3166": "US",
|
||||||
|
"zip": "94101",
|
||||||
|
"latitude": "37.77500916",
|
||||||
|
"longitude": "-122.41825867",
|
||||||
|
"elevation": "47.00000000"
|
||||||
|
},
|
||||||
|
"observation_location": {
|
||||||
|
"full": "SOMA - Near Van Ness, San Francisco, California",
|
||||||
|
"city": "SOMA - Near Van Ness, San Francisco",
|
||||||
|
"state": "California",
|
||||||
|
"country": "US",
|
||||||
|
"country_iso3166": "US",
|
||||||
|
"latitude": "37.773285",
|
||||||
|
"longitude": "-122.417725",
|
||||||
|
"elevation": "49 ft"
|
||||||
|
},
|
||||||
|
"estimated": {},
|
||||||
|
"station_id": "KCASANFR58",
|
||||||
|
"observation_time": "Last Updated on June 27, 5:27 PM PDT",
|
||||||
|
"observation_time_rfc822": "Wed, 27 Jun 2012 17:27:13 -0700",
|
||||||
|
"observation_epoch": "1340843233",
|
||||||
|
"local_time_rfc822": "Wed, 27 Jun 2012 17:27:14 -0700",
|
||||||
|
"local_epoch": "1340843234",
|
||||||
|
"local_tz_short": "PDT",
|
||||||
|
"local_tz_long": "America/Los_Angeles",
|
||||||
|
"local_tz_offset": "-0700",
|
||||||
|
"weather": "Partly Cloudy",
|
||||||
|
"temperature_string": "66.3 F (19.1 C)",
|
||||||
|
"temp_f": 66.3,
|
||||||
|
"temp_c": 19.1,
|
||||||
|
"relative_humidity": "65%",
|
||||||
|
"wind_string": "From the NNW at 22.0 MPH Gusting to 28.0 MPH",
|
||||||
|
"wind_dir": "NNW",
|
||||||
|
"wind_degrees": 346,
|
||||||
|
"wind_mph": 22,
|
||||||
|
"wind_gust_mph": "28.0",
|
||||||
|
"wind_kph": 35.4,
|
||||||
|
"wind_gust_kph": "45.1",
|
||||||
|
"pressure_mb": "1013",
|
||||||
|
"pressure_in": "29.93",
|
||||||
|
"pressure_trend": "+",
|
||||||
|
"dewpoint_string": "54 F (12 C)",
|
||||||
|
"dewpoint_f": 54,
|
||||||
|
"dewpoint_c": 12,
|
||||||
|
"heat_index_string": "NA",
|
||||||
|
"heat_index_f": "NA",
|
||||||
|
"heat_index_c": "NA",
|
||||||
|
"windchill_string": "NA",
|
||||||
|
"windchill_f": "NA",
|
||||||
|
"windchill_c": "NA",
|
||||||
|
"feelslike_string": "66.3 F (19.1 C)",
|
||||||
|
"feelslike_f": "66.3",
|
||||||
|
"feelslike_c": "19.1",
|
||||||
|
"visibility_mi": "10.0",
|
||||||
|
"visibility_km": "16.1",
|
||||||
|
"solarradiation": "",
|
||||||
|
"UV": "5",
|
||||||
|
"precip_1hr_string": "0.00 in ( 0 mm)",
|
||||||
|
"precip_1hr_in": "0.00",
|
||||||
|
"precip_1hr_metric": " 0",
|
||||||
|
"precip_today_string": "0.00 in (0 mm)",
|
||||||
|
"precip_today_in": "0.00",
|
||||||
|
"precip_today_metric": "0",
|
||||||
|
"icon": "partlycloudy",
|
||||||
|
"icon_url": "http://icons-ak.wxug.com/i/c/k/partlycloudy.gif",
|
||||||
|
"forecast_url": "http://www.wunderground.com/US/CA/San_Francisco.html",
|
||||||
|
"history_url": "http://www.wunderground.com/history/airport/KCASANFR58/2012/6/27/DailyHistory.html",
|
||||||
|
"ob_url": "http://www.wunderground.com/cgi-bin/findweather/getForecast?query=37.773285,-122.417725"
|
||||||
|
}
|
||||||
|
}
|
2
extras/fuzzing/msgpack_corpus/.gitignore
vendored
Normal file
2
extras/fuzzing/msgpack_corpus/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
*
|
||||||
|
!.gitignore
|
11
extras/fuzzing/msgpack_fuzzer.cpp
Normal file
11
extras/fuzzing/msgpack_fuzzer.cpp
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||||
|
JsonDocument doc;
|
||||||
|
DeserializationError error = deserializeMsgPack(doc, data, size);
|
||||||
|
if (!error) {
|
||||||
|
std::string json;
|
||||||
|
serializeMsgPack(doc, json);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
BIN
extras/fuzzing/msgpack_seed_corpus/array16
Normal file
BIN
extras/fuzzing/msgpack_seed_corpus/array16
Normal file
Binary file not shown.
BIN
extras/fuzzing/msgpack_seed_corpus/array32
Normal file
BIN
extras/fuzzing/msgpack_seed_corpus/array32
Normal file
Binary file not shown.
1
extras/fuzzing/msgpack_seed_corpus/false
Normal file
1
extras/fuzzing/msgpack_seed_corpus/false
Normal file
@ -0,0 +1 @@
|
|||||||
|
<EFBFBD>
|
1
extras/fuzzing/msgpack_seed_corpus/fixarray
Normal file
1
extras/fuzzing/msgpack_seed_corpus/fixarray
Normal file
@ -0,0 +1 @@
|
|||||||
|
<EFBFBD><EFBFBD>hello<EFBFBD>world
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user