forked from bblanchon/ArduinoJson
Compare commits
535 Commits
v6.19.2
...
replace-ex
Author | SHA1 | Date | |
---|---|---|---|
53f858f55c | |||
6cdd59034d | |||
6ccac18fd4 | |||
3f6fff7d0c | |||
cc2fea45cd | |||
4159af66eb | |||
05942b620a | |||
23c73b061e | |||
c2e756d942 | |||
94aacf873e | |||
bd2dccda0e | |||
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 |
@ -1,10 +1,12 @@
|
|||||||
# http://clang.llvm.org/docs/ClangFormatStyleOptions.html
|
# http://clang.llvm.org/docs/ClangFormatStyleOptions.html
|
||||||
|
|
||||||
BasedOnStyle: Google
|
BasedOnStyle: Google
|
||||||
Standard: Cpp03
|
Standard: c++11
|
||||||
AllowShortFunctionsOnASingleLine: Empty
|
AllowShortFunctionsOnASingleLine: Empty
|
||||||
IncludeBlocks: Preserve
|
IncludeBlocks: Preserve
|
||||||
IndentPPDirectives: AfterHash
|
IndentPPDirectives: AfterHash
|
||||||
|
DerivePointerAlignment: false
|
||||||
|
|
||||||
# Always break after if to get accurate coverage
|
# Always break after if to get accurate coverage
|
||||||
AllowShortIfStatementsOnASingleLine: false
|
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"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -1 +1,2 @@
|
|||||||
|
* text=auto
|
||||||
*.sh text eol=lf
|
*.sh text eol=lf
|
4
.github/ISSUE_TEMPLATE/bug_report.md
vendored
4
.github/ISSUE_TEMPLATE/bug_report.md
vendored
@ -14,7 +14,7 @@ Before opening a bug report, please use the ArduinoJson Troubleshooter as it may
|
|||||||
A clear and concise description of what the bug is.
|
A clear and concise description of what the bug is.
|
||||||
|
|
||||||
**Troubleshooter report**
|
**Troubleshooter report**
|
||||||
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v6/troubleshooter/):
|
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v7/troubleshooter/):
|
||||||
[Paste the report here]
|
[Paste the report here]
|
||||||
|
|
||||||
**Environment**
|
**Environment**
|
||||||
@ -27,7 +27,7 @@ Here is the environment that I used:
|
|||||||
Here is a small snippet that reproduces the issue.
|
Here is a small snippet that reproduces the issue.
|
||||||
|
|
||||||
```c++
|
```c++
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
|
|
||||||
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
|
||||||
|
4
.github/ISSUE_TEMPLATE/config.yml
vendored
4
.github/ISSUE_TEMPLATE/config.yml
vendored
@ -1,8 +1,8 @@
|
|||||||
blank_issues_enabled: true
|
blank_issues_enabled: true
|
||||||
contact_links:
|
contact_links:
|
||||||
- name: 👨🏫 ArduinoJson Assistant
|
- name: 👨🏫 ArduinoJson Assistant
|
||||||
url: https://arduinojson.org/v6/assistant/
|
url: https://arduinojson.org/v7/assistant/
|
||||||
about: An online tool that computes memory requirements and generates scaffolding code for your project.
|
about: An online tool that computes memory requirements and generates scaffolding code for your project.
|
||||||
- name: 👨⚕️ ArduinoJson Troubleshooter
|
- name: 👨⚕️ ArduinoJson Troubleshooter
|
||||||
url: https://arduinojson.org/v6/troubleshooter/
|
url: https://arduinojson.org/v7/troubleshooter/
|
||||||
about: An online tool that helps you diagnose the most common issues with ArduinoJson.
|
about: An online tool that helps you diagnose the most common issues with ArduinoJson.
|
||||||
|
4
.github/ISSUE_TEMPLATE/help.md
vendored
4
.github/ISSUE_TEMPLATE/help.md
vendored
@ -15,7 +15,7 @@ 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.
|
You don't need to explain every aspect of your project: focus on the problem you're having.
|
||||||
|
|
||||||
**Troubleshooter report**
|
**Troubleshooter report**
|
||||||
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v6/troubleshooter/):
|
Here is the report generated by the [ArduinoJson Troubleshooter](https://arduinojson.org/v7/troubleshooter/):
|
||||||
[Paste the report here]
|
[Paste the report here]
|
||||||
|
|
||||||
**Environment**
|
**Environment**
|
||||||
@ -28,7 +28,7 @@ Here is the environment that I'm using':
|
|||||||
Here is a small snippet that demonstrate the problem.
|
Here is a small snippet that demonstrate the problem.
|
||||||
|
|
||||||
```c++
|
```c++
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
|
|
||||||
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
DeserializationError error = deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
|
||||||
|
292
.github/workflows/ci.yml
vendored
292
.github/workflows/ci.yml
vendored
@ -2,35 +2,42 @@ name: Continuous Integration
|
|||||||
|
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
lint:
|
||||||
name: Lint
|
name: Lint
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: sudo apt-get install -y clang-format
|
run: sudo apt-get install -y clang-format
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Symlinks
|
- name: Symlinks
|
||||||
run: find * -type l -printf "::error::%p is a symlink. This is forbidden by the Arduino Library Specification." -exec false {} +
|
run: find * -type l -printf "::error::%p is a symlink. This is forbidden by the Arduino Library Specification." -exec false {} +
|
||||||
- name: Clang-format
|
- name: Clang-format
|
||||||
run: |
|
run: |
|
||||||
find src/ extras/ -name '*.[ch]pp' | xargs clang-format -i --verbose --style=file
|
find src/ extras/ -name '*.[ch]pp' | xargs clang-format -i --verbose --style=file
|
||||||
git diff --exit-code
|
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:
|
gcc:
|
||||||
name: GCC
|
name: GCC
|
||||||
needs: lint
|
needs: lint
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- gcc: "4.4"
|
|
||||||
- gcc: "4.6"
|
|
||||||
- gcc: "4.7"
|
|
||||||
- gcc: "4.8"
|
- gcc: "4.8"
|
||||||
- gcc: "4.9"
|
|
||||||
- gcc: "5"
|
- gcc: "5"
|
||||||
- gcc: "6"
|
- gcc: "6"
|
||||||
- gcc: "7"
|
- gcc: "7"
|
||||||
@ -40,76 +47,99 @@ jobs:
|
|||||||
- gcc: "9"
|
- gcc: "9"
|
||||||
cxxflags: -fsanitize=address -fno-sanitize-recover=all
|
cxxflags: -fsanitize=address -fno-sanitize-recover=all
|
||||||
- gcc: "10"
|
- gcc: "10"
|
||||||
|
cxxflags: -funsigned-char # Issue #1715
|
||||||
- gcc: "11"
|
- gcc: "11"
|
||||||
|
- gcc: "12"
|
||||||
steps:
|
steps:
|
||||||
|
- name: Workaround for actions/runner-images#9491
|
||||||
|
run: sudo sysctl vm.mmap_rnd_bits=28
|
||||||
|
|
||||||
- name: Install
|
- name: Install
|
||||||
run: |
|
run: |
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ trusty main'
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 40976EAF437D05B5 3B4FE6ACC0B21F32
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ trusty universe'
|
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/ xenial main'
|
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/ xenial universe'
|
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ focal main universe'
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ bionic main'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ bionic universe'
|
|
||||||
sudo add-apt-repository -yn 'deb http://mirrors.kernel.org/ubuntu hirsute main universe'
|
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y gcc-${{ matrix.gcc }} g++-${{ matrix.gcc }}
|
sudo apt-get install -y gcc-${{ matrix.gcc }} g++-${{ matrix.gcc }}
|
||||||
|
timeout-minutes: 5
|
||||||
|
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
|
timeout-minutes: 1
|
||||||
|
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
env:
|
env:
|
||||||
CC: gcc-${{ matrix.gcc }}
|
CC: gcc-${{ matrix.gcc }}
|
||||||
CXX: g++-${{ matrix.gcc }}
|
CXX: g++-${{ matrix.gcc }}
|
||||||
CXXFLAGS: ${{ matrix.cxxflags }}
|
CXXFLAGS: ${{ matrix.cxxflags }}
|
||||||
|
timeout-minutes: 1
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: cmake --build .
|
run: cmake --build .
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
- name: Test
|
- name: Test
|
||||||
run: ctest --output-on-failure -C Debug .
|
run: ctest --output-on-failure -C Debug .
|
||||||
env:
|
env:
|
||||||
UBSAN_OPTIONS: print_stacktrace=1
|
UBSAN_OPTIONS: print_stacktrace=1
|
||||||
|
timeout-minutes: 2
|
||||||
|
|
||||||
clang:
|
clang:
|
||||||
name: Clang
|
name: Clang
|
||||||
needs: lint
|
needs: lint
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- clang: "3.5"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "3.6"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "3.7"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "3.8"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "3.9"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "4.0"
|
|
||||||
cxxflags: "-stdlib=libc++"
|
|
||||||
- clang: "5.0"
|
|
||||||
- clang: "6.0"
|
|
||||||
- clang: "7"
|
- clang: "7"
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
- clang: "8"
|
- clang: "8"
|
||||||
cxxflags: -fsanitize=leak -fno-sanitize-recover=all
|
cxxflags: -fsanitize=leak -fno-sanitize-recover=all
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
- clang: "9"
|
- clang: "9"
|
||||||
cxxflags: -fsanitize=undefined -fno-sanitize-recover=all
|
cxxflags: -fsanitize=undefined -fno-sanitize-recover=all
|
||||||
|
runner: ubuntu-22.04
|
||||||
|
archive: focal
|
||||||
- clang: "10"
|
- clang: "10"
|
||||||
cxxflags: -fsanitize=address -fno-sanitize-recover=all
|
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:
|
steps:
|
||||||
- name: Install
|
- 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: |
|
run: |
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ trusty main'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ trusty universe'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ xenial main'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ xenial universe'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ bionic main'
|
|
||||||
sudo add-apt-repository -yn 'deb http://archive.ubuntu.com/ubuntu/ bionic universe'
|
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y clang-${{ matrix.clang }}
|
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
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
env:
|
env:
|
||||||
@ -117,7 +147,7 @@ jobs:
|
|||||||
CXX: clang++-${{ matrix.clang }}
|
CXX: clang++-${{ matrix.clang }}
|
||||||
CXXFLAGS: >-
|
CXXFLAGS: >-
|
||||||
${{ matrix.cxxflags }}
|
${{ matrix.cxxflags }}
|
||||||
${{ contains(matrix.cxxflags, 'libc++') && '-I/usr/lib/llvm-10/include/c++/v1/' || '' }}
|
${{ matrix.clang < 11 && '-I/usr/lib/llvm-10/include/c++/v1/' || '' }}
|
||||||
- name: Build
|
- name: Build
|
||||||
run: cmake --build .
|
run: cmake --build .
|
||||||
- name: Test
|
- name: Test
|
||||||
@ -128,12 +158,16 @@ jobs:
|
|||||||
conf_test:
|
conf_test:
|
||||||
name: Test configuration on Linux
|
name: Test configuration on Linux
|
||||||
needs: [gcc, clang]
|
needs: [gcc, clang]
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: sudo apt-get install -y g++-multilib
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y g++-multilib gcc-avr avr-libc
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
|
- name: AVR
|
||||||
|
run: avr-g++ -std=c++11 -Isrc extras/conf_test/avr.cpp
|
||||||
- name: GCC 32-bit
|
- name: GCC 32-bit
|
||||||
run: g++ -std=c++11 -m32 -Isrc extras/conf_test/x86.cpp
|
run: g++ -std=c++11 -m32 -Isrc extras/conf_test/x86.cpp
|
||||||
- name: GCC 64-bit
|
- name: GCC 64-bit
|
||||||
@ -149,7 +183,7 @@ jobs:
|
|||||||
needs: [gcc, clang]
|
needs: [gcc, clang]
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: 32-bit
|
- name: 32-bit
|
||||||
run: |
|
run: |
|
||||||
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars32.bat"
|
call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\VC\Auxiliary\Build\vcvars32.bat"
|
||||||
@ -164,17 +198,20 @@ jobs:
|
|||||||
xcode:
|
xcode:
|
||||||
name: XCode
|
name: XCode
|
||||||
needs: clang
|
needs: clang
|
||||||
runs-on: macos-10.15
|
runs-on: macos-13
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- xcode: "10.3"
|
- xcode: "14.1"
|
||||||
- xcode: "11.7"
|
- xcode: "14.2"
|
||||||
- xcode: "12.4"
|
- xcode: "14.3.1"
|
||||||
|
- xcode: "15.0.1"
|
||||||
|
- xcode: "15.1"
|
||||||
|
- xcode: "15.2"
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Select XCode version
|
- name: Select XCode version
|
||||||
run: sudo xcode-select --switch /Applications/Xcode_${{ matrix.xcode }}.app
|
run: sudo xcode-select --switch /Applications/Xcode_${{ matrix.xcode }}.app
|
||||||
- name: Configure
|
- name: Configure
|
||||||
@ -196,7 +233,7 @@ jobs:
|
|||||||
# runs-on: ${{ matrix.os }}
|
# runs-on: ${{ matrix.os }}
|
||||||
# steps:
|
# steps:
|
||||||
# - name: Checkout
|
# - name: Checkout
|
||||||
# uses: actions/checkout@v2
|
# uses: actions/checkout@v4
|
||||||
# - name: Configure
|
# - name: Configure
|
||||||
# run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
# run: cmake -DCMAKE_BUILD_TYPE=Debug .
|
||||||
# - name: Build
|
# - name: Build
|
||||||
@ -215,12 +252,12 @@ jobs:
|
|||||||
board: arduino:avr:uno
|
board: arduino:avr:uno
|
||||||
- core: arduino:samd
|
- core: arduino:samd
|
||||||
board: arduino:samd:mkr1000
|
board: arduino:samd:mkr1000
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Install arduino-cli
|
- name: Install arduino-cli
|
||||||
run: brew update && brew install arduino-cli
|
run: curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | BINDIR=/usr/local/bin sh
|
||||||
- name: Install core
|
- name: Install core
|
||||||
run: arduino-cli core install ${{ matrix.core }}
|
run: arduino-cli core install ${{ matrix.core }}
|
||||||
- name: Install libraries
|
- name: Install libraries
|
||||||
@ -291,14 +328,14 @@ jobs:
|
|||||||
conf_test: esp8266
|
conf_test: esp8266
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Set up cache for pip
|
- name: Set up cache for pip
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: ~/.cache/pip
|
path: ~/.cache/pip
|
||||||
key: ${{ runner.os }}-pip
|
key: ${{ runner.os }}-pip
|
||||||
- name: Set up Python 3.x
|
- name: Set up Python 3.x
|
||||||
uses: actions/setup-python@v2
|
uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
python-version: "3.x"
|
python-version: "3.x"
|
||||||
- name: Install PlatformIO
|
- name: Install PlatformIO
|
||||||
@ -310,7 +347,7 @@ jobs:
|
|||||||
if: ${{ matrix.platform == 'nordicnrf52' }}
|
if: ${{ matrix.platform == 'nordicnrf52' }}
|
||||||
run: find examples/ -name '*.ino' -exec sed -i 's/\(#include <ArduinoJson.h>\)/\1\n#include <Adafruit_TinyUSB.h>/' {} +
|
run: find examples/ -name '*.ino' -exec sed -i 's/\(#include <ArduinoJson.h>\)/\1\n#include <Adafruit_TinyUSB.h>/' {} +
|
||||||
- name: Set up cache for platformio
|
- name: Set up cache for platformio
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: ~/.platformio
|
path: ~/.platformio
|
||||||
key: ${{ runner.os }}-platformio-${{ matrix.platform }}
|
key: ${{ runner.os }}-platformio-${{ matrix.platform }}
|
||||||
@ -359,7 +396,7 @@ jobs:
|
|||||||
- board: argon
|
- board: argon
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Install Particle CLI
|
- name: Install Particle CLI
|
||||||
run: sudo npm install -g particle-cli
|
run: sudo npm install -g particle-cli
|
||||||
- name: Login to Particle
|
- name: Login to Particle
|
||||||
@ -370,14 +407,14 @@ jobs:
|
|||||||
arm:
|
arm:
|
||||||
name: GCC for ARM processor
|
name: GCC for ARM processor
|
||||||
needs: gcc
|
needs: gcc
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y g++-arm-linux-gnueabihf
|
sudo apt-get install -y g++-arm-linux-gnueabihf
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake .
|
run: cmake .
|
||||||
env:
|
env:
|
||||||
@ -389,18 +426,18 @@ jobs:
|
|||||||
coverage:
|
coverage:
|
||||||
needs: gcc
|
needs: gcc
|
||||||
name: Coverage
|
name: Coverage
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: sudo apt-get install -y lcov ninja-build
|
run: sudo apt-get install -y lcov ninja-build
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake -G Ninja -DCOVERAGE=true .
|
run: cmake -G Ninja -DCOVERAGE=true .
|
||||||
- name: Build
|
- name: Build
|
||||||
run: ninja
|
run: ninja
|
||||||
- name: Test
|
- name: Test
|
||||||
run: ctest -LE 'WillFail|Fuzzing' -T test
|
run: ctest --output-on-failure -LE 'WillFail|Fuzzing' -T test
|
||||||
- name: lcov --capture
|
- name: lcov --capture
|
||||||
run: lcov --capture --no-external --directory . --output-file coverage.info
|
run: lcov --capture --no-external --directory . --output-file coverage.info
|
||||||
- name: lcov --remove
|
- name: lcov --remove
|
||||||
@ -408,12 +445,12 @@ jobs:
|
|||||||
- name: genhtml
|
- name: genhtml
|
||||||
run: mkdir coverage && genhtml coverage_filtered.info -o coverage -t ArduinoJson
|
run: mkdir coverage && genhtml coverage_filtered.info -o coverage -t ArduinoJson
|
||||||
- name: Upload HTML report
|
- name: Upload HTML report
|
||||||
uses: actions/upload-artifact@v2
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
name: Coverage report
|
name: Coverage report
|
||||||
path: coverage
|
path: coverage
|
||||||
- name: Upload to Coveralls
|
- name: Upload to Coveralls
|
||||||
uses: coverallsapp/github-action@master
|
uses: coverallsapp/github-action@v2
|
||||||
with:
|
with:
|
||||||
github-token: ${{ secrets.GITHUB_TOKEN }}
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
path-to-lcov: coverage_filtered.info
|
path-to-lcov: coverage_filtered.info
|
||||||
@ -421,107 +458,87 @@ jobs:
|
|||||||
valgrind:
|
valgrind:
|
||||||
needs: gcc
|
needs: gcc
|
||||||
name: Valgrind
|
name: Valgrind
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: sudo apt-get install -y valgrind ninja-build
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y valgrind ninja-build
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake -G Ninja -D MEMORYCHECK_COMMAND_OPTIONS="--error-exitcode=1 --leak-check=full" .
|
run: cmake -G Ninja -D MEMORYCHECK_COMMAND_OPTIONS="--error-exitcode=1 --leak-check=full" .
|
||||||
- name: Build
|
- name: Build
|
||||||
run: ninja
|
run: ninja
|
||||||
- name: Memcheck
|
- name: Memcheck
|
||||||
run: ctest -LE WillFail -T memcheck
|
run: ctest --output-on-failure -LE WillFail -T memcheck
|
||||||
id: memcheck
|
id: memcheck
|
||||||
- name: MemoryChecker.*.log
|
- name: MemoryChecker.*.log
|
||||||
run: cat Testing/Temporary/MemoryChecker.*.log
|
run: cat Testing/Temporary/MemoryChecker.*.log > $GITHUB_STEP_SUMMARY
|
||||||
if: failure()
|
if: failure()
|
||||||
|
|
||||||
clang-tidy:
|
clang-tidy:
|
||||||
needs: clang
|
needs: clang
|
||||||
name: Clang-Tidy
|
name: Clang-Tidy
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Install
|
- name: Install
|
||||||
run: sudo apt-get install -y clang-tidy cmake ninja-build
|
run: sudo apt-get install -y clang-tidy libc++-dev libc++abi-dev
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: cmake -G Ninja -DCMAKE_CXX_CLANG_TIDY="clang-tidy-10;--warnings-as-errors=*" -DCMAKE_BUILD_TYPE=Debug .
|
run: cmake -G Ninja -DCMAKE_CXX_CLANG_TIDY="clang-tidy;--warnings-as-errors=*" -DCMAKE_BUILD_TYPE=Debug .
|
||||||
env:
|
env:
|
||||||
CC: clang-10
|
CC: clang
|
||||||
CXX: clang++-10
|
CXX: clang++
|
||||||
- name: Check
|
- name: Check
|
||||||
run: cmake --build . -- -k 0
|
run: cmake --build . -- -k 0
|
||||||
|
|
||||||
amalgamate-h:
|
amalgamate:
|
||||||
needs: gcc
|
needs: gcc
|
||||||
name: Amalgamate ArduinoJson.h
|
name: Amalgamate ArduinoJson.h
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Amalgamate
|
- name: Setup
|
||||||
id: amalgamate
|
|
||||||
run: |
|
run: |
|
||||||
if [[ $GITHUB_REF == refs/tags/* ]]; then
|
if [[ $GITHUB_REF == refs/tags/* ]]; then
|
||||||
VERSION=${GITHUB_REF#refs/tags/}
|
VERSION=${GITHUB_REF#refs/tags/}
|
||||||
else
|
else
|
||||||
VERSION=${GITHUB_SHA::7}
|
VERSION=${GITHUB_SHA::7}
|
||||||
fi
|
fi
|
||||||
INPUT=src/ArduinoJson.h
|
echo "ARDUINOJSON_H=ArduinoJson-$VERSION.h" >> $GITHUB_ENV
|
||||||
OUTPUT=ArduinoJson-$VERSION.h
|
echo "ARDUINOJSON_HPP=ArduinoJson-$VERSION.hpp" >> $GITHUB_ENV
|
||||||
extras/scripts/build-single-header.sh "$INPUT" "$OUTPUT"
|
- name: Amalgamate ArduinoJson.h
|
||||||
echo ::set-output name=filename::${OUTPUT}
|
run: extras/scripts/build-single-header.sh "src/ArduinoJson.h" "$ARDUINOJSON_H"
|
||||||
- name: Smoke test
|
- 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: |
|
run: |
|
||||||
g++ -x c++ - <<END
|
g++ -x c++ - <<END
|
||||||
#include "${{ steps.amalgamate.outputs.filename }}"
|
#include "$ARDUINOJSON_H"
|
||||||
int main() {
|
int main() {
|
||||||
StaticJsonDocument<300> doc;
|
JsonDocument doc;
|
||||||
deserializeJson(doc, "{}");
|
deserializeJson(doc, "{}");
|
||||||
}
|
}
|
||||||
END
|
END
|
||||||
- name: Upload artifact
|
- name: Smoke test ArduinoJson.hpp
|
||||||
uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: Single headers
|
|
||||||
path: ${{ steps.amalgamate.outputs.filename }}
|
|
||||||
|
|
||||||
amalgamate-hpp:
|
|
||||||
needs: gcc
|
|
||||||
name: Amalgamate ArduinoJson.hpp
|
|
||||||
runs-on: ubuntu-20.04
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
- name: Amalgamate
|
|
||||||
id: amalgamate
|
|
||||||
run: |
|
|
||||||
if [[ $GITHUB_REF == refs/tags/* ]]; then
|
|
||||||
VERSION=${GITHUB_REF#refs/tags/}
|
|
||||||
else
|
|
||||||
VERSION=${GITHUB_SHA::7}
|
|
||||||
fi
|
|
||||||
INPUT=src/ArduinoJson.hpp
|
|
||||||
OUTPUT=ArduinoJson-$VERSION.hpp
|
|
||||||
extras/scripts/build-single-header.sh "$INPUT" "$OUTPUT"
|
|
||||||
echo ::set-output name=filename::${OUTPUT}
|
|
||||||
- name: Smoke test
|
|
||||||
run: |
|
run: |
|
||||||
g++ -x c++ - <<END
|
g++ -x c++ - <<END
|
||||||
#include "${{ steps.amalgamate.outputs.filename }}"
|
#include "$ARDUINOJSON_HPP"
|
||||||
int main() {
|
int main() {
|
||||||
ArduinoJson::StaticJsonDocument<300> doc;
|
ArduinoJson::JsonDocument doc;
|
||||||
deserializeJson(doc, "{}");
|
deserializeJson(doc, "{}");
|
||||||
}
|
}
|
||||||
END
|
END
|
||||||
- name: Upload artifact
|
|
||||||
uses: actions/upload-artifact@v2
|
|
||||||
with:
|
|
||||||
name: Single headers
|
|
||||||
path: ${{ steps.amalgamate.outputs.filename }}
|
|
||||||
|
|
||||||
esp-idf:
|
esp-idf:
|
||||||
needs: gcc
|
needs: gcc
|
||||||
@ -529,14 +546,14 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Setup cache
|
- name: Setup cache
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v4
|
||||||
with:
|
with:
|
||||||
path: ~/.espressif
|
path: ~/.espressif
|
||||||
key: ${{ runner.os }}-esp-idf
|
key: ${{ runner.os }}-esp-idf
|
||||||
- name: Checkout ArduinoJson
|
- name: Checkout ArduinoJson
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Checkout ESP-IDF
|
- name: Checkout ESP-IDF
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
repository: espressif/esp-idf
|
repository: espressif/esp-idf
|
||||||
path: esp-idf
|
path: esp-idf
|
||||||
@ -553,3 +570,32 @@ jobs:
|
|||||||
source esp-idf/export.sh
|
source esp-idf/export.sh
|
||||||
cd extras/ci/espidf
|
cd extras/ci/espidf
|
||||||
idf.py build
|
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"
|
||||||
|
6
.github/workflows/lock.yml
vendored
6
.github/workflows/lock.yml
vendored
@ -1,4 +1,4 @@
|
|||||||
name: 'Lock Threads'
|
name: Lock Threads
|
||||||
|
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
@ -8,7 +8,7 @@ jobs:
|
|||||||
lock:
|
lock:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: dessant/lock-threads@v2
|
- uses: dessant/lock-threads@v5
|
||||||
with:
|
with:
|
||||||
github-token: ${{ github.token }}
|
github-token: ${{ github.token }}
|
||||||
issue-lock-inactive-days: 30
|
issue-inactive-days: 30
|
||||||
|
74
.github/workflows/release.yml
vendored
74
.github/workflows/release.yml
vendored
@ -8,44 +8,86 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
release:
|
release:
|
||||||
name: Create release
|
name: Create release
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-22.04
|
||||||
steps:
|
steps:
|
||||||
- name: Set variables
|
- name: Set variables
|
||||||
id: init
|
id: init
|
||||||
run: |
|
run: |
|
||||||
echo ::set-output name=tag::${GITHUB_REF#refs/tags/}
|
echo "tag=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT
|
||||||
echo ::set-output name=version::${GITHUB_REF#refs/tags/v}
|
echo "version=${GITHUB_REF#refs/tags/v}" >> $GITHUB_OUTPUT
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v4
|
||||||
- name: Write release body
|
- name: Write release body
|
||||||
id: body
|
id: body
|
||||||
run: |
|
run: |
|
||||||
FILENAME=RELEASE.md
|
FILENAME=RELEASE.md
|
||||||
extras/scripts/get-release-body.sh ${{ steps.init.outputs.tag }} CHANGELOG.md | tee $FILENAME
|
tee $FILENAME <<END
|
||||||
echo ::set-output name=filename::$FILENAME
|
## 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
|
- name: Amalgamate ArduinoJson.h
|
||||||
id: amalgamate_h
|
id: amalgamate_h
|
||||||
run: |
|
run: |
|
||||||
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.h
|
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.h
|
||||||
extras/scripts/build-single-header.sh src/ArduinoJson.h "$FILENAME"
|
extras/scripts/build-single-header.sh src/ArduinoJson.h "$FILENAME"
|
||||||
echo ::set-output name=filename::$FILENAME
|
echo "filename=$FILENAME" >> $GITHUB_OUTPUT
|
||||||
- name: Amalgamate ArduinoJson.hpp
|
- name: Amalgamate ArduinoJson.hpp
|
||||||
id: amalgamate_hpp
|
id: amalgamate_hpp
|
||||||
run: |
|
run: |
|
||||||
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.hpp
|
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.hpp
|
||||||
extras/scripts/build-single-header.sh src/ArduinoJson.hpp "$FILENAME"
|
extras/scripts/build-single-header.sh src/ArduinoJson.hpp "$FILENAME"
|
||||||
echo ::set-output name=filename::$FILENAME
|
echo "filename=$FILENAME" >> $GITHUB_OUTPUT
|
||||||
- name: Create Arduino package
|
|
||||||
id: arduino
|
|
||||||
run: |
|
|
||||||
FILENAME=ArduinoJson-${{ steps.init.outputs.tag }}.zip
|
|
||||||
extras/scripts/build-arduino-package.sh . "$FILENAME"
|
|
||||||
echo ::set-output name=filename::$FILENAME
|
|
||||||
- name: Create release
|
- name: Create release
|
||||||
uses: ncipollo/release-action@v1
|
uses: ncipollo/release-action@v1
|
||||||
with:
|
with:
|
||||||
bodyFile: ${{ steps.body.outputs.filename }}
|
bodyFile: ${{ steps.body.outputs.filename }}
|
||||||
draft: true
|
|
||||||
name: ArduinoJson ${{ steps.init.outputs.version }}
|
name: ArduinoJson ${{ steps.init.outputs.version }}
|
||||||
artifacts: ${{ steps.amalgamate_h.outputs.filename }},${{ steps.amalgamate_hpp.outputs.filename }},${{ steps.arduino.outputs.filename }}
|
artifacts: ${{ steps.amalgamate_h.outputs.filename }},${{ steps.amalgamate_hpp.outputs.filename }}
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
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 }}
|
||||||
|
3
.gitignore
vendored
3
.gitignore
vendored
@ -15,3 +15,6 @@
|
|||||||
# Used by CI for Particle
|
# Used by CI for Particle
|
||||||
/src/*.ino
|
/src/*.ino
|
||||||
/project.properties
|
/project.properties
|
||||||
|
|
||||||
|
# Used by IDF
|
||||||
|
/dist/
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
.devcontainer/
|
||||||
.github/
|
.github/
|
||||||
examples/
|
examples/
|
||||||
extras/
|
extras/
|
19
.vscode/settings.json
vendored
19
.vscode/settings.json
vendored
@ -1,22 +1,17 @@
|
|||||||
{
|
{
|
||||||
"C_Cpp.default.configurationProvider": "ms-vscode.cmake-tools",
|
"C_Cpp.default.configurationProvider": "ms-vscode.cmake-tools",
|
||||||
"cmake.generator": "Ninja",
|
|
||||||
"git.inputValidationLength": 80,
|
"git.inputValidationLength": 80,
|
||||||
"git.inputValidationSubjectLength": 72,
|
"git.inputValidationSubjectLength": 72,
|
||||||
"files.insertFinalNewline": true,
|
"files.insertFinalNewline": true,
|
||||||
"files.trimFinalNewlines": true,
|
"files.trimFinalNewlines": true,
|
||||||
"files.associations": {
|
|
||||||
"fstream": "cpp",
|
|
||||||
"iomanip": "cpp",
|
|
||||||
"string": "cpp",
|
|
||||||
"system_error": "cpp",
|
|
||||||
"vector": "cpp",
|
|
||||||
"xlocmon": "cpp",
|
|
||||||
"xlocnum": "cpp",
|
|
||||||
"xloctime": "cpp",
|
|
||||||
"xstring": "cpp"
|
|
||||||
},
|
|
||||||
"search.exclude": {
|
"search.exclude": {
|
||||||
"/extras/tests/catch/*": true
|
"/extras/tests/catch/*": true
|
||||||
|
},
|
||||||
|
"C_Cpp.default.includePath": [
|
||||||
|
"/src"
|
||||||
|
],
|
||||||
|
"[cmake]": {
|
||||||
|
"editor.detectIndentation": false,
|
||||||
|
"editor.insertSpaces": false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
|
|
||||||
#include "src/ArduinoJson.h"
|
#include "src/ArduinoJson.h"
|
||||||
|
1032
CHANGELOG.md
1032
CHANGELOG.md
File diff suppressed because it is too large
Load Diff
@ -1,5 +1,5 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.15)
|
cmake_minimum_required(VERSION 3.15)
|
||||||
@ -10,7 +10,7 @@ if(ESP_PLATFORM)
|
|||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
project(ArduinoJson VERSION 6.19.2)
|
project(ArduinoJson VERSION 7.4.1)
|
||||||
|
|
||||||
if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME)
|
if(CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME)
|
||||||
include(CTest)
|
include(CTest)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
Copyright © 2014-2022, 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:
|
||||||
|
|
106
README.md
106
README.md
@ -1,50 +1,47 @@
|
|||||||

|
<p align="center">
|
||||||
|
<a href="https://arduinojson.org/"><img alt="ArduinoJson" src="https://arduinojson.org/images/logo.svg" width="200" /></a>
|
||||||
|
</p>
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
[](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22+branch%3A6.x)
|
[](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22+branch%3A7.x)
|
||||||
[](https://ci.appveyor.com/project/bblanchon/arduinojson/branch/6.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://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened&can=1&q=proj:arduinojson)
|
||||||
[](https://lgtm.com/projects/g/bblanchon/ArduinoJson/)
|
[](https://coveralls.io/github/bblanchon/ArduinoJson?branch=7.x)
|
||||||
[](https://coveralls.io/github/bblanchon/ArduinoJson?branch=6.x)
|
[](https://github.com/bblanchon/ArduinoJson/stargazers)
|
||||||
[](https://www.ardu-badge.com/ArduinoJson/6.19.2)
|
[](https://github.com/sponsors/bblanchon)
|
||||||
[](https://registry.platformio.org/packages/libraries/bblanchon/ArduinoJson?version=6.19.2)
|
|
||||||
[](https://github.com/bblanchon/ArduinoJson/stargazers)
|
|
||||||
[](https://github.com/sponsors/bblanchon)
|
|
||||||
|
|
||||||
ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).
|
ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
* [JSON deserialization](https://arduinojson.org/v6/api/json/deserializejson/?utm_source=github&utm_medium=readme)
|
* [JSON deserialization](https://arduinojson.org/v7/api/json/deserializejson/)
|
||||||
* [Optionally decodes UTF-16 escape sequences to UTF-8](https://arduinojson.org/v6/api/config/decode_unicode/?utm_source=github&utm_medium=readme)
|
* [Optionally decodes UTF-16 escape sequences to UTF-8](https://arduinojson.org/v7/api/config/decode_unicode/)
|
||||||
* [Optionally stores links to the input buffer (zero-copy)](https://arduinojson.org/v6/api/json/deserializejson/?utm_source=github&utm_medium=readme)
|
* [Optionally supports comments in the input](https://arduinojson.org/v7/api/config/enable_comments/)
|
||||||
* [Optionally supports comments in the input](https://arduinojson.org/v6/api/config/enable_comments/?utm_source=github&utm_medium=readme)
|
* [Optionally filters the input to keep only desired values](https://arduinojson.org/v7/api/json/deserializejson/#filtering)
|
||||||
* [Optionally filters the input to keep only desired values](https://arduinojson.org/v6/api/json/deserializejson/?utm_source=github&utm_medium=readme#filtering)
|
|
||||||
* Supports single quotes as a string delimiter
|
* Supports single quotes as a string delimiter
|
||||||
* Compatible with [NDJSON](http://ndjson.org/) and [JSON Lines](https://jsonlines.org/)
|
* Compatible with [NDJSON](http://ndjson.org/) and [JSON Lines](https://jsonlines.org/)
|
||||||
* [JSON serialization](https://arduinojson.org/v6/api/json/serializejson/?utm_source=github&utm_medium=readme)
|
* [JSON serialization](https://arduinojson.org/v7/api/json/serializejson/)
|
||||||
* [Can write to a buffer or a stream](https://arduinojson.org/v6/api/json/serializejson/?utm_source=github&utm_medium=readme)
|
* [Can write to a buffer or a stream](https://arduinojson.org/v7/api/json/serializejson/)
|
||||||
* [Optionally indents the document (prettified JSON)](https://arduinojson.org/v6/api/json/serializejsonpretty/?utm_source=github&utm_medium=readme)
|
* [Optionally indents the document (prettified JSON)](https://arduinojson.org/v7/api/json/serializejsonpretty/)
|
||||||
* [MessagePack serialization](https://arduinojson.org/v6/api/msgpack/serializemsgpack/?utm_source=github&utm_medium=readme)
|
* [MessagePack serialization](https://arduinojson.org/v7/api/msgpack/serializemsgpack/)
|
||||||
* [MessagePack deserialization](https://arduinojson.org/v6/api/msgpack/deserializemsgpack/?utm_source=github&utm_medium=readme)
|
* [MessagePack deserialization](https://arduinojson.org/v7/api/msgpack/deserializemsgpack/)
|
||||||
* Efficient
|
* Efficient
|
||||||
* [Twice smaller than the "official" Arduino_JSON library](https://arduinojson.org/2019/11/19/arduinojson-vs-arduino_json/?utm_source=github&utm_medium=readme)
|
* [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/?utm_source=github&utm_medium=readme)
|
* [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/?utm_source=github&utm_medium=readme)
|
* [Consumes roughly 10% less RAM than the "official" Arduino_JSON library](https://arduinojson.org/2019/11/19/arduinojson-vs-arduino_json/)
|
||||||
* [Fixed memory allocation, no heap fragmentation](https://arduinojson.org/v6/api/jsondocument/?utm_source=github&utm_medium=readme)
|
* [Deduplicates strings](https://arduinojson.org/news/2020/08/01/version-6-16-0/)
|
||||||
* [Optionally works without heap memory (zero malloc)](https://arduinojson.org/v6/api/staticjsondocument/?utm_source=github&utm_medium=readme)
|
|
||||||
* [Deduplicates strings](https://arduinojson.org/news/2020/08/01/version-6-16-0/?utm_source=github&utm_medium=readme)
|
|
||||||
* Versatile
|
* Versatile
|
||||||
* Supports [custom allocators (to use external RAM chip, for example)](https://arduinojson.org/v6/how-to/use-external-ram-on-esp32/?utm_source=github&utm_medium=readme)
|
* 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/v6/api/config/enable_arduino_string/?utm_source=github&utm_medium=readme), [`std::string`](https://arduinojson.org/v6/api/config/enable_std_string/?utm_source=github&utm_medium=readme), and [`std::string_view`](https://arduinojson.org/v6/api/config/enable_string_view/?utm_source=github&utm_medium=readme)
|
* 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/v6/api/config/enable_arduino_stream/?utm_source=github&utm_medium=readme) and [`std::istream`/`std::ostream`](https://arduinojson.org/v6/api/config/enable_std_stream/?utm_source=github&utm_medium=readme)
|
* 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/v6/api/config/enable_progmem/?utm_source=github&utm_medium=readme)
|
* Supports [Flash strings](https://arduinojson.org/v7/api/config/enable_progmem/)
|
||||||
* Supports [custom readers](https://arduinojson.org/v6/api/json/deserializejson/?utm_source=github&utm_medium=readme#custom-reader) and [custom writers](https://arduinojson.org/v6/api/json/serializejson/?utm_source=github&utm_medium=readme#custom-writer)
|
* 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/?utm_source=github&utm_medium=readme)
|
* Supports [custom converters](https://arduinojson.org/news/2021/05/04/version-6-18-0/)
|
||||||
* Portable
|
* Portable
|
||||||
* Usable on any C++ project (not limited to Arduino)
|
* Usable on any C++ project (not limited to Arduino)
|
||||||
* Compatible with C++98, C++11, C++14 and C++17
|
* 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`
|
* Zero warnings with `-Wall -Wextra -pedantic` and `/W4`
|
||||||
* [Header-only library](https://en.wikipedia.org/wiki/Header-only)
|
* [Header-only library](https://en.wikipedia.org/wiki/Header-only)
|
||||||
* Works with virtually any board
|
* Works with virtually any board
|
||||||
@ -69,36 +66,35 @@ ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).
|
|||||||
* [Visual Micro](http://www.visualmicro.com/)
|
* [Visual Micro](http://www.visualmicro.com/)
|
||||||
* [Visual Studio](https://www.visualstudio.com/)
|
* [Visual Studio](https://www.visualstudio.com/)
|
||||||
* [Even works with online compilers like wandbox.org](https://wandbox.org/permlink/RlZSKy17DjJ6HcdN)
|
* [Even works with online compilers like wandbox.org](https://wandbox.org/permlink/RlZSKy17DjJ6HcdN)
|
||||||
* [CMake friendly](https://arduinojson.org/v6/how-to/use-arduinojson-with-cmake/?utm_source=github&utm_medium=readme)
|
* [CMake friendly](https://arduinojson.org/v7/how-to/use-arduinojson-with-cmake/)
|
||||||
* Well designed
|
* Well designed
|
||||||
* [Elegant API](http://arduinojson.org/v6/example/?utm_source=github&utm_medium=readme)
|
* [Elegant API](http://arduinojson.org/v7/example/)
|
||||||
* [Thread-safe](https://en.wikipedia.org/wiki/Thread_safety)
|
* [Thread-safe](https://en.wikipedia.org/wiki/Thread_safety)
|
||||||
* Self-contained (no external dependency)
|
* Self-contained (no external dependency)
|
||||||
* `const` friendly
|
* `const` friendly
|
||||||
* [`for` friendly](https://arduinojson.org/v6/api/jsonobject/begin_end/?utm_source=github&utm_medium=readme)
|
* [`for` friendly](https://arduinojson.org/v7/api/jsonobject/begin_end/)
|
||||||
* [TMP friendly](https://en.wikipedia.org/wiki/Template_metaprogramming)
|
* [TMP friendly](https://en.wikipedia.org/wiki/Template_metaprogramming)
|
||||||
* Handles [integer overflows](https://arduinojson.org/v6/api/jsonvariant/as/?utm_source=github&utm_medium=readme#integer-overflows)
|
* Handles [integer overflows](https://arduinojson.org/v7/api/jsonvariant/as/#integer-overflows)
|
||||||
* Well tested
|
* Well tested
|
||||||
* [Unit test coverage close to 100%](https://coveralls.io/github/bblanchon/ArduinoJson?branch=6.x)
|
* [Unit test coverage close to 100%](https://coveralls.io/github/bblanchon/ArduinoJson?branch=7.x)
|
||||||
* Continuously tested on
|
* Continuously tested on
|
||||||
* [Visual Studio 2010, 2012, 2013, 2015, 2017, 2019, 2022](https://ci.appveyor.com/project/bblanchon/arduinojson/branch/6.x)
|
* [Visual Studio 2017, 2019, 2022](https://ci.appveyor.com/project/bblanchon/arduinojson/branch/7.x)
|
||||||
* [GCC 4.4, 4.6, 4.7, 4.8, 4.9, 5, 6, 7, 8, 9, 10, 11](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22)
|
* [GCC 4.8, 5, 6, 7, 8, 9, 10, 11, 12](https://github.com/bblanchon/ArduinoJson/actions?query=workflow%3A%22Continuous+Integration%22)
|
||||||
* [Clang 3.5, 3.6, 3.7, 3.8, 3.9, 4.0, 5.0, 6.0, 7, 8, 9, 10](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)
|
* [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/)
|
* Passes all default checks of [clang-tidy](https://releases.llvm.org/10.0.0/tools/clang/tools/extra/docs/clang-tidy/)
|
||||||
* Well documented
|
* Well documented
|
||||||
* [Tutorials](https://arduinojson.org/v6/doc/deserialization/?utm_source=github&utm_medium=readme)
|
* [Tutorials](https://arduinojson.org/v7/doc/deserialization/)
|
||||||
* [Examples](https://arduinojson.org/v6/example/?utm_source=github&utm_medium=readme)
|
* [Examples](https://arduinojson.org/v7/example/)
|
||||||
* [How-tos](https://arduinojson.org/v6/example/?utm_source=github&utm_medium=readme)
|
* [How-tos](https://arduinojson.org/v7/example/)
|
||||||
* [FAQ](https://arduinojson.org/v6/faq/?utm_source=github&utm_medium=readme)
|
* [FAQ](https://arduinojson.org/v7/faq/)
|
||||||
* [Troubleshooter](https://arduinojson.org/v6/troubleshooter/?utm_source=github&utm_medium=readme)
|
* [Troubleshooter](https://arduinojson.org/v7/troubleshooter/)
|
||||||
* [Book](https://arduinojson.org/book/?utm_source=github&utm_medium=readme)
|
* [Book](https://arduinojson.org/book/)
|
||||||
* [Changelog](CHANGELOG.md)
|
* [Changelog](CHANGELOG.md)
|
||||||
* Vibrant user community
|
* Vibrant user community
|
||||||
* Most popular of all Arduino libraries on [GitHub](https://github.com/search?o=desc&q=arduino+library&s=stars&type=Repositories)
|
* 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)
|
* [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)
|
* [Responsive support](https://github.com/bblanchon/ArduinoJson/issues?q=is%3Aissue+is%3Aclosed)
|
||||||
* [Discord server](https://discord.gg/DzN6hHHD4h)
|
|
||||||
|
|
||||||
## Quickstart
|
## Quickstart
|
||||||
|
|
||||||
@ -107,9 +103,9 @@ ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).
|
|||||||
Here is a program that parses a JSON document with ArduinoJson.
|
Here is a program that parses a JSON document with ArduinoJson.
|
||||||
|
|
||||||
```c++
|
```c++
|
||||||
char json[] = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
const char* json = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
deserializeJson(doc, json);
|
deserializeJson(doc, json);
|
||||||
|
|
||||||
const char* sensor = doc["sensor"];
|
const char* sensor = doc["sensor"];
|
||||||
@ -118,14 +114,14 @@ double latitude = doc["data"][0];
|
|||||||
double longitude = doc["data"][1];
|
double longitude = doc["data"][1];
|
||||||
```
|
```
|
||||||
|
|
||||||
See the [tutorial on arduinojson.org](https://arduinojson.org/doc/decoding/?utm_source=github&utm_medium=readme)
|
See the [tutorial on arduinojson.org](https://arduinojson.org/v7/doc/deserialization/)
|
||||||
|
|
||||||
### Serialization
|
### Serialization
|
||||||
|
|
||||||
Here is a program that generates a JSON document with ArduinoJson:
|
Here is a program that generates a JSON document with ArduinoJson:
|
||||||
|
|
||||||
```c++
|
```c++
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
|
|
||||||
doc["sensor"] = "gps";
|
doc["sensor"] = "gps";
|
||||||
doc["time"] = 1351824120;
|
doc["time"] = 1351824120;
|
||||||
@ -137,16 +133,13 @@ serializeJson(doc, Serial);
|
|||||||
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
||||||
```
|
```
|
||||||
|
|
||||||
See the [tutorial on arduinojson.org](https://arduinojson.org/doc/encoding/?utm_source=github&utm_medium=readme)
|
See the [tutorial on arduinojson.org](https://arduinojson.org/v7/doc/serialization/)
|
||||||
|
|
||||||
## Sponsors
|
## Sponsors
|
||||||
|
|
||||||
ArduinoJson is thankful to its sponsors. Please give them a visit; they deserve it!
|
ArduinoJson is thankful to its sponsors. Please give them a visit; they deserve it!
|
||||||
|
|
||||||
<p>
|
<p>
|
||||||
<a href="https://techexplorations.com/" rel="sponsored">
|
|
||||||
<img alt="Tech Explorations" src="https://arduinojson.org/images/2021/10/techexplorations.png" width="200">
|
|
||||||
</a>
|
|
||||||
<a href="https://www.programmingelectronics.com/" rel="sponsored">
|
<a href="https://www.programmingelectronics.com/" rel="sponsored">
|
||||||
<img src="https://arduinojson.org/images/2021/10/programmingeleactronicsacademy.png" alt="Programming Electronics Academy" width="200">
|
<img src="https://arduinojson.org/images/2021/10/programmingeleactronicsacademy.png" alt="Programming Electronics Academy" width="200">
|
||||||
</a>
|
</a>
|
||||||
@ -155,6 +148,9 @@ ArduinoJson is thankful to its sponsors. Please give them a visit; they deserve
|
|||||||
<a href="https://github.com/1technophile" rel="sponsored">
|
<a href="https://github.com/1technophile" rel="sponsored">
|
||||||
<img alt="1technophile" src="https://avatars.githubusercontent.com/u/12672732?s=40&v=4">
|
<img alt="1technophile" src="https://avatars.githubusercontent.com/u/12672732?s=40&v=4">
|
||||||
</a>
|
</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>
|
</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 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.
|
||||||
|
11
appveyor.yml
11
appveyor.yml
@ -1,4 +1,4 @@
|
|||||||
version: 6.19.2.{build}
|
version: 7.4.1.{build}
|
||||||
environment:
|
environment:
|
||||||
matrix:
|
matrix:
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2022
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2022
|
||||||
@ -7,15 +7,6 @@ environment:
|
|||||||
CMAKE_GENERATOR: Visual Studio 16 2019
|
CMAKE_GENERATOR: Visual Studio 16 2019
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
|
||||||
CMAKE_GENERATOR: Visual Studio 15 2017
|
CMAKE_GENERATOR: Visual Studio 15 2017
|
||||||
- APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2015
|
|
||||||
CMAKE_GENERATOR: Visual Studio 14 2015
|
|
||||||
- CMAKE_GENERATOR: Visual Studio 12 2013
|
|
||||||
- CMAKE_GENERATOR: Visual Studio 11 2012
|
|
||||||
- CMAKE_GENERATOR: Visual Studio 10 2010
|
|
||||||
- CMAKE_GENERATOR: Ninja
|
|
||||||
MINGW: MinGW # MinGW 32-bit 5.3.0
|
|
||||||
- CMAKE_GENERATOR: Ninja
|
|
||||||
MINGW32: i686-5.3.0-posix-dwarf-rt_v4-rev0 # MinGW-w64 5.3.0
|
|
||||||
- CMAKE_GENERATOR: Ninja
|
- CMAKE_GENERATOR: Ninja
|
||||||
MINGW32: i686-6.3.0-posix-dwarf-rt_v5-rev1 # MinGW-w64 6.3.0 i686
|
MINGW32: i686-6.3.0-posix-dwarf-rt_v5-rev1 # MinGW-w64 6.3.0 i686
|
||||||
- CMAKE_GENERATOR: Ninja
|
- CMAKE_GENERATOR: Ninja
|
||||||
|
367
banner.svg
367
banner.svg
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 32 KiB |
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to store your project configuration in a file.
|
// This example shows how to store your project configuration in a file.
|
||||||
@ -17,35 +17,28 @@
|
|||||||
// * CLK <-> pin 13
|
// * CLK <-> pin 13
|
||||||
// * CS <-> pin 4
|
// * CS <-> pin 4
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/config/
|
// https://arduinojson.org/v7/example/config/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <SD.h>
|
#include <SD.h>
|
||||||
#include <SPI.h>
|
#include <SPI.h>
|
||||||
|
|
||||||
// Our configuration structure.
|
// Our configuration structure.
|
||||||
//
|
|
||||||
// Never use a JsonDocument to store the configuration!
|
|
||||||
// A JsonDocument is *not* a permanent storage; it's only a temporary storage
|
|
||||||
// used during the serialization phase. See:
|
|
||||||
// https://arduinojson.org/v6/faq/why-must-i-create-a-separate-config-object/
|
|
||||||
struct Config {
|
struct Config {
|
||||||
char hostname[64];
|
char hostname[64];
|
||||||
int port;
|
int port;
|
||||||
};
|
};
|
||||||
|
|
||||||
const char *filename = "/config.txt"; // <- SD library uses 8.3 filenames
|
const char* filename = "/config.txt"; // <- SD library uses 8.3 filenames
|
||||||
Config config; // <- global configuration object
|
Config config; // <- global configuration object
|
||||||
|
|
||||||
// Loads the configuration from a file
|
// Loads the configuration from a file
|
||||||
void loadConfiguration(const char *filename, Config &config) {
|
void loadConfiguration(const char* filename, Config& config) {
|
||||||
// Open file for reading
|
// Open file for reading
|
||||||
File file = SD.open(filename);
|
File file = SD.open(filename);
|
||||||
|
|
||||||
// Allocate a temporary JsonDocument
|
// Allocate a temporary JsonDocument
|
||||||
// Don't forget to change the capacity to match your requirements.
|
JsonDocument doc;
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<512> doc;
|
|
||||||
|
|
||||||
// Deserialize the JSON document
|
// Deserialize the JSON document
|
||||||
DeserializationError error = deserializeJson(doc, file);
|
DeserializationError error = deserializeJson(doc, file);
|
||||||
@ -63,7 +56,7 @@ void loadConfiguration(const char *filename, Config &config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Saves the configuration to a file
|
// Saves the configuration to a file
|
||||||
void saveConfiguration(const char *filename, const Config &config) {
|
void saveConfiguration(const char* filename, const Config& config) {
|
||||||
// Delete existing file, otherwise the configuration is appended to the file
|
// Delete existing file, otherwise the configuration is appended to the file
|
||||||
SD.remove(filename);
|
SD.remove(filename);
|
||||||
|
|
||||||
@ -75,9 +68,7 @@ void saveConfiguration(const char *filename, const Config &config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Allocate a temporary JsonDocument
|
// Allocate a temporary JsonDocument
|
||||||
// Don't forget to change the capacity to match your requirements.
|
JsonDocument doc;
|
||||||
// Use https://arduinojson.org/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<256> doc;
|
|
||||||
|
|
||||||
// Set the values in the document
|
// Set the values in the document
|
||||||
doc["hostname"] = config.hostname;
|
doc["hostname"] = config.hostname;
|
||||||
@ -93,7 +84,7 @@ void saveConfiguration(const char *filename, const Config &config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Prints the content of a file to the Serial
|
// Prints the content of a file to the Serial
|
||||||
void printFile(const char *filename) {
|
void printFile(const char* filename) {
|
||||||
// Open file for reading
|
// Open file for reading
|
||||||
File file = SD.open(filename);
|
File file = SD.open(filename);
|
||||||
if (!file) {
|
if (!file) {
|
||||||
@ -114,7 +105,8 @@ void printFile(const char *filename) {
|
|||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Initialize SD library
|
// Initialize SD library
|
||||||
const int chipSelect = 4;
|
const int chipSelect = 4;
|
||||||
@ -144,7 +136,7 @@ void loop() {
|
|||||||
// ------------------
|
// ------------------
|
||||||
//
|
//
|
||||||
// File is an unbuffered stream, which is not optimal for ArduinoJson.
|
// File is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
// See: https://arduinojson.org/v6/how-to/improve-speed/
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
// See also
|
// See also
|
||||||
// --------
|
// --------
|
||||||
|
@ -1,20 +1,21 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to use DeserializationOpion::Filter
|
// This example shows how to use DeserializationOption::Filter
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/filter/
|
// https://arduinojson.org/v7/example/filter/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// The huge input: an extract from OpenWeatherMap response
|
// The huge input: an extract from OpenWeatherMap response
|
||||||
const __FlashStringHelper* input_json = F(
|
auto input_json = F(
|
||||||
"{\"cod\":\"200\",\"message\":0,\"list\":[{\"dt\":1581498000,\"main\":{"
|
"{\"cod\":\"200\",\"message\":0,\"list\":[{\"dt\":1581498000,\"main\":{"
|
||||||
"\"temp\":3.23,\"feels_like\":-3.63,\"temp_min\":3.23,\"temp_max\":4.62,"
|
"\"temp\":3.23,\"feels_like\":-3.63,\"temp_min\":3.23,\"temp_max\":4.62,"
|
||||||
"\"pressure\":1014,\"sea_level\":1014,\"grnd_level\":1010,\"humidity\":"
|
"\"pressure\":1014,\"sea_level\":1014,\"grnd_level\":1010,\"humidity\":"
|
||||||
@ -33,12 +34,12 @@ void setup() {
|
|||||||
"1000000,\"timezone\":0,\"sunrise\":1581492085,\"sunset\":1581527294}}");
|
"1000000,\"timezone\":0,\"sunrise\":1581492085,\"sunset\":1581527294}}");
|
||||||
|
|
||||||
// The filter: it contains "true" for each value we want to keep
|
// The filter: it contains "true" for each value we want to keep
|
||||||
StaticJsonDocument<200> filter;
|
JsonDocument filter;
|
||||||
filter["list"][0]["dt"] = true;
|
filter["list"][0]["dt"] = true;
|
||||||
filter["list"][0]["main"]["temp"] = true;
|
filter["list"][0]["main"]["temp"] = true;
|
||||||
|
|
||||||
// Deserialize the document
|
// Deserialize the document
|
||||||
StaticJsonDocument<400> doc;
|
JsonDocument doc;
|
||||||
deserializeJson(doc, input_json, DeserializationOption::Filter(filter));
|
deserializeJson(doc, input_json, DeserializationOption::Filter(filter));
|
||||||
|
|
||||||
// Print the result
|
// Print the result
|
||||||
|
@ -1,43 +1,32 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to generate a JSON document with ArduinoJson.
|
// This example shows how to generate a JSON document with ArduinoJson.
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/generator/
|
// https://arduinojson.org/v7/example/generator/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
// Initialize Serial port
|
// Initialize Serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 200 is the RAM allocated to this document.
|
|
||||||
// Don't forget to change this value to match your requirement.
|
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<200> doc;
|
|
||||||
|
|
||||||
// StaticJsonObject allocates memory on the stack, it can be
|
|
||||||
// replaced by DynamicJsonDocument which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonDocument doc(200);
|
|
||||||
|
|
||||||
// Add values in the document
|
// Add values in the document
|
||||||
//
|
|
||||||
doc["sensor"] = "gps";
|
doc["sensor"] = "gps";
|
||||||
doc["time"] = 1351824120;
|
doc["time"] = 1351824120;
|
||||||
|
|
||||||
// Add an array.
|
// Add an array
|
||||||
//
|
JsonArray data = doc["data"].to<JsonArray>();
|
||||||
JsonArray data = doc.createNestedArray("data");
|
|
||||||
data.add(48.756080);
|
data.add(48.756080);
|
||||||
data.add(2.302038);
|
data.add(2.302038);
|
||||||
|
|
||||||
// Generate the minified JSON and send it to the Serial port.
|
// Generate the minified JSON and send it to the Serial port
|
||||||
//
|
|
||||||
serializeJson(doc, Serial);
|
serializeJson(doc, Serial);
|
||||||
// The above line prints:
|
// The above line prints:
|
||||||
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
||||||
@ -45,8 +34,7 @@ void setup() {
|
|||||||
// Start a new line
|
// Start a new line
|
||||||
Serial.println();
|
Serial.println();
|
||||||
|
|
||||||
// Generate the prettified JSON and send it to the Serial port.
|
// Generate the prettified JSON and send it to the Serial port
|
||||||
//
|
|
||||||
serializeJsonPretty(doc, Serial);
|
serializeJsonPretty(doc, Serial);
|
||||||
// The above line prints:
|
// The above line prints:
|
||||||
// {
|
// {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to parse a JSON document in an HTTP response.
|
// This example shows how to parse a JSON document in an HTTP response.
|
||||||
@ -16,7 +16,7 @@
|
|||||||
// ]
|
// ]
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/http-client/
|
// https://arduinojson.org/v7/example/http-client/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
@ -25,7 +25,8 @@
|
|||||||
void setup() {
|
void setup() {
|
||||||
// Initialize Serial port
|
// Initialize Serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Initialize Ethernet library
|
// Initialize Ethernet library
|
||||||
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
byte mac[] = {0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED};
|
||||||
@ -77,9 +78,7 @@ void setup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
JsonDocument doc;
|
||||||
const size_t capacity = JSON_OBJECT_SIZE(3) + JSON_ARRAY_SIZE(2) + 60;
|
|
||||||
DynamicJsonDocument doc(capacity);
|
|
||||||
|
|
||||||
// Parse JSON object
|
// Parse JSON object
|
||||||
DeserializationError error = deserializeJson(doc, client);
|
DeserializationError error = deserializeJson(doc, client);
|
||||||
@ -109,7 +108,7 @@ void loop() {
|
|||||||
// ------------------
|
// ------------------
|
||||||
//
|
//
|
||||||
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
// See: https://arduinojson.org/v6/how-to/improve-speed/
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
// See also
|
// See also
|
||||||
// --------
|
// --------
|
||||||
|
@ -1,52 +1,37 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to deserialize a JSON document with ArduinoJson.
|
// This example shows how to deserialize a JSON document with ArduinoJson.
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/parser/
|
// https://arduinojson.org/v7/example/parser/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 200 is the capacity of the memory pool in bytes.
|
|
||||||
// Don't forget to change this value to match your JSON document.
|
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<200> doc;
|
|
||||||
|
|
||||||
// StaticJsonDocument<N> allocates memory on the stack, it can be
|
|
||||||
// replaced by DynamicJsonDocument which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonDocument doc(200);
|
|
||||||
|
|
||||||
// JSON input string.
|
// JSON input string.
|
||||||
//
|
const char* json =
|
||||||
// Using a char[], as shown here, enables the "zero-copy" mode. This mode uses
|
|
||||||
// the minimal amount of memory because the JsonDocument stores pointers to
|
|
||||||
// the input buffer.
|
|
||||||
// If you use another type of input, ArduinoJson must copy the strings from
|
|
||||||
// the input to the JsonDocument, so you need to increase the capacity of the
|
|
||||||
// JsonDocument.
|
|
||||||
char json[] =
|
|
||||||
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
|
||||||
// Deserialize the JSON document
|
// Deserialize the JSON document
|
||||||
DeserializationError error = deserializeJson(doc, json);
|
DeserializationError error = deserializeJson(doc, json);
|
||||||
|
|
||||||
// Test if parsing succeeds.
|
// Test if parsing succeeds
|
||||||
if (error) {
|
if (error) {
|
||||||
Serial.print(F("deserializeJson() failed: "));
|
Serial.print(F("deserializeJson() failed: "));
|
||||||
Serial.println(error.f_str());
|
Serial.println(error.f_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch values.
|
// Fetch the values
|
||||||
//
|
//
|
||||||
// Most of the time, you can rely on the implicit casts.
|
// Most of the time, you can rely on the implicit casts.
|
||||||
// In other case, you can do doc["time"].as<long>();
|
// In other case, you can do doc["time"].as<long>();
|
||||||
@ -55,7 +40,7 @@ void setup() {
|
|||||||
double latitude = doc["data"][0];
|
double latitude = doc["data"][0];
|
||||||
double longitude = doc["data"][1];
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
// Print values.
|
// Print the values
|
||||||
Serial.println(sensor);
|
Serial.println(sensor);
|
||||||
Serial.println(time);
|
Serial.println(time);
|
||||||
Serial.println(latitude, 6);
|
Serial.println(latitude, 6);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to implement an HTTP server that sends a JSON document
|
// This example shows how to implement an HTTP server that sends a JSON document
|
||||||
@ -13,7 +13,7 @@
|
|||||||
// "digital": [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0]
|
// "digital": [1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0]
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/http-server/
|
// https://arduinojson.org/v7/example/http-server/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
@ -25,7 +25,8 @@ EthernetServer server(80);
|
|||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Initialize Ethernet libary
|
// Initialize Ethernet libary
|
||||||
if (!Ethernet.begin(mac)) {
|
if (!Ethernet.begin(mac)) {
|
||||||
@ -52,14 +53,14 @@ void loop() {
|
|||||||
Serial.println(F("New client"));
|
Serial.println(F("New client"));
|
||||||
|
|
||||||
// Read the request (we ignore the content in this example)
|
// Read the request (we ignore the content in this example)
|
||||||
while (client.available()) client.read();
|
while (client.available())
|
||||||
|
client.read();
|
||||||
|
|
||||||
// Allocate a temporary JsonDocument
|
// Allocate a temporary JsonDocument
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
JsonDocument doc;
|
||||||
StaticJsonDocument<500> doc;
|
|
||||||
|
|
||||||
// Create the "analog" array
|
// Create the "analog" array
|
||||||
JsonArray analogValues = doc.createNestedArray("analog");
|
JsonArray analogValues = doc["analog"].to<JsonArray>();
|
||||||
for (int pin = 0; pin < 6; pin++) {
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
// Read the analog input
|
// Read the analog input
|
||||||
int value = analogRead(pin);
|
int value = analogRead(pin);
|
||||||
@ -69,7 +70,7 @@ void loop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create the "digital" array
|
// Create the "digital" array
|
||||||
JsonArray digitalValues = doc.createNestedArray("digital");
|
JsonArray digitalValues = doc["digital"].to<JsonArray>();
|
||||||
for (int pin = 0; pin < 14; pin++) {
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
// Read the digital input
|
// Read the digital input
|
||||||
int value = digitalRead(pin);
|
int value = digitalRead(pin);
|
||||||
@ -101,7 +102,7 @@ void loop() {
|
|||||||
// ------------------
|
// ------------------
|
||||||
//
|
//
|
||||||
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
// EthernetClient is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
// See: https://arduinojson.org/v6/how-to/improve-speed/
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
// See also
|
// See also
|
||||||
// --------
|
// --------
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to send a JSON document to a UDP socket.
|
// This example shows how to send a JSON document to a UDP socket.
|
||||||
@ -17,7 +17,7 @@
|
|||||||
// $ ncat -ulp 8888
|
// $ ncat -ulp 8888
|
||||||
// See https://nmap.org/ncat/
|
// See https://nmap.org/ncat/
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/udp-beacon/
|
// https://arduinojson.org/v7/example/udp-beacon/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <Ethernet.h>
|
#include <Ethernet.h>
|
||||||
@ -32,7 +32,8 @@ EthernetUDP udp;
|
|||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Initialize Ethernet libary
|
// Initialize Ethernet libary
|
||||||
if (!Ethernet.begin(mac)) {
|
if (!Ethernet.begin(mac)) {
|
||||||
@ -46,11 +47,10 @@ void setup() {
|
|||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
// Allocate a temporary JsonDocument
|
// Allocate a temporary JsonDocument
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
JsonDocument doc;
|
||||||
StaticJsonDocument<500> doc;
|
|
||||||
|
|
||||||
// Create the "analog" array
|
// Create the "analog" array
|
||||||
JsonArray analogValues = doc.createNestedArray("analog");
|
JsonArray analogValues = doc["analog"].to<JsonArray>();
|
||||||
for (int pin = 0; pin < 6; pin++) {
|
for (int pin = 0; pin < 6; pin++) {
|
||||||
// Read the analog input
|
// Read the analog input
|
||||||
int value = analogRead(pin);
|
int value = analogRead(pin);
|
||||||
@ -60,7 +60,7 @@ void loop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create the "digital" array
|
// Create the "digital" array
|
||||||
JsonArray digitalValues = doc.createNestedArray("digital");
|
JsonArray digitalValues = doc["digital"].to<JsonArray>();
|
||||||
for (int pin = 0; pin < 14; pin++) {
|
for (int pin = 0; pin < 14; pin++) {
|
||||||
// Read the digital input
|
// Read the digital input
|
||||||
int value = digitalRead(pin);
|
int value = digitalRead(pin);
|
||||||
@ -90,7 +90,7 @@ void loop() {
|
|||||||
// ------------------
|
// ------------------
|
||||||
//
|
//
|
||||||
// EthernetUDP is an unbuffered stream, which is not optimal for ArduinoJson.
|
// EthernetUDP is an unbuffered stream, which is not optimal for ArduinoJson.
|
||||||
// See: https://arduinojson.org/v6/how-to/improve-speed/
|
// See: https://arduinojson.org/v7/how-to/improve-speed/
|
||||||
|
|
||||||
// See also
|
// See also
|
||||||
// --------
|
// --------
|
||||||
|
@ -1,39 +1,24 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to deserialize a MessagePack document with
|
// This example shows how to deserialize a MessagePack document with
|
||||||
// ArduinoJson.
|
// ArduinoJson.
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/msgpack-parser/
|
// https://arduinojson.org/v7/example/msgpack-parser/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
// Initialize serial port
|
// Initialize serial port
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
while (!Serial) continue;
|
while (!Serial)
|
||||||
|
continue;
|
||||||
|
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 200 is the capacity of the memory pool in bytes.
|
|
||||||
// Don't forget to change this value to match your JSON document.
|
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<200> doc;
|
|
||||||
|
|
||||||
// StaticJsonObject allocates memory on the stack, it can be
|
// The MessagePack input string
|
||||||
// replaced by DynamicJsonObject which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonObject doc(200);
|
|
||||||
|
|
||||||
// MessagePack input string.
|
|
||||||
//
|
|
||||||
// Using a char[], as shown here, enables the "zero-copy" mode. This mode uses
|
|
||||||
// the minimal amount of memory because the JsonDocument stores pointers to
|
|
||||||
// the input buffer.
|
|
||||||
// If you use another type of input, ArduinoJson must copy the strings from
|
|
||||||
// the input to the JsonDocument, so you need to increase the capacity of the
|
|
||||||
// JsonDocument.
|
|
||||||
uint8_t input[] = {131, 166, 115, 101, 110, 115, 111, 114, 163, 103, 112, 115,
|
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,
|
164, 116, 105, 109, 101, 206, 80, 147, 50, 248, 164, 100,
|
||||||
97, 116, 97, 146, 203, 64, 72, 96, 199, 58, 188, 148,
|
97, 116, 97, 146, 203, 64, 72, 96, 199, 58, 188, 148,
|
||||||
@ -45,16 +30,17 @@ void setup() {
|
|||||||
// "data": [48.75608, 2.302038]
|
// "data": [48.75608, 2.302038]
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
// Parse the input
|
||||||
DeserializationError error = deserializeMsgPack(doc, input);
|
DeserializationError error = deserializeMsgPack(doc, input);
|
||||||
|
|
||||||
// Test if parsing succeeded.
|
// Test if parsing succeeded
|
||||||
if (error) {
|
if (error) {
|
||||||
Serial.print("deserializeMsgPack() failed: ");
|
Serial.print("deserializeMsgPack() failed: ");
|
||||||
Serial.println(error.f_str());
|
Serial.println(error.f_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch values.
|
// Fetch the values
|
||||||
//
|
//
|
||||||
// Most of the time, you can rely on the implicit casts.
|
// Most of the time, you can rely on the implicit casts.
|
||||||
// In other case, you can do doc["time"].as<long>();
|
// In other case, you can do doc["time"].as<long>();
|
||||||
@ -63,7 +49,7 @@ void setup() {
|
|||||||
double latitude = doc["data"][0];
|
double latitude = doc["data"][0];
|
||||||
double longitude = doc["data"][1];
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
// Print values.
|
// Print the values
|
||||||
Serial.println(sensor);
|
Serial.println(sensor);
|
||||||
Serial.println(time);
|
Serial.println(time);
|
||||||
Serial.println(latitude, 6);
|
Serial.println(latitude, 6);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows the different ways you can use Flash strings with
|
// This example shows the different ways you can use Flash strings with
|
||||||
@ -9,39 +9,38 @@
|
|||||||
// JsonDocument. Prefer plain old char*, as they are more efficient in term of
|
// JsonDocument. Prefer plain old char*, as they are more efficient in term of
|
||||||
// code size, speed, and memory usage.
|
// code size, speed, and memory usage.
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/progmem/
|
// https://arduinojson.org/v7/example/progmem/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
|
|
||||||
// You can use a Flash String as your JSON input.
|
// You can use a Flash String as your JSON input.
|
||||||
// WARNING: the strings in the input will be duplicated in the JsonDocument.
|
// WARNING: the strings in the input will be duplicated in the JsonDocument.
|
||||||
deserializeJson(doc, F("{\"sensor\":\"gps\",\"time\":1351824120,"
|
deserializeJson(doc, F("{\"sensor\":\"gps\",\"time\":1351824120,"
|
||||||
"\"data\":[48.756080,2.302038]}"));
|
"\"data\":[48.756080,2.302038]}"));
|
||||||
JsonObject obj = doc.as<JsonObject>();
|
|
||||||
|
|
||||||
// You can use a Flash String to get an element of a JsonObject
|
// You can use a Flash String as a key to get a member from JsonDocument
|
||||||
// No duplication is done.
|
// No duplication is done.
|
||||||
long time = obj[F("time")];
|
long time = doc[F("time")];
|
||||||
|
|
||||||
// You can use a Flash String to set an element of a JsonObject
|
// 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
|
// WARNING: the content of the Flash String will be duplicated in the
|
||||||
// JsonDocument.
|
// JsonDocument.
|
||||||
obj[F("time")] = time;
|
doc[F("time")] = time;
|
||||||
|
|
||||||
// You can set a Flash String to a JsonObject or JsonArray:
|
// You can set a Flash String as the content of a JsonVariant
|
||||||
// WARNING: the content of the Flash String will be duplicated in the
|
// WARNING: the content of the Flash String will be duplicated in the
|
||||||
// JsonDocument.
|
// JsonDocument.
|
||||||
obj["sensor"] = F("gps");
|
doc["sensor"] = F("gps");
|
||||||
|
|
||||||
// It works with serialized() too:
|
// It works with serialized() too:
|
||||||
obj["sensor"] = serialized(F("\"gps\""));
|
doc["sensor"] = serialized(F("\"gps\""));
|
||||||
obj["sensor"] = serialized(F("\xA3gps"), 3);
|
doc["sensor"] = serialized(F("\xA3gps"), 3);
|
||||||
|
|
||||||
// You can compare the content of a JsonVariant to a Flash String
|
// You can compare the content of a JsonVariant to a Flash String
|
||||||
if (obj["sensor"] == F("gps")) {
|
if (doc["sensor"] == F("gps")) {
|
||||||
// ...
|
// ...
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows the different ways you can use String with ArduinoJson.
|
// This example shows the different ways you can use String with ArduinoJson.
|
||||||
@ -8,50 +8,49 @@
|
|||||||
// JsonDocument. Prefer plain old char[], as they are more efficient in term of
|
// JsonDocument. Prefer plain old char[], as they are more efficient in term of
|
||||||
// code size, speed, and memory usage.
|
// code size, speed, and memory usage.
|
||||||
//
|
//
|
||||||
// https://arduinojson.org/v6/example/string/
|
// https://arduinojson.org/v7/example/string/
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
|
|
||||||
// You can use a String as your JSON input.
|
// You can use a String as your JSON input.
|
||||||
// WARNING: the string in the input will be duplicated in the JsonDocument.
|
// WARNING: the string in the input will be duplicated in the JsonDocument.
|
||||||
String input =
|
String input =
|
||||||
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
deserializeJson(doc, input);
|
deserializeJson(doc, input);
|
||||||
JsonObject obj = doc.as<JsonObject>();
|
|
||||||
|
|
||||||
// You can use a String to get an element of a JsonObject
|
// You can use a String as a key to get a member from JsonDocument
|
||||||
// No duplication is done.
|
// No duplication is done.
|
||||||
long time = obj[String("time")];
|
long time = doc[String("time")];
|
||||||
|
|
||||||
// You can use a String to set an element of a JsonObject
|
// 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.
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
obj[String("time")] = time;
|
doc[String("time")] = time;
|
||||||
|
|
||||||
// You can get a String from a JsonObject or JsonArray:
|
// You can get the content of a JsonVariant as a String
|
||||||
// No duplication is done, at least not in the JsonDocument.
|
// No duplication is done, at least not in the JsonDocument.
|
||||||
String sensor = obj["sensor"];
|
String sensor = doc["sensor"];
|
||||||
|
|
||||||
// Unfortunately, the following doesn't work (issue #118):
|
// Unfortunately, the following doesn't work (issue #118):
|
||||||
// sensor = obj["sensor"]; // <- error "ambiguous overload for 'operator='"
|
// sensor = doc["sensor"]; // <- error "ambiguous overload for 'operator='"
|
||||||
// As a workaround, you need to replace by:
|
// As a workaround, you need to replace by:
|
||||||
sensor = obj["sensor"].as<String>();
|
sensor = doc["sensor"].as<String>();
|
||||||
|
|
||||||
// You can set a String to a JsonObject or JsonArray:
|
// You can set a String as the content of a JsonVariant
|
||||||
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
obj["sensor"] = sensor;
|
doc["sensor"] = sensor;
|
||||||
|
|
||||||
// It works with serialized() too:
|
// It works with serialized() too:
|
||||||
obj["sensor"] = serialized(sensor);
|
doc["sensor"] = serialized(sensor);
|
||||||
|
|
||||||
// You can also concatenate strings
|
// You can also concatenate strings
|
||||||
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
// WARNING: the content of the String will be duplicated in the JsonDocument.
|
||||||
obj[String("sen") + "sor"] = String("gp") + "s";
|
doc[String("sen") + "sor"] = String("gp") + "s";
|
||||||
|
|
||||||
// You can compare the content of a JsonObject with a String
|
// You can compare the content of a JsonObject with a String
|
||||||
if (obj["sensor"] == sensor) {
|
if (doc["sensor"] == sensor) {
|
||||||
// ...
|
// ...
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
if(NOT DEFINED COVERAGE)
|
||||||
|
set(COVERAGE OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
||||||
add_compile_options(
|
add_compile_options(
|
||||||
-pedantic
|
-pedantic
|
||||||
@ -18,6 +22,7 @@ if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
|||||||
-Wparentheses
|
-Wparentheses
|
||||||
-Wredundant-decls
|
-Wredundant-decls
|
||||||
-Wshadow
|
-Wshadow
|
||||||
|
-Wsign-conversion
|
||||||
-Wsign-promo
|
-Wsign-promo
|
||||||
-Wstrict-aliasing
|
-Wstrict-aliasing
|
||||||
-Wundef
|
-Wundef
|
||||||
@ -26,14 +31,23 @@ if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
|||||||
if(${COVERAGE})
|
if(${COVERAGE})
|
||||||
set(CMAKE_CXX_FLAGS "-fprofile-arcs -ftest-coverage")
|
set(CMAKE_CXX_FLAGS "-fprofile-arcs -ftest-coverage")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
||||||
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.8) AND (NOT ${COVERAGE}))
|
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.9) AND(NOT ${COVERAGE}))
|
||||||
add_compile_options(-g -Og)
|
add_compile_options(-g -Og)
|
||||||
else()
|
else() # GCC 4.8
|
||||||
add_compile_options(-g -O0)
|
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()
|
endif()
|
||||||
|
|
||||||
add_compile_options(
|
add_compile_options(
|
||||||
@ -64,7 +78,10 @@ if(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
||||||
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.0) AND (NOT ${COVERAGE}))
|
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)
|
add_compile_options(-g -Og)
|
||||||
else()
|
else()
|
||||||
add_compile_options(-g -O0)
|
add_compile_options(-g -O0)
|
||||||
@ -72,7 +89,7 @@ if(CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "AppleClang")
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "AppleClang")
|
||||||
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 9.0) AND (NOT ${COVERAGE}))
|
if((CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 9.0) AND(NOT ${COVERAGE}))
|
||||||
add_compile_options(-g -Og)
|
add_compile_options(-g -Og)
|
||||||
else()
|
else()
|
||||||
add_compile_options(-g -O0)
|
add_compile_options(-g -O0)
|
||||||
@ -84,11 +101,12 @@ if(MSVC)
|
|||||||
add_compile_options(
|
add_compile_options(
|
||||||
/W4 # Set warning level
|
/W4 # Set warning level
|
||||||
/WX # Treats all compiler warnings as errors.
|
/WX # Treats all compiler warnings as errors.
|
||||||
)
|
|
||||||
|
|
||||||
if (NOT MSVC_VERSION LESS 1910) # >= Visual Studio 2017
|
|
||||||
add_compile_options(
|
|
||||||
/Zc:__cplusplus # Enable updated __cplusplus macro
|
/Zc:__cplusplus # Enable updated __cplusplus macro
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(MINGW)
|
||||||
|
# Static link on MinGW to avoid linking with the wrong DLLs when multiple
|
||||||
|
# versions are installed.
|
||||||
|
add_link_options(-static)
|
||||||
endif()
|
endif()
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.5)
|
cmake_minimum_required(VERSION 3.5)
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
idf_component_register(SRCS "main.cpp"
|
idf_component_register(
|
||||||
INCLUDE_DIRS "")
|
SRCS "main.cpp"
|
||||||
|
INCLUDE_DIRS ""
|
||||||
|
)
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
extern "C" void app_main() {
|
extern "C" void app_main() {
|
||||||
char buffer[256];
|
char buffer[256];
|
||||||
StaticJsonDocument<200> doc;
|
JsonDocument doc;
|
||||||
|
|
||||||
doc["hello"] = "world";
|
doc["hello"] = "world";
|
||||||
serializeJson(doc, buffer);
|
serializeJson(doc, buffer);
|
||||||
|
@ -1,16 +1,18 @@
|
|||||||
#include <ArduinoJson.h>
|
#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_USE_LONG_LONG == 0, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_SLOT_OFFSET_SIZE == 1,
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 1, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
"ARDUINOJSON_SLOT_OFFSET_SIZE");
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 16, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
static_assert(ARDUINOJSON_USE_DOUBLE == 0, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
static_assert(sizeof(ARDUINOJSON_NAMESPACE::VariantSlot) == 8,
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 6, "slot size");
|
||||||
"sizeof(VariantSlot)");
|
|
||||||
|
|
||||||
void setup() {}
|
void setup() {}
|
||||||
void loop() {}
|
void loop() {}
|
||||||
|
@ -2,15 +2,15 @@
|
|||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_SLOT_OFFSET_SIZE == 2,
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 2, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
"ARDUINOJSON_SLOT_OFFSET_SIZE");
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 128, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
static_assert(sizeof(ARDUINOJSON_NAMESPACE::VariantSlot) == 16,
|
static_assert(sizeof(VariantData) == 8, "slot size");
|
||||||
"sizeof(VariantSlot)");
|
|
||||||
|
|
||||||
void setup() {}
|
void setup() {}
|
||||||
void loop() {}
|
void loop() {}
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_SLOT_OFFSET_SIZE == 4,
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 4, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
"ARDUINOJSON_SLOT_OFFSET_SIZE");
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 256, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
static_assert(sizeof(ARDUINOJSON_NAMESPACE::VariantSlot) == 32,
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 16, "slot size");
|
||||||
"sizeof(VariantSlot)");
|
|
||||||
|
|
||||||
int main() {}
|
int main() {}
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
static_assert(ARDUINOJSON_USE_LONG_LONG == 1, "ARDUINOJSON_USE_LONG_LONG");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_SLOT_OFFSET_SIZE == 2,
|
static_assert(ARDUINOJSON_SLOT_ID_SIZE == 2, "ARDUINOJSON_SLOT_ID_SIZE");
|
||||||
"ARDUINOJSON_SLOT_OFFSET_SIZE");
|
|
||||||
|
static_assert(ARDUINOJSON_POOL_CAPACITY == 128, "ARDUINOJSON_POOL_CAPACITY");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
static_assert(ARDUINOJSON_LITTLE_ENDIAN == 1, "ARDUINOJSON_LITTLE_ENDIAN");
|
||||||
|
|
||||||
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
static_assert(ARDUINOJSON_USE_DOUBLE == 1, "ARDUINOJSON_USE_DOUBLE");
|
||||||
|
|
||||||
static_assert(sizeof(ARDUINOJSON_NAMESPACE::VariantSlot) == 16,
|
static_assert(sizeof(ArduinoJson::detail::VariantData) == 8, "slot size");
|
||||||
"sizeof(VariantSlot)");
|
|
||||||
|
|
||||||
int main() {}
|
int main() {}
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
|
set(CMAKE_CXX_STANDARD 11)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
if(MSVC)
|
if(MSVC)
|
||||||
add_compile_options(-D_CRT_SECURE_NO_WARNINGS)
|
add_compile_options(-D_CRT_SECURE_NO_WARNINGS)
|
||||||
endif()
|
endif()
|
||||||
@ -34,17 +37,13 @@ macro(add_fuzzer name)
|
|||||||
)
|
)
|
||||||
set_target_properties("${FUZZER}"
|
set_target_properties("${FUZZER}"
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
COMPILE_FLAGS
|
COMPILE_FLAGS "-fprofile-instr-generate -fcoverage-mapping -fsanitize=fuzzer -fno-sanitize-recover=all"
|
||||||
"-fprofile-instr-generate -fcoverage-mapping -fsanitize=fuzzer -fno-sanitize-recover=all"
|
LINK_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(
|
add_test(
|
||||||
NAME
|
NAME "${FUZZER}"
|
||||||
"${FUZZER}"
|
COMMAND "${FUZZER}" "${CORPUS_DIR}" "${SEED_CORPUS_DIR}" -max_total_time=5 -timeout=1
|
||||||
COMMAND
|
|
||||||
"${FUZZER}" "${CORPUS_DIR}" "${SEED_CORPUS_DIR}" -max_total_time=5 -timeout=1
|
|
||||||
)
|
)
|
||||||
|
|
||||||
set_tests_properties("${FUZZER}"
|
set_tests_properties("${FUZZER}"
|
||||||
@ -53,7 +52,16 @@ macro(add_fuzzer name)
|
|||||||
)
|
)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
if (CMAKE_CXX_COMPILER_ID STREQUAL "Clang" AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 6)
|
# 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(json)
|
||||||
add_fuzzer(msgpack)
|
add_fuzzer(msgpack)
|
||||||
endif()
|
endif()
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# CAUTION: this file is invoked by https://github.com/google/oss-fuzz
|
# CAUTION: this file is invoked by https://github.com/google/oss-fuzz
|
||||||
|
|
||||||
CXXFLAGS += -I../../src -DARDUINOJSON_DEBUG=1
|
CXXFLAGS += -I../../src -DARDUINOJSON_DEBUG=1 -std=c++11
|
||||||
|
|
||||||
all: \
|
all: \
|
||||||
$(OUT)/json_fuzzer \
|
$(OUT)/json_fuzzer \
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||||
DynamicJsonDocument doc(4096);
|
JsonDocument doc;
|
||||||
DeserializationError error = deserializeJson(doc, data, size);
|
DeserializationError error = deserializeJson(doc, data, size);
|
||||||
if (!error) {
|
if (!error) {
|
||||||
std::string json;
|
std::string json;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
|
||||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
|
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||||
DynamicJsonDocument doc(4096);
|
JsonDocument doc;
|
||||||
DeserializationError error = deserializeMsgPack(doc, data, size);
|
DeserializationError error = deserializeMsgPack(doc, data, size);
|
||||||
if (!error) {
|
if (!error) {
|
||||||
std::string json;
|
std::string json;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
|
|
||||||
// This file is NOT use by Google's OSS fuzz
|
// This file is NOT use by Google's OSS fuzz
|
||||||
|
@ -1,23 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -eu
|
|
||||||
|
|
||||||
INPUT=$1
|
|
||||||
OUTPUT=$2
|
|
||||||
|
|
||||||
cd "$INPUT"
|
|
||||||
|
|
||||||
# remove existing file
|
|
||||||
rm -f "$OUTPUT"
|
|
||||||
|
|
||||||
# create zip
|
|
||||||
7z a "$OUTPUT" \
|
|
||||||
-xr!.vs \
|
|
||||||
CHANGELOG.md \
|
|
||||||
examples \
|
|
||||||
src \
|
|
||||||
keywords.txt \
|
|
||||||
library.properties \
|
|
||||||
LICENSE.md \
|
|
||||||
README.md \
|
|
||||||
ArduinoJson.h
|
|
@ -53,7 +53,8 @@ process()
|
|||||||
}
|
}
|
||||||
|
|
||||||
simplify_namespaces() {
|
simplify_namespaces() {
|
||||||
perl -p0i -e 's|\} // namespace ARDUINOJSON_NAMESPACE\r?\nnamespace ARDUINOJSON_NAMESPACE \{\r?\n||igs' "$1"
|
perl -p0i -e 's|ARDUINOJSON_END_PUBLIC_NAMESPACE\r?\nARDUINOJSON_BEGIN_PUBLIC_NAMESPACE\r?\n||igs' "$1"
|
||||||
|
perl -p0i -e 's|ARDUINOJSON_END_PRIVATE_NAMESPACE\r?\nARDUINOJSON_BEGIN_PRIVATE_NAMESPACE\r?\n||igs' "$1"
|
||||||
rm -f "$1.bak"
|
rm -f "$1.bak"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
29
extras/scripts/extract_changes.awk
Executable file
29
extras/scripts/extract_changes.awk
Executable file
@ -0,0 +1,29 @@
|
|||||||
|
#!/usr/bin/awk -f
|
||||||
|
|
||||||
|
# Start echoing after the first list item
|
||||||
|
/\* / {
|
||||||
|
STARTED=1
|
||||||
|
EMPTY_LINE=0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Remember if we have seen an empty line
|
||||||
|
/^[[:space:]]*$/ {
|
||||||
|
EMPTY_LINE=1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Exit when seeing a new version number
|
||||||
|
/^v[[:digit:]]/ {
|
||||||
|
if (STARTED) exit
|
||||||
|
}
|
||||||
|
|
||||||
|
# Print if the line is not empty
|
||||||
|
# and restore the empty line we have skipped
|
||||||
|
!/^[[:space:]]*$/ {
|
||||||
|
if (STARTED) {
|
||||||
|
if (EMPTY_LINE) {
|
||||||
|
print ""
|
||||||
|
EMPTY_LINE=0
|
||||||
|
}
|
||||||
|
print
|
||||||
|
}
|
||||||
|
}
|
@ -1,14 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
set -eu
|
|
||||||
|
|
||||||
TAG="$1"
|
|
||||||
CHANGELOG="$2"
|
|
||||||
|
|
||||||
cat << END
|
|
||||||
## Changes
|
|
||||||
|
|
||||||
$(awk '/\* /{ FOUND=1 } /^[[:space:]]*$/ { if(FOUND) exit } { if(FOUND) print }' "$CHANGELOG")
|
|
||||||
|
|
||||||
[View version history](https://github.com/bblanchon/ArduinoJson/blob/$TAG/CHANGELOG.md)
|
|
||||||
END
|
|
@ -4,15 +4,15 @@ set -eu
|
|||||||
|
|
||||||
VERSION="$1"
|
VERSION="$1"
|
||||||
CHANGELOG="$2"
|
CHANGELOG="$2"
|
||||||
FRONTMATTER="$3"
|
ARDUINOJSON_H="$3"
|
||||||
|
|
||||||
cat << END
|
cat << END
|
||||||
---
|
---
|
||||||
branch: v6
|
branch: v7
|
||||||
version: $VERSION
|
version: $VERSION
|
||||||
date: '$(date +'%Y-%m-%d')'
|
date: '$(date +'%Y-%m-%d')'
|
||||||
$(cat "$FRONTMATTER")
|
$(extras/scripts/wandbox/publish.sh "$ARDUINOJSON_H")
|
||||||
---
|
---
|
||||||
|
|
||||||
$(awk '/\* /{ FOUND=1; print; next } { if (FOUND) exit}' "$CHANGELOG")
|
$(extras/scripts/extract_changes.awk "$CHANGELOG")
|
||||||
END
|
END
|
||||||
|
@ -9,7 +9,7 @@ trap 'rm -rf "$WORK_DIR"' EXIT
|
|||||||
cp "$SOURCE_DIR/README.md" "$WORK_DIR/README.md"
|
cp "$SOURCE_DIR/README.md" "$WORK_DIR/README.md"
|
||||||
cp "$SOURCE_DIR/CHANGELOG.md" "$WORK_DIR/CHANGELOG.md"
|
cp "$SOURCE_DIR/CHANGELOG.md" "$WORK_DIR/CHANGELOG.md"
|
||||||
cp "$SOURCE_DIR/library.properties" "$WORK_DIR/library.properties"
|
cp "$SOURCE_DIR/library.properties" "$WORK_DIR/library.properties"
|
||||||
cp "$SOURCE_DIR/LICENSE.md" "$WORK_DIR/LICENSE.txt"
|
cp "$SOURCE_DIR/LICENSE.txt" "$WORK_DIR/LICENSE.txt"
|
||||||
cp -r "$SOURCE_DIR/src" "$WORK_DIR/"
|
cp -r "$SOURCE_DIR/src" "$WORK_DIR/"
|
||||||
cp -r "$SOURCE_DIR/examples" "$WORK_DIR/"
|
cp -r "$SOURCE_DIR/examples" "$WORK_DIR/"
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
which awk sed jq 7z curl perl >/dev/null
|
which awk sed jq curl perl >/dev/null
|
||||||
|
|
||||||
cd "$(dirname "$0")/../.."
|
cd "$(dirname "$0")/../.."
|
||||||
|
|
||||||
@ -15,6 +15,7 @@ VERSION="$1"
|
|||||||
DATE=$(date +%F)
|
DATE=$(date +%F)
|
||||||
TAG="v$VERSION"
|
TAG="v$VERSION"
|
||||||
VERSION_REGEX='[0-9]+\.[0-9]+\.[0-9]+(-[a-z0-9]+)?'
|
VERSION_REGEX='[0-9]+\.[0-9]+\.[0-9]+(-[a-z0-9]+)?'
|
||||||
|
STARS=$(curl -s https://api.github.com/repos/bblanchon/ArduinoJson | jq '.stargazers_count')
|
||||||
|
|
||||||
update_version_in_source () {
|
update_version_in_source () {
|
||||||
IFS=".-" read MAJOR MINOR REVISION EXTRA < <(echo "$VERSION")
|
IFS=".-" read MAJOR MINOR REVISION EXTRA < <(echo "$VERSION")
|
||||||
@ -29,26 +30,39 @@ update_version_in_source () {
|
|||||||
sed -i~ -bE "s/(project\\s*\\(ArduinoJson\\s+VERSION\\s+).*?\\)/\\1$MAJOR.$MINOR.$REVISION)/" CMakeLists.txt
|
sed -i~ -bE "s/(project\\s*\\(ArduinoJson\\s+VERSION\\s+).*?\\)/\\1$MAJOR.$MINOR.$REVISION)/" CMakeLists.txt
|
||||||
rm CMakeLists.txt~
|
rm CMakeLists.txt~
|
||||||
|
|
||||||
sed -i~ -bE "s/\"version\":.*$/\"version\": \"$VERSION\",/" library.json
|
sed -i~ -bE \
|
||||||
|
-e "s/\"version\":.*$/\"version\": \"$VERSION\",/" \
|
||||||
|
-e "s/[0-9]+ stars/$STARS stars/" \
|
||||||
|
library.json
|
||||||
rm library.json~
|
rm library.json~
|
||||||
|
|
||||||
sed -i~ -bE "s/version=.*$/version=$VERSION/" library.properties
|
sed -i~ -bE \
|
||||||
|
-e "s/version=.*$/version=$VERSION/" \
|
||||||
|
-e "s/[0-9]+ stars/$STARS stars/" \
|
||||||
|
library.properties
|
||||||
rm library.properties~
|
rm library.properties~
|
||||||
|
|
||||||
sed -i~ -bE "s/version: .*$/version: $VERSION.{build}/" appveyor.yml
|
sed -i~ -bE "s/version: .*$/version: $VERSION.{build}/" appveyor.yml
|
||||||
rm appveyor.yml~
|
rm appveyor.yml~
|
||||||
|
|
||||||
|
sed -i~ -bE \
|
||||||
|
-e "s/^version: .*$/version: \"$VERSION\"/" \
|
||||||
|
-e "s/[0-9]+ stars/$STARS stars/" \
|
||||||
|
idf_component.yml
|
||||||
|
rm idf_component.yml~
|
||||||
|
|
||||||
sed -i~ -bE \
|
sed -i~ -bE \
|
||||||
-e "s/ARDUINOJSON_VERSION .*$/ARDUINOJSON_VERSION \"$VERSION\"/" \
|
-e "s/ARDUINOJSON_VERSION .*$/ARDUINOJSON_VERSION \"$VERSION\"/" \
|
||||||
-e "s/ARDUINOJSON_VERSION_MAJOR .*$/ARDUINOJSON_VERSION_MAJOR $MAJOR/" \
|
-e "s/ARDUINOJSON_VERSION_MAJOR .*$/ARDUINOJSON_VERSION_MAJOR $MAJOR/" \
|
||||||
-e "s/ARDUINOJSON_VERSION_MINOR .*$/ARDUINOJSON_VERSION_MINOR $MINOR/" \
|
-e "s/ARDUINOJSON_VERSION_MINOR .*$/ARDUINOJSON_VERSION_MINOR $MINOR/" \
|
||||||
-e "s/ARDUINOJSON_VERSION_REVISION .*$/ARDUINOJSON_VERSION_REVISION $REVISION/" \
|
-e "s/ARDUINOJSON_VERSION_REVISION .*$/ARDUINOJSON_VERSION_REVISION $REVISION/" \
|
||||||
|
-e "s/ARDUINOJSON_VERSION_MACRO .*$/ARDUINOJSON_VERSION_MACRO V$MAJOR$MINOR$REVISION/" \
|
||||||
src/ArduinoJson/version.hpp
|
src/ArduinoJson/version.hpp
|
||||||
rm src/ArduinoJson/version.hpp*~
|
rm src/ArduinoJson/version.hpp*~
|
||||||
}
|
}
|
||||||
|
|
||||||
commit_new_version () {
|
commit_new_version () {
|
||||||
git add src/ArduinoJson/version.hpp README.md CHANGELOG.md library.json library.properties appveyor.yml CMakeLists.txt
|
git add src/ArduinoJson/version.hpp README.md CHANGELOG.md library.json library.properties appveyor.yml CMakeLists.txt idf_component.yml
|
||||||
git commit -m "Set version to $VERSION"
|
git commit -m "Set version to $VERSION"
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,10 +80,8 @@ commit_new_version
|
|||||||
add_tag
|
add_tag
|
||||||
push
|
push
|
||||||
|
|
||||||
extras/scripts/build-arduino-package.sh . "../ArduinoJson-$TAG.zip"
|
|
||||||
extras/scripts/build-single-header.sh "src/ArduinoJson.h" "../ArduinoJson-$TAG.h"
|
extras/scripts/build-single-header.sh "src/ArduinoJson.h" "../ArduinoJson-$TAG.h"
|
||||||
extras/scripts/build-single-header.sh "src/ArduinoJson.hpp" "../ArduinoJson-$TAG.hpp"
|
extras/scripts/build-single-header.sh "src/ArduinoJson.hpp" "../ArduinoJson-$TAG.hpp"
|
||||||
extras/scripts/wandbox/publish.sh "../ArduinoJson-$TAG.h" > "../ArduinoJson-$TAG-wandbox.txt" || echo "Wandbox failed!"
|
extras/scripts/get-release-page.sh "$VERSION" "CHANGELOG.md" "../ArduinoJson-$TAG.h" > "../ArduinoJson-$TAG.md"
|
||||||
extras/scripts/get-release-page.sh "$VERSION" "CHANGELOG.md" "../ArduinoJson-$TAG-wandbox.txt" > "../ArduinoJson-$TAG.md"
|
|
||||||
|
|
||||||
echo "You can now copy ../ArduinoJson-$TAG.md into arduinojson.org/collections/_versions/$VERSION.md"
|
echo "You can now copy ../ArduinoJson-$TAG.md into arduinojson.org/collections/_versions/$VERSION.md"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to generate a JSON document with ArduinoJson.
|
// This example shows how to generate a JSON document with ArduinoJson.
|
||||||
@ -9,35 +9,18 @@
|
|||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 200 is the RAM allocated to this document.
|
|
||||||
// Don't forget to change this value to match your requirement.
|
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<200> doc;
|
|
||||||
|
|
||||||
// StaticJsonObject allocates memory on the stack, it can be
|
// Add values in the document.
|
||||||
// replaced by DynamicJsonDocument which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonDocument doc(200);
|
|
||||||
|
|
||||||
// StaticJsonObject allocates memory on the stack, it can be
|
|
||||||
// replaced by DynamicJsonDocument which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonDocument doc(200);
|
|
||||||
|
|
||||||
// Add values in the document
|
|
||||||
//
|
|
||||||
doc["sensor"] = "gps";
|
doc["sensor"] = "gps";
|
||||||
doc["time"] = 1351824120;
|
doc["time"] = 1351824120;
|
||||||
|
|
||||||
// Add an array.
|
// Add an array
|
||||||
//
|
JsonArray data = doc["data"].to<JsonArray>();
|
||||||
JsonArray data = doc.createNestedArray("data");
|
|
||||||
data.add(48.756080);
|
data.add(48.756080);
|
||||||
data.add(2.302038);
|
data.add(2.302038);
|
||||||
|
|
||||||
// Generate the minified JSON and send it to STDOUT
|
// Generate the minified JSON and send it to STDOUT
|
||||||
//
|
|
||||||
serializeJson(doc, std::cout);
|
serializeJson(doc, std::cout);
|
||||||
// The above line prints:
|
// The above line prints:
|
||||||
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}
|
||||||
@ -46,7 +29,6 @@ int main() {
|
|||||||
std::cout << std::endl;
|
std::cout << std::endl;
|
||||||
|
|
||||||
// Generate the prettified JSON and send it to STDOUT
|
// Generate the prettified JSON and send it to STDOUT
|
||||||
//
|
|
||||||
serializeJsonPretty(doc, std::cout);
|
serializeJsonPretty(doc, std::cout);
|
||||||
// The above line prints:
|
// The above line prints:
|
||||||
// {
|
// {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to deserialize a JSON document with ArduinoJson.
|
// This example shows how to deserialize a JSON document with ArduinoJson.
|
||||||
@ -9,38 +9,22 @@
|
|||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 200 is the capacity of the memory pool in bytes.
|
|
||||||
// Don't forget to change this value to match your JSON document.
|
|
||||||
// Use https://arduinojson.org/v6/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<300> doc;
|
|
||||||
|
|
||||||
// StaticJsonDocument<N> allocates memory on the stack, it can be
|
// JSON input string
|
||||||
// replaced by DynamicJsonDocument which allocates in the heap.
|
const char* json =
|
||||||
//
|
|
||||||
// DynamicJsonDocument doc(200);
|
|
||||||
|
|
||||||
// JSON input string.
|
|
||||||
//
|
|
||||||
// Using a char[], as shown here, enables the "zero-copy" mode. This mode uses
|
|
||||||
// the minimal amount of memory because the JsonDocument stores pointers to
|
|
||||||
// the input buffer.
|
|
||||||
// If you use another type of input, ArduinoJson must copy the strings from
|
|
||||||
// the input to the JsonDocument, so you need to increase the capacity of the
|
|
||||||
// JsonDocument.
|
|
||||||
char json[] =
|
|
||||||
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
"{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";
|
||||||
|
|
||||||
// Deserialize the JSON document
|
// Deserialize the JSON document
|
||||||
DeserializationError error = deserializeJson(doc, json);
|
DeserializationError error = deserializeJson(doc, json);
|
||||||
|
|
||||||
// Test if parsing succeeds.
|
// Test if parsing succeeds
|
||||||
if (error) {
|
if (error) {
|
||||||
std::cerr << "deserializeJson() failed: " << error.c_str() << std::endl;
|
std::cerr << "deserializeJson() failed: " << error.c_str() << std::endl;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch values.
|
// Fetch the values
|
||||||
//
|
//
|
||||||
// Most of the time, you can rely on the implicit casts.
|
// Most of the time, you can rely on the implicit casts.
|
||||||
// In other case, you can do doc["time"].as<long>();
|
// In other case, you can do doc["time"].as<long>();
|
||||||
@ -49,7 +33,7 @@ int main() {
|
|||||||
double latitude = doc["data"][0];
|
double latitude = doc["data"][0];
|
||||||
double longitude = doc["data"][1];
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
// Print values.
|
// Print the values
|
||||||
std::cout << sensor << std::endl;
|
std::cout << sensor << std::endl;
|
||||||
std::cout << time << std::endl;
|
std::cout << time << std::endl;
|
||||||
std::cout << latitude << std::endl;
|
std::cout << latitude << std::endl;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
//
|
//
|
||||||
// This example shows how to generate a JSON document with ArduinoJson.
|
// This example shows how to generate a JSON document with ArduinoJson.
|
||||||
@ -9,22 +9,9 @@
|
|||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
// Allocate the JSON document
|
// Allocate the JSON document
|
||||||
//
|
JsonDocument doc;
|
||||||
// Inside the brackets, 300 is the size of the memory pool in bytes.
|
|
||||||
// Don't forget to change this value to match your JSON document.
|
|
||||||
// Use https://arduinojson.org/assistant to compute the capacity.
|
|
||||||
StaticJsonDocument<300> doc;
|
|
||||||
|
|
||||||
// StaticJsonObject allocates memory on the stack, it can be
|
// The MessagePack input string
|
||||||
// replaced by DynamicJsonObject which allocates in the heap.
|
|
||||||
//
|
|
||||||
// DynamicJsonObject doc(200);
|
|
||||||
|
|
||||||
// MessagePack input string.
|
|
||||||
//
|
|
||||||
// It's better to use a char[] as shown here.
|
|
||||||
// If you use a const char* or a String, ArduinoJson will
|
|
||||||
// have to make a copy of the input in the JsonBuffer.
|
|
||||||
uint8_t input[] = {131, 166, 115, 101, 110, 115, 111, 114, 163, 103, 112, 115,
|
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,
|
164, 116, 105, 109, 101, 206, 80, 147, 50, 248, 164, 100,
|
||||||
97, 116, 97, 146, 203, 64, 72, 96, 199, 58, 188, 148,
|
97, 116, 97, 146, 203, 64, 72, 96, 199, 58, 188, 148,
|
||||||
@ -36,20 +23,16 @@ int main() {
|
|||||||
// "data": [48.75608, 2.302038]
|
// "data": [48.75608, 2.302038]
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// doc of the object tree.
|
// Parse the input
|
||||||
//
|
|
||||||
// It's a reference to the JsonObject, the actual bytes are inside the
|
|
||||||
// JsonBuffer with all the other nodes of the object tree.
|
|
||||||
// Memory is freed when jsonBuffer goes out of scope.
|
|
||||||
DeserializationError error = deserializeMsgPack(doc, input);
|
DeserializationError error = deserializeMsgPack(doc, input);
|
||||||
|
|
||||||
// Test if parsing succeeds.
|
// Test if parsing succeeds
|
||||||
if (error) {
|
if (error) {
|
||||||
std::cerr << "deserializeMsgPack() failed: " << error.c_str() << std::endl;
|
std::cerr << "deserializeMsgPack() failed: " << error.c_str() << std::endl;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch values.
|
// Fetch the values
|
||||||
//
|
//
|
||||||
// Most of the time, you can rely on the implicit casts.
|
// Most of the time, you can rely on the implicit casts.
|
||||||
// In other case, you can do doc["time"].as<long>();
|
// In other case, you can do doc["time"].as<long>();
|
||||||
@ -58,7 +41,7 @@ int main() {
|
|||||||
double latitude = doc["data"][0];
|
double latitude = doc["data"][0];
|
||||||
double longitude = doc["data"][1];
|
double longitude = doc["data"][1];
|
||||||
|
|
||||||
// Print values.
|
// Print the values
|
||||||
std::cout << sensor << std::endl;
|
std::cout << sensor << std::endl;
|
||||||
std::cout << time << std::endl;
|
std::cout << time << std::endl;
|
||||||
std::cout << latitude << std::endl;
|
std::cout << latitude << std::endl;
|
||||||
|
@ -14,8 +14,8 @@ compile() {
|
|||||||
{
|
{
|
||||||
"code":$(read_string "$FILE_PATH"),
|
"code":$(read_string "$FILE_PATH"),
|
||||||
"codes": [{"file":"ArduinoJson.h","code":$(read_string "$ARDUINOJSON_H")}],
|
"codes": [{"file":"ArduinoJson.h","code":$(read_string "$ARDUINOJSON_H")}],
|
||||||
"options": "warning",
|
"options": "warning,c++11",
|
||||||
"compiler": "gcc-4.9.4",
|
"compiler": "gcc-head",
|
||||||
"save": true
|
"save": true
|
||||||
}
|
}
|
||||||
END
|
END
|
||||||
|
@ -1,27 +1,33 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 98)
|
set(CMAKE_CXX_STANDARD 11)
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
add_subdirectory(catch)
|
link_libraries(ArduinoJson)
|
||||||
|
|
||||||
link_libraries(ArduinoJson catch)
|
# Failing builds should only link with ArduinoJson, not catch
|
||||||
|
add_subdirectory(FailingBuilds)
|
||||||
|
|
||||||
|
add_subdirectory(catch)
|
||||||
|
link_libraries(catch)
|
||||||
|
|
||||||
include_directories(Helpers)
|
include_directories(Helpers)
|
||||||
add_subdirectory(Cpp11)
|
|
||||||
add_subdirectory(Cpp17)
|
add_subdirectory(Cpp17)
|
||||||
add_subdirectory(Cpp20)
|
add_subdirectory(Cpp20)
|
||||||
add_subdirectory(FailingBuilds)
|
add_subdirectory(Deprecated)
|
||||||
add_subdirectory(IntegrationTests)
|
add_subdirectory(IntegrationTests)
|
||||||
add_subdirectory(JsonArray)
|
add_subdirectory(JsonArray)
|
||||||
|
add_subdirectory(JsonArrayConst)
|
||||||
add_subdirectory(JsonDeserializer)
|
add_subdirectory(JsonDeserializer)
|
||||||
add_subdirectory(JsonDocument)
|
add_subdirectory(JsonDocument)
|
||||||
add_subdirectory(JsonObject)
|
add_subdirectory(JsonObject)
|
||||||
|
add_subdirectory(JsonObjectConst)
|
||||||
add_subdirectory(JsonSerializer)
|
add_subdirectory(JsonSerializer)
|
||||||
add_subdirectory(JsonVariant)
|
add_subdirectory(JsonVariant)
|
||||||
add_subdirectory(MemoryPool)
|
add_subdirectory(JsonVariantConst)
|
||||||
|
add_subdirectory(ResourceManager)
|
||||||
add_subdirectory(Misc)
|
add_subdirectory(Misc)
|
||||||
add_subdirectory(MixedConfiguration)
|
add_subdirectory(MixedConfiguration)
|
||||||
add_subdirectory(MsgPackDeserializer)
|
add_subdirectory(MsgPackDeserializer)
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
|
||||||
# MIT License
|
|
||||||
|
|
||||||
if("cxx_nullptr" IN_LIST CMAKE_CXX_COMPILE_FEATURES)
|
|
||||||
list(APPEND SOURCES nullptr.cpp)
|
|
||||||
add_definitions(-DARDUINOJSON_HAS_NULLPTR=1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("cxx_auto_type" IN_LIST CMAKE_CXX_COMPILE_FEATURES AND "cxx_constexpr" IN_LIST CMAKE_CXX_COMPILE_FEATURES)
|
|
||||||
list(APPEND SOURCES issue1120.cpp)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if("cxx_long_long_type" IN_LIST CMAKE_CXX_COMPILE_FEATURES)
|
|
||||||
list(APPEND SOURCES use_long_long_0.cpp use_long_long_1.cpp)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT SOURCES)
|
|
||||||
return()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 11)
|
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
||||||
|
|
||||||
add_executable(Cpp11Tests ${SOURCES})
|
|
||||||
|
|
||||||
add_test(Cpp11 Cpp11Tests)
|
|
||||||
|
|
||||||
set_tests_properties(Cpp11
|
|
||||||
PROPERTIES
|
|
||||||
LABELS "Catch"
|
|
||||||
)
|
|
@ -1,16 +0,0 @@
|
|||||||
#define ARDUINOJSON_USE_LONG_LONG 0
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
#include <catch.hpp>
|
|
||||||
|
|
||||||
TEST_CASE("ARDUINOJSON_USE_LONG_LONG == 0") {
|
|
||||||
DynamicJsonDocument doc(4096);
|
|
||||||
|
|
||||||
doc["A"] = 42;
|
|
||||||
doc["B"] = 84;
|
|
||||||
|
|
||||||
std::string json;
|
|
||||||
serializeJson(doc, json);
|
|
||||||
|
|
||||||
REQUIRE(json == "{\"A\":42,\"B\":84}");
|
|
||||||
}
|
|
@ -1,5 +1,5 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
if(MSVC_VERSION LESS 1910)
|
if(MSVC_VERSION LESS 1910)
|
||||||
|
@ -1,14 +1,28 @@
|
|||||||
#include <ArduinoJson.h>
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
// we expect ArduinoJson.h to include <string_view>
|
||||||
|
// but we don't want it to included accidentally
|
||||||
|
#undef ARDUINO
|
||||||
|
#define ARDUINOJSON_ENABLE_STD_STREAM 0
|
||||||
|
#define ARDUINOJSON_ENABLE_STD_STRING 0
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
#include <catch.hpp>
|
#include <catch.hpp>
|
||||||
#include <string_view>
|
|
||||||
|
#include "Allocators.hpp"
|
||||||
|
#include "Literals.hpp"
|
||||||
|
|
||||||
#if !ARDUINOJSON_ENABLE_STRING_VIEW
|
#if !ARDUINOJSON_ENABLE_STRING_VIEW
|
||||||
# error ARDUINOJSON_ENABLE_STRING_VIEW must be set to 1
|
# error ARDUINOJSON_ENABLE_STRING_VIEW must be set to 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
using ArduinoJson::detail::sizeofArray;
|
||||||
|
|
||||||
TEST_CASE("string_view") {
|
TEST_CASE("string_view") {
|
||||||
StaticJsonDocument<256> doc;
|
SpyingAllocator spy;
|
||||||
|
JsonDocument doc(&spy);
|
||||||
JsonVariant variant = doc.to<JsonVariant>();
|
JsonVariant variant = doc.to<JsonVariant>();
|
||||||
|
|
||||||
SECTION("deserializeJson()") {
|
SECTION("deserializeJson()") {
|
||||||
@ -19,7 +33,7 @@ TEST_CASE("string_view") {
|
|||||||
|
|
||||||
SECTION("JsonDocument::set()") {
|
SECTION("JsonDocument::set()") {
|
||||||
doc.set(std::string_view("123", 2));
|
doc.set(std::string_view("123", 2));
|
||||||
REQUIRE(doc.as<std::string>() == "12");
|
REQUIRE(doc.as<std::string_view>() == "12");
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION("JsonDocument::operator[]() const") {
|
SECTION("JsonDocument::operator[]() const") {
|
||||||
@ -53,16 +67,15 @@ TEST_CASE("string_view") {
|
|||||||
|
|
||||||
SECTION("String deduplication") {
|
SECTION("String deduplication") {
|
||||||
doc.add(std::string_view("example one", 7));
|
doc.add(std::string_view("example one", 7));
|
||||||
REQUIRE(doc.memoryUsage() == JSON_ARRAY_SIZE(1) + 8);
|
|
||||||
|
|
||||||
doc.add(std::string_view("example two", 7));
|
doc.add(std::string_view("example two", 7));
|
||||||
REQUIRE(doc.memoryUsage() == JSON_ARRAY_SIZE(2) + 8);
|
|
||||||
|
|
||||||
doc.add(std::string_view("example\0tree", 12));
|
doc.add(std::string_view("example\0tree", 12));
|
||||||
REQUIRE(doc.memoryUsage() == JSON_ARRAY_SIZE(3) + 21);
|
|
||||||
|
|
||||||
doc.add(std::string_view("example\0tree and a half", 12));
|
doc.add(std::string_view("example\0tree and a half", 12));
|
||||||
REQUIRE(doc.memoryUsage() == JSON_ARRAY_SIZE(4) + 21);
|
|
||||||
|
REQUIRE(spy.log() == AllocatorLog{
|
||||||
|
Allocate(sizeofPool()),
|
||||||
|
Allocate(sizeofString("example")),
|
||||||
|
Allocate(sizeofString("example tree")),
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION("as<std::string_view>()") {
|
SECTION("as<std::string_view>()") {
|
||||||
@ -80,13 +93,13 @@ TEST_CASE("string_view") {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SECTION("String containing NUL") {
|
SECTION("String containing NUL") {
|
||||||
doc.set(std::string("hello\0world", 11));
|
doc.set("hello\0world"_s);
|
||||||
REQUIRE(doc.as<std::string_view>().size() == 11);
|
REQUIRE(doc.as<std::string_view>().size() == 11);
|
||||||
REQUIRE(doc.as<std::string_view>() == std::string_view("hello\0world", 11));
|
REQUIRE(doc.as<std::string_view>() == std::string_view("hello\0world", 11));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
using ARDUINOJSON_NAMESPACE::adaptString;
|
using ArduinoJson::detail::adaptString;
|
||||||
|
|
||||||
TEST_CASE("StringViewAdapter") {
|
TEST_CASE("StringViewAdapter") {
|
||||||
std::string_view str("bravoXXX", 5);
|
std::string_view str("bravoXXX", 5);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
if(MSVC_VERSION LESS 1910)
|
if(MSVC_VERSION LESS 1910)
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
TEST_CASE("C++20 smoke test") {
|
TEST_CASE("C++20 smoke test") {
|
||||||
StaticJsonDocument<128> doc;
|
JsonDocument doc;
|
||||||
|
|
||||||
deserializeJson(doc, "{\"hello\":\"world\"}");
|
deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
REQUIRE(doc["hello"] == "world");
|
REQUIRE(doc["hello"] == "world");
|
||||||
|
69
extras/tests/Deprecated/BasicJsonDocument.cpp
Normal file
69
extras/tests/Deprecated/BasicJsonDocument.cpp
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
using ArduinoJson::detail::is_base_of;
|
||||||
|
|
||||||
|
static std::string allocatorLog;
|
||||||
|
|
||||||
|
struct CustomAllocator {
|
||||||
|
CustomAllocator() {
|
||||||
|
allocatorLog = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void* allocate(size_t n) {
|
||||||
|
allocatorLog += "A";
|
||||||
|
return malloc(n);
|
||||||
|
}
|
||||||
|
|
||||||
|
void deallocate(void* p) {
|
||||||
|
free(p);
|
||||||
|
allocatorLog += "D";
|
||||||
|
}
|
||||||
|
|
||||||
|
void* reallocate(void* p, size_t n) {
|
||||||
|
allocatorLog += "R";
|
||||||
|
return realloc(p, n);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_CASE("BasicJsonDocument") {
|
||||||
|
allocatorLog.clear();
|
||||||
|
|
||||||
|
SECTION("is a JsonDocument") {
|
||||||
|
REQUIRE(
|
||||||
|
is_base_of<JsonDocument, BasicJsonDocument<CustomAllocator>>::value ==
|
||||||
|
true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("deserialize / serialize") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
doc.clear();
|
||||||
|
REQUIRE(allocatorLog == "AARARDDD");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("copy") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
doc["hello"] = "world";
|
||||||
|
auto copy = doc;
|
||||||
|
REQUIRE(copy.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(allocatorLog == "AAAA");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("capacity") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
REQUIRE(doc.capacity() == 256);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("garbageCollect()") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
doc.garbageCollect();
|
||||||
|
}
|
||||||
|
}
|
35
extras/tests/Deprecated/CMakeLists.txt
Normal file
35
extras/tests/Deprecated/CMakeLists.txt
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# ArduinoJson - https://arduinojson.org
|
||||||
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
# MIT License
|
||||||
|
|
||||||
|
if(CMAKE_CXX_COMPILER_ID MATCHES "(GNU|Clang)")
|
||||||
|
add_compile_options(
|
||||||
|
-w
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(MSVC)
|
||||||
|
add_compile_options(
|
||||||
|
/wd4996
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_executable(DeprecatedTests
|
||||||
|
add.cpp
|
||||||
|
BasicJsonDocument.cpp
|
||||||
|
containsKey.cpp
|
||||||
|
createNestedArray.cpp
|
||||||
|
createNestedObject.cpp
|
||||||
|
DynamicJsonDocument.cpp
|
||||||
|
macros.cpp
|
||||||
|
memoryUsage.cpp
|
||||||
|
shallowCopy.cpp
|
||||||
|
StaticJsonDocument.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
add_test(Deprecated DeprecatedTests)
|
||||||
|
|
||||||
|
set_tests_properties(Deprecated
|
||||||
|
PROPERTIES
|
||||||
|
LABELS "Catch"
|
||||||
|
)
|
37
extras/tests/Deprecated/DynamicJsonDocument.cpp
Normal file
37
extras/tests/Deprecated/DynamicJsonDocument.cpp
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
using ArduinoJson::detail::is_base_of;
|
||||||
|
|
||||||
|
TEST_CASE("DynamicJsonDocument") {
|
||||||
|
SECTION("is a JsonDocument") {
|
||||||
|
REQUIRE(is_base_of<JsonDocument, DynamicJsonDocument>::value == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("deserialize / serialize") {
|
||||||
|
DynamicJsonDocument doc(256);
|
||||||
|
deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("copy") {
|
||||||
|
DynamicJsonDocument doc(256);
|
||||||
|
doc["hello"] = "world";
|
||||||
|
auto copy = doc;
|
||||||
|
REQUIRE(copy.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("capacity") {
|
||||||
|
DynamicJsonDocument doc(256);
|
||||||
|
REQUIRE(doc.capacity() == 256);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("garbageCollect()") {
|
||||||
|
DynamicJsonDocument doc(256);
|
||||||
|
doc.garbageCollect();
|
||||||
|
}
|
||||||
|
}
|
32
extras/tests/Deprecated/StaticJsonDocument.cpp
Normal file
32
extras/tests/Deprecated/StaticJsonDocument.cpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
using ArduinoJson::detail::is_base_of;
|
||||||
|
|
||||||
|
TEST_CASE("StaticJsonDocument") {
|
||||||
|
SECTION("is a JsonDocument") {
|
||||||
|
REQUIRE(is_base_of<JsonDocument, StaticJsonDocument<256>>::value == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("deserialize / serialize") {
|
||||||
|
StaticJsonDocument<256> doc;
|
||||||
|
deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("copy") {
|
||||||
|
StaticJsonDocument<256> doc;
|
||||||
|
doc["hello"] = "world";
|
||||||
|
auto copy = doc;
|
||||||
|
REQUIRE(copy.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("capacity") {
|
||||||
|
StaticJsonDocument<256> doc;
|
||||||
|
REQUIRE(doc.capacity() == 256);
|
||||||
|
}
|
||||||
|
}
|
38
extras/tests/Deprecated/add.cpp
Normal file
38
extras/tests/Deprecated/add.cpp
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
TEST_CASE("JsonArray::add()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonArray array = doc.to<JsonArray>();
|
||||||
|
array.add().set(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[42]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonDocument::add()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
doc.add().set(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[42]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("ElementProxy::add()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
doc[0].add().set(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[[42]]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("MemberProxy::add()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
doc["x"].add().set(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"x\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariant::add()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonVariant v = doc.add();
|
||||||
|
v.add().set(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[[42]]");
|
||||||
|
}
|
246
extras/tests/Deprecated/containsKey.cpp
Normal file
246
extras/tests/Deprecated/containsKey.cpp
Normal file
@ -0,0 +1,246 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
#include "Literals.hpp"
|
||||||
|
|
||||||
|
TEST_CASE("JsonDocument::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
SECTION("returns true on object") {
|
||||||
|
doc["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey("hello") == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns true when value is null") {
|
||||||
|
doc["hello"] = static_cast<const char*>(0);
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey("hello") == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns true when key is a std::string") {
|
||||||
|
doc["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey("hello"_s) == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns false on object") {
|
||||||
|
doc["world"] = "hello";
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey("hello") == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns false on array") {
|
||||||
|
doc.add("hello");
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey("hello") == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns false on null") {
|
||||||
|
REQUIRE(doc.containsKey("hello") == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("supports JsonVariant") {
|
||||||
|
doc["hello"] = "world";
|
||||||
|
doc["key"] = "hello";
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey(doc["key"]) == true);
|
||||||
|
REQUIRE(doc.containsKey(doc["foo"]) == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("supports VLAs") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
doc["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(doc.containsKey(vla) == true);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("MemberProxy::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
const auto& mp = doc["hello"];
|
||||||
|
|
||||||
|
SECTION("containsKey(const char*)") {
|
||||||
|
mp["key"] = "value";
|
||||||
|
|
||||||
|
REQUIRE(mp.containsKey("key") == true);
|
||||||
|
REQUIRE(mp.containsKey("key") == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("containsKey(std::string)") {
|
||||||
|
mp["key"] = "value";
|
||||||
|
|
||||||
|
REQUIRE(mp.containsKey("key"_s) == true);
|
||||||
|
REQUIRE(mp.containsKey("key"_s) == true);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("supports VLAs") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
mp["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(mp.containsKey(vla) == true);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObject::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonObject obj = doc.to<JsonObject>();
|
||||||
|
obj["hello"] = 42;
|
||||||
|
|
||||||
|
SECTION("returns true only if key is present") {
|
||||||
|
REQUIRE(false == obj.containsKey("world"));
|
||||||
|
REQUIRE(true == obj.containsKey("hello"));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("returns false after remove()") {
|
||||||
|
obj.remove("hello");
|
||||||
|
|
||||||
|
REQUIRE(false == obj.containsKey("hello"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("key is a VLA") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
REQUIRE(true == obj.containsKey(vla));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SECTION("key is a JsonVariant") {
|
||||||
|
doc["key"] = "hello";
|
||||||
|
REQUIRE(true == obj.containsKey(obj["key"]));
|
||||||
|
REQUIRE(false == obj.containsKey(obj["hello"]));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("std::string") {
|
||||||
|
REQUIRE(true == obj.containsKey("hello"_s));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("unsigned char[]") {
|
||||||
|
unsigned char key[] = "hello";
|
||||||
|
REQUIRE(true == obj.containsKey(key));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObjectConst::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
doc["hello"] = 42;
|
||||||
|
auto obj = doc.as<JsonObjectConst>();
|
||||||
|
|
||||||
|
SECTION("supports const char*") {
|
||||||
|
REQUIRE(false == obj.containsKey("world"));
|
||||||
|
REQUIRE(true == obj.containsKey("hello"));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("supports std::string") {
|
||||||
|
REQUIRE(false == obj.containsKey("world"_s));
|
||||||
|
REQUIRE(true == obj.containsKey("hello"_s));
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("supports VLA") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
REQUIRE(true == obj.containsKey(vla));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SECTION("supports JsonVariant") {
|
||||||
|
doc["key"] = "hello";
|
||||||
|
REQUIRE(true == obj.containsKey(obj["key"]));
|
||||||
|
REQUIRE(false == obj.containsKey(obj["hello"]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariant::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonVariant var = doc.to<JsonVariant>();
|
||||||
|
|
||||||
|
SECTION("returns false is unbound") {
|
||||||
|
CHECK_FALSE(JsonVariant().containsKey("hello"));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("containsKey(const char*)") {
|
||||||
|
var["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(var.containsKey("hello") == true);
|
||||||
|
REQUIRE(var.containsKey("world") == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("containsKey(std::string)") {
|
||||||
|
var["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(var.containsKey("hello"_s) == true);
|
||||||
|
REQUIRE(var.containsKey("world"_s) == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("containsKey(JsonVariant)") {
|
||||||
|
var["hello"] = "world";
|
||||||
|
var["key"] = "hello";
|
||||||
|
|
||||||
|
REQUIRE(var.containsKey(doc["key"]) == true);
|
||||||
|
REQUIRE(var.containsKey(doc["foo"]) == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("supports VLAs") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
var["hello"] = "world";
|
||||||
|
|
||||||
|
REQUIRE(var.containsKey(vla) == true);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariantConst::containsKey()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
doc["hello"] = "world";
|
||||||
|
JsonVariantConst var = doc.as<JsonVariant>();
|
||||||
|
|
||||||
|
SECTION("support const char*") {
|
||||||
|
REQUIRE(var.containsKey("hello") == true);
|
||||||
|
REQUIRE(var.containsKey("world") == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("support std::string") {
|
||||||
|
REQUIRE(var.containsKey("hello"_s) == true);
|
||||||
|
REQUIRE(var.containsKey("world"_s) == false);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("supports VLA") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "hello");
|
||||||
|
|
||||||
|
REQUIRE(true == var.containsKey(vla));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SECTION("support JsonVariant") {
|
||||||
|
doc["key"] = "hello";
|
||||||
|
REQUIRE(var.containsKey(var["key"]) == true);
|
||||||
|
REQUIRE(var.containsKey(var["foo"]) == false);
|
||||||
|
}
|
||||||
|
}
|
113
extras/tests/Deprecated/createNestedArray.cpp
Normal file
113
extras/tests/Deprecated/createNestedArray.cpp
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "Literals.hpp"
|
||||||
|
|
||||||
|
TEST_CASE("JsonDocument::createNestedArray()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
SECTION("createNestedArray()") {
|
||||||
|
JsonArray array = doc.createNestedArray();
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[[42]]");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedArray(const char*)") {
|
||||||
|
JsonArray array = doc.createNestedArray("key");
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedArray(std::string)") {
|
||||||
|
JsonArray array = doc.createNestedArray("key"_s);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedArray(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonArray array = doc.createNestedArray(vla);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonArray::createNestedArray()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonArray array = doc.to<JsonArray>();
|
||||||
|
JsonArray nestedArray = array.createNestedArray();
|
||||||
|
nestedArray.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[[42]]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObject::createNestedArray()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonObject object = doc.to<JsonObject>();
|
||||||
|
|
||||||
|
SECTION("createNestedArray(const char*)") {
|
||||||
|
JsonArray array = object.createNestedArray("key");
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedArray(std::string)") {
|
||||||
|
JsonArray array = object.createNestedArray("key"_s);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedArray(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonArray array = object.createNestedArray(vla);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariant::createNestedArray()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonVariant variant = doc.to<JsonVariant>();
|
||||||
|
|
||||||
|
SECTION("createNestedArray()") {
|
||||||
|
JsonArray array = variant.createNestedArray();
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "[[42]]");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedArray(const char*)") {
|
||||||
|
JsonArray array = variant.createNestedArray("key");
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedArray(std::string)") {
|
||||||
|
JsonArray array = variant.createNestedArray("key"_s);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedArray(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonArray array = variant.createNestedArray(vla);
|
||||||
|
array.add(42);
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":[42]}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
113
extras/tests/Deprecated/createNestedObject.cpp
Normal file
113
extras/tests/Deprecated/createNestedObject.cpp
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "Literals.hpp"
|
||||||
|
|
||||||
|
TEST_CASE("JsonDocument::createNestedObject()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
|
||||||
|
SECTION("createNestedObject()") {
|
||||||
|
JsonObject object = doc.createNestedObject();
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "[{\"hello\":\"world\"}]");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedObject(const char*)") {
|
||||||
|
JsonObject object = doc.createNestedObject("key");
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedObject(std::string)") {
|
||||||
|
JsonObject object = doc.createNestedObject("key"_s);
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedObject(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonObject object = doc.createNestedObject(vla);
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonArray::createNestedObject()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonArray array = doc.to<JsonArray>();
|
||||||
|
JsonObject object = array.createNestedObject();
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "[{\"hello\":\"world\"}]");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObject::createNestedObject()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonObject object = doc.to<JsonObject>();
|
||||||
|
|
||||||
|
SECTION("createNestedObject(const char*)") {
|
||||||
|
JsonObject nestedObject = object.createNestedObject("key");
|
||||||
|
nestedObject["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedObject(std::string)") {
|
||||||
|
JsonObject nestedObject = object.createNestedObject("key"_s);
|
||||||
|
nestedObject["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedObject(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonObject nestedObject = object.createNestedObject(vla);
|
||||||
|
nestedObject["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariant::createNestedObject()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
JsonVariant variant = doc.to<JsonVariant>();
|
||||||
|
|
||||||
|
SECTION("createNestedObject()") {
|
||||||
|
JsonObject object = variant.createNestedObject();
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "[{\"hello\":\"world\"}]");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedObject(const char*)") {
|
||||||
|
JsonObject object = variant.createNestedObject("key");
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("createNestedObject(std::string)") {
|
||||||
|
JsonObject object = variant.createNestedObject("key"_s);
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef HAS_VARIABLE_LENGTH_ARRAY
|
||||||
|
SECTION("createNestedObject(VLA)") {
|
||||||
|
size_t i = 16;
|
||||||
|
char vla[i];
|
||||||
|
strcpy(vla, "key");
|
||||||
|
JsonObject object = variant.createNestedObject(vla);
|
||||||
|
object["hello"] = "world";
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"key\":{\"hello\":\"world\"}}");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
18
extras/tests/Deprecated/macros.cpp
Normal file
18
extras/tests/Deprecated/macros.cpp
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
TEST_CASE("JSON_ARRAY_SIZE") {
|
||||||
|
REQUIRE(JSON_ARRAY_SIZE(10) == ArduinoJson::detail::sizeofArray(10));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JSON_OBJECT_SIZE") {
|
||||||
|
REQUIRE(JSON_OBJECT_SIZE(10) == ArduinoJson::detail::sizeofObject(10));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JSON_STRING_SIZE") {
|
||||||
|
REQUIRE(JSON_STRING_SIZE(10) == 11); // issue #2054
|
||||||
|
}
|
51
extras/tests/Deprecated/memoryUsage.cpp
Normal file
51
extras/tests/Deprecated/memoryUsage.cpp
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
TEST_CASE("JsonArray::memoryUsage()") {
|
||||||
|
JsonArray array;
|
||||||
|
REQUIRE(array.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonArrayConst::memoryUsage()") {
|
||||||
|
JsonArrayConst array;
|
||||||
|
REQUIRE(array.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonDocument::memoryUsage()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
REQUIRE(doc.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObject::memoryUsage()") {
|
||||||
|
JsonObject array;
|
||||||
|
REQUIRE(array.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonObjectConst::memoryUsage()") {
|
||||||
|
JsonObjectConst array;
|
||||||
|
REQUIRE(array.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariant::memoryUsage()") {
|
||||||
|
JsonVariant doc;
|
||||||
|
REQUIRE(doc.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("JsonVariantConst::memoryUsage()") {
|
||||||
|
JsonVariantConst doc;
|
||||||
|
REQUIRE(doc.memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("ElementProxy::memoryUsage()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
REQUIRE(doc[0].memoryUsage() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("MemberProxy::memoryUsage()") {
|
||||||
|
JsonDocument doc;
|
||||||
|
REQUIRE(doc["hello"].memoryUsage() == 0);
|
||||||
|
}
|
14
extras/tests/Deprecated/shallowCopy.cpp
Normal file
14
extras/tests/Deprecated/shallowCopy.cpp
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
TEST_CASE("shallowCopy()") {
|
||||||
|
JsonDocument doc1, doc2;
|
||||||
|
doc1["b"] = "c";
|
||||||
|
doc2["a"].shallowCopy(doc1);
|
||||||
|
|
||||||
|
REQUIRE(doc2.as<std::string>() == "{\"a\":{\"b\":\"c\"}}");
|
||||||
|
}
|
@ -1,48 +1,32 @@
|
|||||||
# ArduinoJson - https://arduinojson.org
|
# ArduinoJson - https://arduinojson.org
|
||||||
# Copyright © 2014-2022, Benoit BLANCHON
|
# Copyright © 2014-2025, Benoit BLANCHON
|
||||||
# MIT License
|
# MIT License
|
||||||
|
|
||||||
macro(build_should_fail target)
|
macro(add_failing_build source_file)
|
||||||
|
get_filename_component(target ${source_file} NAME_WE)
|
||||||
|
|
||||||
|
add_executable(${target} ${source_file})
|
||||||
|
|
||||||
set_target_properties(${target}
|
set_target_properties(${target}
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
EXCLUDE_FROM_ALL TRUE
|
EXCLUDE_FROM_ALL TRUE
|
||||||
EXCLUDE_FROM_DEFAULT_BUILD TRUE
|
EXCLUDE_FROM_DEFAULT_BUILD TRUE
|
||||||
)
|
)
|
||||||
add_test(
|
add_test(
|
||||||
NAME
|
NAME ${target}
|
||||||
${target}
|
COMMAND ${CMAKE_COMMAND} --build . --target ${target} --config $<CONFIGURATION>
|
||||||
COMMAND
|
WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
|
||||||
${CMAKE_COMMAND} --build . --target ${target} --config $<CONFIGURATION>
|
|
||||||
WORKING_DIRECTORY
|
|
||||||
${CMAKE_BINARY_DIR}
|
|
||||||
)
|
)
|
||||||
set_tests_properties(${target}
|
set_tests_properties(${target}
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
WILL_FAIL TRUE
|
WILL_FAIL TRUE
|
||||||
LABELS "WillFail;Catch"
|
LABELS "WillFail"
|
||||||
)
|
)
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
|
add_failing_build(Issue978.cpp)
|
||||||
add_executable(Issue978 Issue978.cpp)
|
add_failing_build(read_long_long.cpp)
|
||||||
build_should_fail(Issue978)
|
add_failing_build(write_long_long.cpp)
|
||||||
|
add_failing_build(variant_as_char.cpp)
|
||||||
add_executable(Issue1189 Issue1189.cpp)
|
add_failing_build(assign_char.cpp)
|
||||||
build_should_fail(Issue1189)
|
add_failing_build(deserialize_object.cpp)
|
||||||
|
|
||||||
add_executable(read_long_long read_long_long.cpp)
|
|
||||||
set_property(TARGET read_long_long PROPERTY CXX_STANDARD 11)
|
|
||||||
build_should_fail(read_long_long)
|
|
||||||
|
|
||||||
add_executable(write_long_long write_long_long.cpp)
|
|
||||||
set_property(TARGET write_long_long PROPERTY CXX_STANDARD 11)
|
|
||||||
build_should_fail(write_long_long)
|
|
||||||
|
|
||||||
add_executable(delete_jsondocument delete_jsondocument.cpp)
|
|
||||||
build_should_fail(delete_jsondocument)
|
|
||||||
|
|
||||||
add_executable(variant_as_char variant_as_char.cpp)
|
|
||||||
build_should_fail(variant_as_char)
|
|
||||||
|
|
||||||
add_executable(assign_char assign_char.cpp)
|
|
||||||
build_should_fail(assign_char)
|
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
|
||||||
// MIT License
|
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
|
||||||
|
|
||||||
// a function should not be able to get a JsonDocument by value
|
|
||||||
void f(JsonDocument) {}
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
DynamicJsonDocument doc(1024);
|
|
||||||
f(doc);
|
|
||||||
}
|
|
@ -1,5 +1,5 @@
|
|||||||
// ArduinoJson - https://arduinojson.org
|
// ArduinoJson - https://arduinojson.org
|
||||||
// Copyright © 2014-2022, Benoit BLANCHON
|
// Copyright © 2014-2025, Benoit BLANCHON
|
||||||
// MIT License
|
// MIT License
|
||||||
|
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
@ -8,6 +8,6 @@ struct Stream {};
|
|||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
Stream* stream = 0;
|
Stream* stream = 0;
|
||||||
DynamicJsonDocument doc(1024);
|
JsonDocument doc;
|
||||||
deserializeJson(doc, stream);
|
deserializeJson(doc, stream);
|
||||||
}
|
}
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user