Compare commits
590 Commits
upgrade/c+
...
master
Author | SHA1 | Date | |
---|---|---|---|
![]() |
d6d850ba6e | ||
![]() |
63baa62f70 | ||
![]() |
8bd89b7fc0 | ||
![]() |
8c9e447fd5 | ||
![]() |
fa145ac838 | ||
![]() |
7880596b03 | ||
![]() |
f3f8e63448 | ||
![]() |
29671fa5cd | ||
![]() |
077f714e05 | ||
![]() |
61b3f4a34d | ||
![]() |
d382b3f55a | ||
![]() |
82a0c503ce | ||
![]() |
f3d1541e44 | ||
![]() |
c92a7e529b | ||
![]() |
ca86ac12c8 | ||
![]() |
fca803220b | ||
![]() |
70e8518a32 | ||
![]() |
6c41f9bb3f | ||
![]() |
5c7c874f72 | ||
![]() |
9761fdf4da | ||
![]() |
1425705a2a | ||
![]() |
d2809156bc | ||
![]() |
06e2fc95a1 | ||
![]() |
c4b77f1942 | ||
![]() |
ae0bb4929c | ||
![]() |
00c88167ce | ||
![]() |
1f25ebc90a | ||
![]() |
5bc79f9d0a | ||
![]() |
d815fabc28 | ||
![]() |
88223c56b8 | ||
![]() |
5fcbcda76f | ||
![]() |
c7d9c2cedd | ||
![]() |
5452ae4038 | ||
![]() |
baf7ec23d8 | ||
![]() |
a687ddeb85 | ||
![]() |
540a9a0f30 | ||
![]() |
d6f2f49b6d | ||
![]() |
247483c538 | ||
![]() |
418873f25e | ||
![]() |
d8dc0e6f41 | ||
![]() |
37bc0f4c10 | ||
![]() |
ffead570b2 | ||
![]() |
5138ae74fc | ||
![]() |
e0d1250645 | ||
![]() |
dc6aab3d92 | ||
![]() |
d5267c63a9 | ||
![]() |
baded8330f | ||
![]() |
f3c8c70c81 | ||
![]() |
295c5ba0f5 | ||
![]() |
dd1c12f624 | ||
![]() |
1818600e50 | ||
![]() |
870227ff5e | ||
![]() |
a9e51c09cc | ||
![]() |
be3cc19fac | ||
![]() |
37f402aca7 | ||
![]() |
6f44b98fe9 | ||
![]() |
a5c939bec9 | ||
![]() |
88ce3fe5d3 | ||
![]() |
59c716ce23 | ||
![]() |
5928ad75c6 | ||
![]() |
203b9d740d | ||
![]() |
75c3fd1fc3 | ||
![]() |
e803ba5f8a | ||
![]() |
c3ff38865e | ||
![]() |
94a731aad0 | ||
![]() |
effd55d1ce | ||
![]() |
aacca52eec | ||
![]() |
4cab85cb19 | ||
![]() |
54dc915661 | ||
![]() |
612bf702ba | ||
![]() |
6f6c74b723 | ||
![]() |
48b105405a | ||
![]() |
3908b0e9ee | ||
![]() |
3cc32b6727 | ||
![]() |
e39fa4b66a | ||
![]() |
c5eaa1544f | ||
![]() |
1d9cfdb17d | ||
![]() |
4b32621c61 | ||
![]() |
3b1c33c5d9 | ||
![]() |
f8c9481673 | ||
![]() |
78a2babe4d | ||
![]() |
0a977c1fd7 | ||
![]() |
29a63820fd | ||
![]() |
4f2beac029 | ||
![]() |
529d8fea3d | ||
![]() |
d2cb6c10e1 | ||
![]() |
fccf328a54 | ||
![]() |
25b9126644 | ||
![]() |
2206d1a960 | ||
![]() |
1d8dec4b72 | ||
![]() |
995a5d0f60 | ||
![]() |
5ca7aee79b | ||
![]() |
73b878db37 | ||
![]() |
14a22de993 | ||
![]() |
0057d862af | ||
![]() |
82d3b078c3 | ||
![]() |
88e3eba8cf | ||
![]() |
c8935ef18a | ||
![]() |
fa5e642d4d | ||
![]() |
549fc3f860 | ||
![]() |
30f8cb1f6e | ||
![]() |
21359386be | ||
![]() |
861833bcfa | ||
![]() |
a0bec6a404 | ||
![]() |
5123704795 | ||
![]() |
d344caa08d | ||
![]() |
1ca634df1d | ||
![]() |
5f16a06f2f | ||
![]() |
566ac2078d | ||
![]() |
d191c2cf2a | ||
![]() |
4555e7c14c | ||
![]() |
ba5221ef97 | ||
![]() |
ce5de23874 | ||
![]() |
44fbe3940d | ||
![]() |
68f8a4bc7f | ||
![]() |
6451925430 | ||
![]() |
fcf74b0dfc | ||
![]() |
8c4d1bb0c6 | ||
![]() |
503f9e09f6 | ||
![]() |
8f9b0b8354 | ||
![]() |
84cdc9cae0 | ||
![]() |
34eb4be25b | ||
![]() |
9c9dcc8cab | ||
![]() |
aaa9890470 | ||
![]() |
6fdaac4a75 | ||
![]() |
0d3550e7ea | ||
![]() |
6ca99e7852 | ||
![]() |
9267c2bf8a | ||
![]() |
92722db3ab | ||
![]() |
6daa032144 | ||
![]() |
17a6d039d9 | ||
![]() |
ec9a5fae4b | ||
![]() |
e8f1c7f9e7 | ||
![]() |
4c1b1c1a5c | ||
![]() |
ed3f418d15 | ||
![]() |
c74ad5c8c2 | ||
![]() |
48b4623f3e | ||
![]() |
660b194ade | ||
![]() |
23e7e1f367 | ||
![]() |
1c96180fe6 | ||
![]() |
545417ef11 | ||
![]() |
f60a4bdfaf | ||
![]() |
1f9a43c9d2 | ||
![]() |
1b9e46b247 | ||
![]() |
4e77ada895 | ||
![]() |
98eaf85a90 | ||
![]() |
19f94e18f0 | ||
![]() |
3b5b5be574 | ||
![]() |
39644a980f | ||
![]() |
924d1ddad7 | ||
![]() |
79935a75c9 | ||
![]() |
9e2b0b4a4d | ||
![]() |
05ced985e3 | ||
![]() |
cc60c46e5f | ||
![]() |
b4ae40d401 | ||
![]() |
023263df7d | ||
![]() |
7c017bac6a | ||
![]() |
361530a1b6 | ||
![]() |
d1cf6f4ac7 | ||
![]() |
c83f41a5a3 | ||
![]() |
5d232db89e | ||
![]() |
949a33081f | ||
![]() |
b81904d554 | ||
![]() |
aa62b2fa80 | ||
![]() |
4327fb05a9 | ||
![]() |
e1e8b68b33 | ||
![]() |
91b501bbb2 | ||
![]() |
a9a8b0d0c4 | ||
![]() |
da8229b8f5 | ||
![]() |
8980203f7b | ||
![]() |
fe9f617f97 | ||
![]() |
580511c0bb | ||
![]() |
f85ca81066 | ||
![]() |
04117614cb | ||
![]() |
04386a8ebc | ||
![]() |
d445497870 | ||
![]() |
1af1943f85 | ||
![]() |
13bc3e2bb7 | ||
![]() |
ffe40def4a | ||
![]() |
bcb34695a5 | ||
![]() |
fd9b475446 | ||
![]() |
8546f9f089 | ||
![]() |
ffbbb94080 | ||
![]() |
c8cbc2e3a1 | ||
![]() |
a44d9540fb | ||
![]() |
fd36fc04b2 | ||
![]() |
b48948822a | ||
![]() |
30928a04e1 | ||
![]() |
3ada0c11be | ||
![]() |
90b2b9cbbf | ||
![]() |
7ddd035442 | ||
![]() |
38ca0998fd | ||
![]() |
29a3c5263b | ||
![]() |
827517f8cf | ||
![]() |
6d2ef66bbb | ||
![]() |
7ebf47e31c | ||
![]() |
2ebdd50e08 | ||
![]() |
d949740cd9 | ||
![]() |
16e9d52204 | ||
![]() |
cad5cab976 | ||
![]() |
9e959f7fd6 | ||
![]() |
0e434aa73b | ||
![]() |
2963e52fc6 | ||
![]() |
7c44390606 | ||
![]() |
45b588c654 | ||
![]() |
5124ddf575 | ||
![]() |
0f0bd685d9 | ||
![]() |
f15cb72f94 | ||
![]() |
75f518859f | ||
![]() |
b5e3e5e69b | ||
![]() |
3cbdcf999f | ||
![]() |
cd7341930e | ||
![]() |
25b98c87db | ||
![]() |
5df7de2b15 | ||
![]() |
089c3056cf | ||
![]() |
d05e11aecd | ||
![]() |
310fcd6fa1 | ||
![]() |
81894eeba6 | ||
![]() |
9eff7be9cd | ||
![]() |
82c37ce32d | ||
![]() |
c70bc39751 | ||
![]() |
eb4658f940 | ||
![]() |
03f07ab8c7 | ||
![]() |
100b590094 | ||
![]() |
cb42dceb87 | ||
![]() |
8cec8ce560 | ||
![]() |
537072e610 | ||
![]() |
c546e67995 | ||
![]() |
8745391ad4 | ||
![]() |
4f82aff8fd | ||
![]() |
9440869743 | ||
![]() |
3c1187e150 | ||
![]() |
349b04bf28 | ||
![]() |
b0902a4142 | ||
![]() |
4247bc50c5 | ||
![]() |
23787bdfa4 | ||
![]() |
8a109071a5 | ||
![]() |
43d4e071df | ||
![]() |
7d9a23d03f | ||
![]() |
861832ec27 | ||
![]() |
2633599458 | ||
![]() |
1a004f0164 | ||
![]() |
ed2d03d811 | ||
![]() |
42bd87d9b7 | ||
![]() |
dd663c7eb4 | ||
![]() |
34711b5307 | ||
![]() |
b71586b3ca | ||
![]() |
3627377d49 | ||
![]() |
5ebfd54163 | ||
![]() |
f85f990e3e | ||
![]() |
f55e29068a | ||
![]() |
a768af85ee | ||
![]() |
872e31cc8d | ||
![]() |
0536323882 | ||
![]() |
43eece8628 | ||
![]() |
3e82cf45a6 | ||
![]() |
4a3149649e | ||
![]() |
34e90e9aa9 | ||
![]() |
c9582cc4fd | ||
![]() |
5efd5b8c95 | ||
![]() |
0865e160cb | ||
![]() |
3b6c3b61c0 | ||
![]() |
4124cdaa4a | ||
![]() |
37d9196a4e | ||
![]() |
f34a47ae24 | ||
![]() |
9139a21adc | ||
![]() |
398bae57a8 | ||
![]() |
d4ec7eb241 | ||
![]() |
efe7824bbe | ||
![]() |
fa71d1012d | ||
![]() |
8e44c94c7c | ||
![]() |
9ed6ff829b | ||
![]() |
e77513dc73 | ||
![]() |
c22906d775 | ||
![]() |
eb308dcad2 | ||
![]() |
e196eadcaa | ||
![]() |
464c122b40 | ||
![]() |
f9073574d3 | ||
![]() |
9305da45dc | ||
![]() |
a0bbbf1729 | ||
![]() |
83067220bc | ||
![]() |
893b133444 | ||
![]() |
8e2ee12b18 | ||
![]() |
c43f7b369e | ||
![]() |
e965e2794b | ||
![]() |
04904c0947 | ||
![]() |
9f90e4e9e1 | ||
![]() |
51ca9c4923 | ||
![]() |
c8ab735348 | ||
![]() |
72b3d1bf0e | ||
![]() |
d3fcb66d3a | ||
![]() |
f5909c3d78 | ||
![]() |
5ad81d67ea | ||
![]() |
1362c7666d | ||
![]() |
c4026c08c8 | ||
![]() |
360b8bc3e2 | ||
![]() |
96f40d9adc | ||
![]() |
a29e115a62 | ||
![]() |
60dbe5a42d | ||
![]() |
a3cb48a341 | ||
![]() |
1f3b42c175 | ||
![]() |
360710d2f0 | ||
![]() |
644a22c5bb | ||
![]() |
ff90feaf85 | ||
![]() |
2121aa2ed7 | ||
![]() |
091a6c5401 | ||
![]() |
f22e423677 | ||
![]() |
1c31d9c83e | ||
![]() |
3756872529 | ||
![]() |
fe9c959bf0 | ||
![]() |
756abe34d5 | ||
![]() |
23766e61c3 | ||
![]() |
11e50dec41 | ||
![]() |
7999ccb215 | ||
![]() |
0fe2d0a0fe | ||
![]() |
ccce839881 | ||
![]() |
b0971c0f67 | ||
![]() |
9c06340f3a | ||
![]() |
afbfd13606 | ||
![]() |
e4ec88c666 | ||
![]() |
782299112b | ||
![]() |
61c2480d89 | ||
![]() |
b6f17692e9 | ||
![]() |
e3a3bfc868 | ||
![]() |
79ea192032 | ||
![]() |
8336f046b7 | ||
![]() |
1f6ec24a33 | ||
![]() |
f2a3bad3e2 | ||
![]() |
82b36dc847 | ||
![]() |
cd0c44af60 | ||
![]() |
871c4e62cf | ||
![]() |
6750837854 | ||
![]() |
ac85d44197 | ||
![]() |
c33bb0b726 | ||
![]() |
7c153416bc | ||
![]() |
ad3a2e99eb | ||
![]() |
e0cf16d3e9 | ||
![]() |
c8980072a5 | ||
![]() |
7ee7a25887 | ||
![]() |
a7f0aab600 | ||
![]() |
53f1c5bb80 | ||
![]() |
7db67c6207 | ||
![]() |
461294f423 | ||
![]() |
eec798bfc3 | ||
![]() |
bfae557aeb | ||
![]() |
5a92ebd98a | ||
![]() |
8aa2430950 | ||
![]() |
8efb5b9d71 | ||
![]() |
d8d7955702 | ||
![]() |
8740574ae3 | ||
![]() |
8102f5eaad | ||
![]() |
c23afaeac0 | ||
![]() |
8be1f819d9 | ||
![]() |
a1616903a6 | ||
![]() |
2cfafe4c9f | ||
![]() |
66dddb3b19 | ||
![]() |
a8b7f929f6 | ||
![]() |
02cd29c57b | ||
![]() |
676c2483ac | ||
![]() |
ebabfd8807 | ||
![]() |
da9e321330 | ||
![]() |
eec9d34ead | ||
![]() |
f000e76ba4 | ||
![]() |
f48823fe73 | ||
![]() |
8459fc8dbb | ||
![]() |
3e3a716468 | ||
![]() |
b794224b18 | ||
![]() |
2487d2bf79 | ||
![]() |
ba1ed0f6ee | ||
![]() |
1e4475b438 | ||
![]() |
62a49a2d5a | ||
![]() |
1d5fdbad80 | ||
![]() |
6c5be5b7df | ||
![]() |
b4e066a37f | ||
![]() |
61311f5912 | ||
![]() |
4547dc8e6a | ||
![]() |
0e9ae33f64 | ||
![]() |
7977612e0b | ||
![]() |
bbb6a9e90c | ||
![]() |
f5889b08ea | ||
![]() |
5b2f4e63a7 | ||
![]() |
a7f05bf696 | ||
![]() |
8b6c072ff5 | ||
![]() |
00a9077dd6 | ||
![]() |
73604e370f | ||
![]() |
1bc9748755 | ||
![]() |
dd2c582179 | ||
![]() |
fffad65480 | ||
![]() |
8196149b2b | ||
![]() |
10c78203ba | ||
![]() |
a7ea96afa9 | ||
![]() |
442cf87fcc | ||
![]() |
6e0a5bfa83 | ||
![]() |
6fb5120b8c | ||
![]() |
c600d817ba | ||
![]() |
cdf377e071 | ||
![]() |
f4fa967991 | ||
![]() |
0f18869276 | ||
![]() |
ffd940b2b5 | ||
![]() |
149439a25d | ||
![]() |
673ef066fb | ||
![]() |
b37107853a | ||
![]() |
3cf70659fa | ||
![]() |
209de449c9 | ||
![]() |
eadfa053f6 | ||
![]() |
6611aa731c | ||
![]() |
379009b31f | ||
![]() |
a1db6278ac | ||
![]() |
4268dd025b | ||
![]() |
d53880cf1e | ||
![]() |
b3ddb4511c | ||
![]() |
e30951a032 | ||
![]() |
f4b9748e1f | ||
![]() |
bf1e1b77c8 | ||
![]() |
d75fb9b64e | ||
![]() |
047e5eef6d | ||
![]() |
af602d5535 | ||
![]() |
40b2d0ff13 | ||
![]() |
266194f928 | ||
![]() |
4ce3c460e5 | ||
![]() |
0a87d2f3d6 | ||
![]() |
c16473eb94 | ||
![]() |
d4c7614d80 | ||
![]() |
953ec517d4 | ||
![]() |
8d49496177 | ||
![]() |
9e17fa776c | ||
![]() |
9ddd26f1e2 | ||
![]() |
b3741bbd3c | ||
![]() |
fe4234cd39 | ||
![]() |
c979ed7472 | ||
![]() |
511c337ee3 | ||
![]() |
70d9f118d8 | ||
![]() |
4cb368cdb1 | ||
![]() |
5860524bdd | ||
![]() |
458a9d8950 | ||
![]() |
f20f8b01be | ||
![]() |
e304472638 | ||
![]() |
fbd0478864 | ||
![]() |
b6d6f09fd7 | ||
![]() |
89dbf89830 | ||
![]() |
2ba2473489 | ||
![]() |
f6d9acdd69 | ||
![]() |
f79419687a | ||
![]() |
d6ba042e1e | ||
![]() |
711705df10 | ||
![]() |
833966f47b | ||
![]() |
39cdaa6b84 | ||
![]() |
b331958381 | ||
![]() |
cfac5bb769 | ||
![]() |
8d7239d1a4 | ||
![]() |
c1a52490b1 | ||
![]() |
33d20fa91a | ||
![]() |
8fd752f9cd | ||
![]() |
83ef1e72c2 | ||
![]() |
aa8f501388 | ||
![]() |
38d335a267 | ||
![]() |
5b832de199 | ||
![]() |
e5ec2b2ef8 | ||
![]() |
5339b455c0 | ||
![]() |
6f5706a945 | ||
![]() |
e7ac2b26dd | ||
![]() |
75faf9ac1a | ||
![]() |
08a1c41d1b | ||
![]() |
8073c3026a | ||
![]() |
2c61b336bc | ||
![]() |
466722b25e | ||
![]() |
4c9280728a | ||
![]() |
8e56967c83 | ||
![]() |
7913eda1e6 | ||
![]() |
251cfa2c9c | ||
![]() |
fab88ecd04 | ||
![]() |
8c059b5b2e | ||
![]() |
fc27b45d9f | ||
![]() |
ecf0174a55 | ||
![]() |
9907721a69 | ||
![]() |
ccd7e5c14a | ||
![]() |
7c18321138 | ||
![]() |
5443d566a7 | ||
![]() |
a4a8e58ba1 | ||
![]() |
8fd3e2d5e2 | ||
![]() |
af28882a6f | ||
![]() |
016e3570aa | ||
![]() |
fcf0b5d821 | ||
![]() |
b4b69a2cc1 | ||
![]() |
d3b99e6dc1 | ||
![]() |
dfa7e5e084 | ||
![]() |
84bf6b87f1 | ||
![]() |
6308b4feaf | ||
![]() |
d7840cd265 | ||
![]() |
4718d5e813 | ||
![]() |
b4be3b059a | ||
![]() |
9051fc644d | ||
![]() |
9df8f9f113 | ||
![]() |
ea65c1b9ba | ||
![]() |
339adbbe2d | ||
![]() |
579dea8fad | ||
![]() |
665eb969ed | ||
![]() |
939567d361 | ||
![]() |
635add84d7 | ||
![]() |
5385584f6f | ||
![]() |
16195cea2a | ||
![]() |
a818232e77 | ||
![]() |
741dfe37ae | ||
![]() |
e4acd6e5dc | ||
![]() |
452238b523 | ||
![]() |
6c8b29e91b | ||
![]() |
287501d665 | ||
![]() |
e1e19a6d06 | ||
![]() |
382d6bf54a | ||
![]() |
e40c3edc31 | ||
![]() |
a2f4f2bf8e | ||
![]() |
22aca36d35 | ||
![]() |
18ec884ba8 | ||
![]() |
7853e926c2 | ||
![]() |
c7b464b91f | ||
![]() |
0413d0e85c | ||
![]() |
2a4a82315b | ||
![]() |
36a2c9783f | ||
![]() |
0fbe8c3ecd | ||
![]() |
806c89edb3 | ||
![]() |
801c3c782e | ||
![]() |
66c05937b5 | ||
![]() |
ab6c5beaf8 | ||
![]() |
d2e972cfd1 | ||
![]() |
c12d5ed6b7 | ||
![]() |
c2f44f5fcb | ||
![]() |
74b2834502 | ||
![]() |
8a4b34ef6a | ||
![]() |
cf0264be45 | ||
![]() |
370ee1e876 | ||
![]() |
b7807db42f | ||
![]() |
db5874d677 | ||
![]() |
fff69b0cfd | ||
![]() |
6136f7df35 | ||
![]() |
1a5072c153 | ||
![]() |
65200eba50 | ||
![]() |
70736c9b1d | ||
![]() |
d031afe364 | ||
![]() |
81b62348b7 | ||
![]() |
eff3b2014b | ||
![]() |
c06fed6b56 | ||
![]() |
f8c5cd9552 | ||
![]() |
6673e1a786 | ||
![]() |
49ba072f3a | ||
![]() |
8abf9960a0 | ||
![]() |
f0e374ea23 | ||
![]() |
819b7cb361 | ||
![]() |
4d9b1a0b83 | ||
![]() |
1ccdc17df5 | ||
![]() |
b95daa3041 | ||
![]() |
36972bf9ea | ||
![]() |
4e646235d2 | ||
![]() |
b4f740ce18 | ||
![]() |
19bbd82c55 | ||
![]() |
067c21b647 | ||
![]() |
22abdf8dbe | ||
![]() |
7dd6eb5182 | ||
![]() |
cbb5380527 | ||
![]() |
ae2ea3df10 | ||
![]() |
6ff1ebfa98 | ||
![]() |
3f45df1025 | ||
![]() |
eb875d1af5 | ||
![]() |
bee2c27d78 | ||
![]() |
b3881bd1fc | ||
![]() |
1c35482ecf | ||
![]() |
3998f7ed75 | ||
![]() |
8f4a1d2932 | ||
![]() |
1b1164f91d | ||
![]() |
6a0b7afd88 | ||
![]() |
bb8c4a03c8 | ||
![]() |
b22e186e77 | ||
![]() |
b56f11207c | ||
![]() |
839d378680 | ||
![]() |
1985662045 | ||
![]() |
08d3467faa | ||
![]() |
240f71cbce | ||
![]() |
b2ceb30e30 | ||
![]() |
a35063dfd6 | ||
![]() |
56ae2174c0 | ||
![]() |
c6c9babb5e | ||
![]() |
42d8c163b7 | ||
![]() |
9d2bcc7a70 | ||
![]() |
e235c9cab4 | ||
![]() |
eff6131087 | ||
![]() |
bc7b9cdd2e | ||
![]() |
36bcfaecee | ||
![]() |
98b3f2af52 | ||
![]() |
7629ff4032 | ||
![]() |
ce8f053359 | ||
![]() |
56af701ade |
9
.git-blame-ignore-revs
Normal file
9
.git-blame-ignore-revs
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# Massive EOL normalization & 'svn:eol-style native' flag setting for all txt/conf/h/c files.
|
||||||
|
# https://github.com/rathena/rathena/commit/637ae9a4dcde0d5885a18841d2f3875e06893c30
|
||||||
|
637ae9a4dcde0d5885a18841d2f3875e06893c30
|
||||||
|
# Applied AStyle code formating as discussed on tid:74602.
|
||||||
|
# https://github.com/rathena/rathena/commit/a7c32653f70bd420bdf5a621acdf3aea5c6e6002
|
||||||
|
a7c32653f70bd420bdf5a621acdf3aea5c6e6002
|
||||||
|
# Undid r16968: SVN Replaced with source:/trunk/src/@16966 (tid:74924).
|
||||||
|
# https://github.com/rathena/rathena/commit/a2bdc47dafb32f6d18ed350d8bbe79b8f679a049
|
||||||
|
a2bdc47dafb32f6d18ed350d8bbe79b8f679a049
|
8
.github/workflows/analysis_codeql.yml
vendored
8
.github/workflows/analysis_codeql.yml
vendored
@ -38,11 +38,11 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
# Initializes the CodeQL tools for scanning.
|
# Initializes the CodeQL tools for scanning.
|
||||||
- name: Initialize CodeQL
|
- name: Initialize CodeQL
|
||||||
uses: github/codeql-action/init@v2
|
uses: github/codeql-action/init@v3
|
||||||
with:
|
with:
|
||||||
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ]
|
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ]
|
||||||
# Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support
|
# Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support
|
||||||
@ -74,7 +74,7 @@ jobs:
|
|||||||
#- name: Autobuild
|
#- name: Autobuild
|
||||||
# uses: github/codeql-action/autobuild@v2
|
# uses: github/codeql-action/autobuild@v2
|
||||||
|
|
||||||
# ✏️ If the Autobuild fails above, remove it and uncomment the following
|
# ?? If the Autobuild fails above, remove it and uncomment the following
|
||||||
# three lines and modify them (or add more) to build your code if your
|
# three lines and modify them (or add more) to build your code if your
|
||||||
# project uses a compiled language
|
# project uses a compiled language
|
||||||
- name: Command - configure
|
- name: Command - configure
|
||||||
@ -89,4 +89,4 @@ jobs:
|
|||||||
run: make server
|
run: make server
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@v2
|
uses: github/codeql-action/analyze@v3
|
||||||
|
2
.github/workflows/build_servers_clang.yml
vendored
2
.github/workflows/build_servers_clang.yml
vendored
@ -34,7 +34,7 @@ jobs:
|
|||||||
clang: ['6.0', '7', '8', '9', '10', '11'] #, '12', '13']
|
clang: ['6.0', '7', '8', '9', '10', '11'] #, '12', '13']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Set up Clang
|
- name: Set up Clang
|
||||||
uses: egor-tensin/setup-clang@v1
|
uses: egor-tensin/setup-clang@v1
|
||||||
|
4
.github/workflows/build_servers_cmake.yml
vendored
4
.github/workflows/build_servers_cmake.yml
vendored
@ -18,6 +18,8 @@ on:
|
|||||||
# This workflow should run when a file in a source directory has been modified.
|
# This workflow should run when a file in a source directory has been modified.
|
||||||
- 'src/**'
|
- 'src/**'
|
||||||
- '3rdparty/**'
|
- '3rdparty/**'
|
||||||
|
# This workflow should run whenever a CMake related file has been modified
|
||||||
|
- '**/CMakeLists.txt'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
@ -32,7 +34,7 @@ jobs:
|
|||||||
os: [ubuntu-latest]
|
os: [ubuntu-latest]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
# Install latest CMake.
|
# Install latest CMake.
|
||||||
- uses: lukka/get-cmake@latest
|
- uses: lukka/get-cmake@latest
|
||||||
|
14
.github/workflows/build_servers_gcc.yml
vendored
14
.github/workflows/build_servers_gcc.yml
vendored
@ -31,10 +31,14 @@ jobs:
|
|||||||
# Available: ubuntu-22.04, ubuntu-20.04
|
# Available: ubuntu-22.04, ubuntu-20.04
|
||||||
os: [ubuntu-latest]
|
os: [ubuntu-latest]
|
||||||
# Older versions of GCC are not available via unaltered aptitude repo lists.
|
# Older versions of GCC are not available via unaltered aptitude repo lists.
|
||||||
gcc: ['9', '10', '11']
|
gcc: ['9', '10', '11', '12']
|
||||||
|
# GCC 13 was removed from 22.04, include it as a separate job
|
||||||
|
include:
|
||||||
|
- os: ubuntu-24.04
|
||||||
|
gcc: 13
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Update & Install packages
|
- name: Update & Install packages
|
||||||
# Ubuntu runners already have most of the packages rAthena requires to build.
|
# Ubuntu runners already have most of the packages rAthena requires to build.
|
||||||
@ -45,8 +49,10 @@ jobs:
|
|||||||
|
|
||||||
- name: Command - configure
|
- name: Command - configure
|
||||||
env:
|
env:
|
||||||
CONFIGURE_FLAGS: 'CC=gcc-${{ matrix.gcc }} CXX=g++-${{ matrix.gcc }} --enable-buildbot=yes'
|
CONFIGURE_FLAGS: 'CC=gcc-${{ matrix.gcc }} CXX=g++-${{ matrix.gcc }}'
|
||||||
run: ./configure $CONFIGURE_FLAGS
|
# -Werror: to treat all warnings as errors
|
||||||
|
# -Wno-error=builtin-declaration-mismatch: otherwise ./configure checks fail
|
||||||
|
run: ./configure $CONFIGURE_FLAGS --enable-buildbot=yes CXXFLAGS='-Werror -Wno-error=builtin-declaration-mismatch'
|
||||||
|
|
||||||
- name: Command - make clean
|
- name: Command - make clean
|
||||||
run: make clean
|
run: make clean
|
||||||
|
2
.github/workflows/build_servers_modes.yml
vendored
2
.github/workflows/build_servers_modes.yml
vendored
@ -36,7 +36,7 @@ jobs:
|
|||||||
mode: ['PRE','RE']
|
mode: ['PRE','RE']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
||||||
- name: Variable Parsing - PRE
|
- name: Variable Parsing - PRE
|
||||||
|
8
.github/workflows/build_servers_msbuild.yml
vendored
8
.github/workflows/build_servers_msbuild.yml
vendored
@ -34,15 +34,15 @@ jobs:
|
|||||||
mode: ['PRE', 'RE']
|
mode: ['PRE', 'RE']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Add msbuild to PATH
|
- name: Add msbuild to PATH
|
||||||
uses: microsoft/setup-msbuild@v1.1
|
uses: microsoft/setup-msbuild@v2
|
||||||
|
|
||||||
- name: Build solution in Debug
|
- name: Build solution in Debug
|
||||||
if: ${{ matrix.mode == 'PRE' }}
|
if: ${{ matrix.mode == 'PRE' }}
|
||||||
run: msbuild rAthena.sln -t:rebuild -property:Configuration=Debug /p:DefineConstants="BUILDBOT%3BPRERE"
|
run: msbuild rAthena.sln -t:rebuild -property:Configuration=Debug /p:DefineConstants="BUILDBOT%3BPRERE" /warnaserror
|
||||||
|
|
||||||
- name: Build solution in Debug
|
- name: Build solution in Debug
|
||||||
if: ${{ matrix.mode == 'RE' }}
|
if: ${{ matrix.mode == 'RE' }}
|
||||||
run: msbuild rAthena.sln -t:rebuild -property:Configuration=Debug /p:DefineConstants="BUILDBOT"
|
run: msbuild rAthena.sln -t:rebuild -property:Configuration=Debug /p:DefineConstants="BUILDBOT" /warnaserror
|
||||||
|
@ -38,7 +38,7 @@ jobs:
|
|||||||
packetver: ['20211103', '20200902', '20200401', '20180620', '20151104']
|
packetver: ['20211103', '20200902', '20200401', '20180620', '20151104']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
||||||
- name: Variable Parsing - PRE
|
- name: Variable Parsing - PRE
|
||||||
|
2
.github/workflows/build_servers_vip.yml
vendored
2
.github/workflows/build_servers_vip.yml
vendored
@ -36,7 +36,7 @@ jobs:
|
|||||||
mode: ['PRE', 'RE']
|
mode: ['PRE', 'RE']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
||||||
- name: Variable Parsing - PRE
|
- name: Variable Parsing - PRE
|
||||||
|
2
.github/workflows/npc_db_validation.yml
vendored
2
.github/workflows/npc_db_validation.yml
vendored
@ -39,7 +39,7 @@ jobs:
|
|||||||
mode: ['PRE', 'RE']
|
mode: ['PRE', 'RE']
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
# A simple 'yes' and 'no' can be confusing, so we use names to display in the current job then convert them for use in the compiler.
|
||||||
- name: Variable Parsing - PRE
|
- name: Variable Parsing - PRE
|
||||||
|
1
3rdparty/README.txt
vendored
1
3rdparty/README.txt
vendored
@ -7,3 +7,4 @@ mysql - library for MySQL Community Server (http://www.mysql.com)
|
|||||||
pcre - library for Perl Compatible Regular Expressions (http://www.pcre.org)
|
pcre - library for Perl Compatible Regular Expressions (http://www.pcre.org)
|
||||||
zlib - library for DEFLATE lossless compression algorithm (http://www.zlib.net)
|
zlib - library for DEFLATE lossless compression algorithm (http://www.zlib.net)
|
||||||
json - library for nlohmann json (https://github.com/nlohmann/json/tree/4b2c8ce6bcfe7f39f2bb9e680c1e7a4d67c2dd48)
|
json - library for nlohmann json (https://github.com/nlohmann/json/tree/4b2c8ce6bcfe7f39f2bb9e680c1e7a4d67c2dd48)
|
||||||
|
yaml-cpp - library for yaml (https://github.com/jbeder/yaml-cpp/tree/0e6e28d1a38224fc8172fae0109ea7f673c096db)
|
||||||
|
4
3rdparty/httplib/httplib.vcxproj
vendored
4
3rdparty/httplib/httplib.vcxproj
vendored
@ -98,6 +98,7 @@
|
|||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -112,6 +113,7 @@
|
|||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -128,6 +130,7 @@
|
|||||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -146,6 +149,7 @@
|
|||||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
|
4
3rdparty/libconfig/libconfig.vcxproj
vendored
4
3rdparty/libconfig/libconfig.vcxproj
vendored
@ -108,6 +108,7 @@
|
|||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -122,6 +123,7 @@
|
|||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_DEBUG;_LIB;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -138,6 +140,7 @@
|
|||||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;WIN32;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
@ -156,6 +159,7 @@
|
|||||||
<IntrinsicFunctions>true</IntrinsicFunctions>
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YY_USE_CONST;LIBCONFIG_STATIC;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;NDEBUG;_LIB;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
|
9
3rdparty/libconfig/scanner.c
vendored
9
3rdparty/libconfig/scanner.c
vendored
@ -2,6 +2,11 @@
|
|||||||
|
|
||||||
#line 4 "scanner.c"
|
#line 4 "scanner.c"
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma warning( push )
|
||||||
|
#pragma warning( disable : 4267 )
|
||||||
|
#endif
|
||||||
|
|
||||||
#define YY_INT_ALIGNED short int
|
#define YY_INT_ALIGNED short int
|
||||||
|
|
||||||
/* A lexical scanner generated by flex */
|
/* A lexical scanner generated by flex */
|
||||||
@ -2365,3 +2370,7 @@ void libconfig_yyfree (void * ptr , yyscan_t yyscanner)
|
|||||||
#define YYTABLES_NAME "yytables"
|
#define YYTABLES_NAME "yytables"
|
||||||
|
|
||||||
#line 192 "scanner.l"
|
#line 192 "scanner.l"
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma warning( pop )
|
||||||
|
#endif
|
||||||
|
4
3rdparty/rapidyaml/ryml.vcxproj
vendored
4
3rdparty/rapidyaml/ryml.vcxproj
vendored
@ -103,6 +103,7 @@
|
|||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;CMAKE_INTDIR="Debug";_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;CMAKE_INTDIR="Debug";_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<ObjectFileName>$(IntDir)</ObjectFileName>
|
<ObjectFileName>$(IntDir)</ObjectFileName>
|
||||||
<LanguageStandard>stdcpp17</LanguageStandard>
|
<LanguageStandard>stdcpp17</LanguageStandard>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ResourceCompile>
|
<ResourceCompile>
|
||||||
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;CMAKE_INTDIR=\"Debug\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;CMAKE_INTDIR=\"Debug\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
@ -138,6 +139,7 @@
|
|||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;CMAKE_INTDIR="Debug";_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;CMAKE_INTDIR="Debug";_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<ObjectFileName>$(IntDir)</ObjectFileName>
|
<ObjectFileName>$(IntDir)</ObjectFileName>
|
||||||
<LanguageStandard>stdcpp17</LanguageStandard>
|
<LanguageStandard>stdcpp17</LanguageStandard>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ResourceCompile>
|
<ResourceCompile>
|
||||||
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;CMAKE_INTDIR=\"Debug\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;CMAKE_INTDIR=\"Debug\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
@ -173,6 +175,7 @@
|
|||||||
<DebugInformationFormat>
|
<DebugInformationFormat>
|
||||||
</DebugInformationFormat>
|
</DebugInformationFormat>
|
||||||
<LanguageStandard>stdcpp17</LanguageStandard>
|
<LanguageStandard>stdcpp17</LanguageStandard>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ResourceCompile>
|
<ResourceCompile>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;CMAKE_INTDIR=\"Release\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;CMAKE_INTDIR=\"Release\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
@ -208,6 +211,7 @@
|
|||||||
<DebugInformationFormat>
|
<DebugInformationFormat>
|
||||||
</DebugInformationFormat>
|
</DebugInformationFormat>
|
||||||
<LanguageStandard>stdcpp17</LanguageStandard>
|
<LanguageStandard>stdcpp17</LanguageStandard>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ResourceCompile>
|
<ResourceCompile>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;CMAKE_INTDIR=\"Release\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;CMAKE_INTDIR=\"Release\";%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
|
4
3rdparty/yaml-cpp/CMakeLists.txt
vendored
4
3rdparty/yaml-cpp/CMakeLists.txt
vendored
@ -21,6 +21,7 @@ set( YAML_HEADERS
|
|||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/ostream_wrapper.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/ostream_wrapper.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/null.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/null.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/noncopyable.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/noncopyable.h"
|
||||||
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/noexcept.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/mark.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/mark.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/exceptions.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/exceptions.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/eventhandler.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/eventhandler.h"
|
||||||
@ -30,6 +31,7 @@ set( YAML_HEADERS
|
|||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/emitterdef.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/emitterdef.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/emitfromevents.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/emitfromevents.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/dll.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/dll.h"
|
||||||
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/depthguard.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/binary.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/binary.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/anchor.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/anchor.h"
|
||||||
"${YAML_INCLUDE_DIRS}/yaml-cpp/node/type.h"
|
"${YAML_INCLUDE_DIRS}/yaml-cpp/node/type.h"
|
||||||
@ -46,6 +48,7 @@ set( YAML_HEADERS
|
|||||||
set( YAML_SOURCES
|
set( YAML_SOURCES
|
||||||
"${YAML_SOURCE_DIR}/binary.cpp"
|
"${YAML_SOURCE_DIR}/binary.cpp"
|
||||||
"${YAML_SOURCE_DIR}/convert.cpp"
|
"${YAML_SOURCE_DIR}/convert.cpp"
|
||||||
|
"${YAML_SOURCE_DIR}/depthguard.cpp"
|
||||||
"${YAML_SOURCE_DIR}/directives.cpp"
|
"${YAML_SOURCE_DIR}/directives.cpp"
|
||||||
"${YAML_SOURCE_DIR}/emit.cpp"
|
"${YAML_SOURCE_DIR}/emit.cpp"
|
||||||
"${YAML_SOURCE_DIR}/emitfromevents.cpp"
|
"${YAML_SOURCE_DIR}/emitfromevents.cpp"
|
||||||
@ -81,3 +84,4 @@ set( YAML_DEFINITIONS
|
|||||||
include_directories(${YAML_INCLUDE_DIRS} ${YAML_SOURCE_DIR})
|
include_directories(${YAML_INCLUDE_DIRS} ${YAML_SOURCE_DIR})
|
||||||
#message(STATUS "YAML_INCLUDE_DIRS : ${YAML_INCLUDE_DIRS}, YAML_SOURCE_DIR=${YAML_SOURCE_DIR}")
|
#message(STATUS "YAML_INCLUDE_DIRS : ${YAML_INCLUDE_DIRS}, YAML_SOURCE_DIR=${YAML_SOURCE_DIR}")
|
||||||
ADD_LIBRARY(${this_target} STATIC ${YAML_SOURCES} )
|
ADD_LIBRARY(${this_target} STATIC ${YAML_SOURCES} )
|
||||||
|
target_compile_definitions(${this_target} PUBLIC "-DYAML_CPP_STATIC_DEFINE")
|
||||||
|
2
3rdparty/yaml-cpp/Makefile.in
vendored
2
3rdparty/yaml-cpp/Makefile.in
vendored
@ -4,7 +4,7 @@ YAML_CPP_DIR_OBJ = $(YAML_CPP_OBJ:%=obj/%)
|
|||||||
YAML_CPP_H = $(shell find * -type f -name "*.h")
|
YAML_CPP_H = $(shell find * -type f -name "*.h")
|
||||||
YAML_CPP_AR = obj/yaml-cpp.a
|
YAML_CPP_AR = obj/yaml-cpp.a
|
||||||
|
|
||||||
CXXFLAG =-std=c++11
|
CXXFLAG =-std=c++17 -DYAML_CPP_STATIC_DEFINE
|
||||||
INC=-Iinclude
|
INC=-Iinclude
|
||||||
|
|
||||||
@SET_MAKE@
|
@SET_MAKE@
|
||||||
|
2
3rdparty/yaml-cpp/include/yaml-cpp/anchor.h
vendored
2
3rdparty/yaml-cpp/include/yaml-cpp/anchor.h
vendored
@ -10,7 +10,7 @@
|
|||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
typedef std::size_t anchor_t;
|
using anchor_t = std::size_t;
|
||||||
const anchor_t NullAnchor = 0;
|
const anchor_t NullAnchor = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
12
3rdparty/yaml-cpp/include/yaml-cpp/binary.h
vendored
12
3rdparty/yaml-cpp/include/yaml-cpp/binary.h
vendored
@ -19,9 +19,13 @@ YAML_CPP_API std::vector<unsigned char> DecodeBase64(const std::string &input);
|
|||||||
|
|
||||||
class YAML_CPP_API Binary {
|
class YAML_CPP_API Binary {
|
||||||
public:
|
public:
|
||||||
Binary() : m_unownedData(0), m_unownedSize(0) {}
|
|
||||||
Binary(const unsigned char *data_, std::size_t size_)
|
Binary(const unsigned char *data_, std::size_t size_)
|
||||||
: m_unownedData(data_), m_unownedSize(size_) {}
|
: m_data{}, m_unownedData(data_), m_unownedSize(size_) {}
|
||||||
|
Binary() : Binary(nullptr, 0) {}
|
||||||
|
Binary(const Binary &) = default;
|
||||||
|
Binary(Binary &&) = default;
|
||||||
|
Binary &operator=(const Binary &) = default;
|
||||||
|
Binary &operator=(Binary &&) = default;
|
||||||
|
|
||||||
bool owned() const { return !m_unownedData; }
|
bool owned() const { return !m_unownedData; }
|
||||||
std::size_t size() const { return owned() ? m_data.size() : m_unownedSize; }
|
std::size_t size() const { return owned() ? m_data.size() : m_unownedSize; }
|
||||||
@ -35,7 +39,7 @@ class YAML_CPP_API Binary {
|
|||||||
rhs.clear();
|
rhs.clear();
|
||||||
rhs.resize(m_unownedSize);
|
rhs.resize(m_unownedSize);
|
||||||
std::copy(m_unownedData, m_unownedData + m_unownedSize, rhs.begin());
|
std::copy(m_unownedData, m_unownedData + m_unownedSize, rhs.begin());
|
||||||
m_unownedData = 0;
|
m_unownedData = nullptr;
|
||||||
m_unownedSize = 0;
|
m_unownedSize = 0;
|
||||||
} else {
|
} else {
|
||||||
m_data.swap(rhs);
|
m_data.swap(rhs);
|
||||||
@ -62,6 +66,6 @@ class YAML_CPP_API Binary {
|
|||||||
const unsigned char *m_unownedData;
|
const unsigned char *m_unownedData;
|
||||||
std::size_t m_unownedSize;
|
std::size_t m_unownedSize;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // BASE64_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // BASE64_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -22,6 +22,7 @@ namespace YAML {
|
|||||||
template <class T>
|
template <class T>
|
||||||
class AnchorDict {
|
class AnchorDict {
|
||||||
public:
|
public:
|
||||||
|
AnchorDict() : m_data{} {}
|
||||||
void Register(anchor_t anchor, T value) {
|
void Register(anchor_t anchor, T value) {
|
||||||
if (anchor > m_data.size()) {
|
if (anchor > m_data.size()) {
|
||||||
m_data.resize(anchor);
|
m_data.resize(anchor);
|
||||||
@ -34,6 +35,6 @@ class AnchorDict {
|
|||||||
private:
|
private:
|
||||||
std::vector<T> m_data;
|
std::vector<T> m_data;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // ANCHORDICT_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // ANCHORDICT_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -15,10 +15,12 @@ class Parser;
|
|||||||
|
|
||||||
// GraphBuilderInterface
|
// GraphBuilderInterface
|
||||||
// . Abstraction of node creation
|
// . Abstraction of node creation
|
||||||
// . pParentNode is always NULL or the return value of one of the NewXXX()
|
// . pParentNode is always nullptr or the return value of one of the NewXXX()
|
||||||
// functions.
|
// functions.
|
||||||
class GraphBuilderInterface {
|
class GraphBuilderInterface {
|
||||||
public:
|
public:
|
||||||
|
virtual ~GraphBuilderInterface() = 0;
|
||||||
|
|
||||||
// Create and return a new node with a null value.
|
// Create and return a new node with a null value.
|
||||||
virtual void *NewNull(const Mark &mark, void *pParentNode) = 0;
|
virtual void *NewNull(const Mark &mark, void *pParentNode) = 0;
|
||||||
|
|
||||||
@ -71,9 +73,9 @@ class GraphBuilder : public GraphBuilderInterface {
|
|||||||
typedef typename Impl::Map Map;
|
typedef typename Impl::Map Map;
|
||||||
|
|
||||||
GraphBuilder(Impl &impl) : m_impl(impl) {
|
GraphBuilder(Impl &impl) : m_impl(impl) {
|
||||||
Map *pMap = NULL;
|
Map *pMap = nullptr;
|
||||||
Sequence *pSeq = NULL;
|
Sequence *pSeq = nullptr;
|
||||||
Node *pNode = NULL;
|
Node *pNode = nullptr;
|
||||||
|
|
||||||
// Type consistency checks
|
// Type consistency checks
|
||||||
pNode = pMap;
|
pNode = pMap;
|
||||||
|
77
3rdparty/yaml-cpp/include/yaml-cpp/depthguard.h
vendored
Normal file
77
3rdparty/yaml-cpp/include/yaml-cpp/depthguard.h
vendored
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
#ifndef DEPTH_GUARD_H_00000000000000000000000000000000000000000000000000000000
|
||||||
|
#define DEPTH_GUARD_H_00000000000000000000000000000000000000000000000000000000
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) || \
|
||||||
|
(defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || \
|
||||||
|
(__GNUC__ >= 4)) // GCC supports "pragma once" correctly since 3.4
|
||||||
|
#pragma once
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "exceptions.h"
|
||||||
|
|
||||||
|
namespace YAML {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The DeepRecursion class
|
||||||
|
* An exception class which is thrown by DepthGuard. Ideally it should be
|
||||||
|
* a member of DepthGuard. However, DepthGuard is a templated class which means
|
||||||
|
* that any catch points would then need to know the template parameters. It is
|
||||||
|
* simpler for clients to not have to know at the catch point what was the
|
||||||
|
* maximum depth.
|
||||||
|
*/
|
||||||
|
class DeepRecursion : public ParserException {
|
||||||
|
public:
|
||||||
|
virtual ~DeepRecursion() = default;
|
||||||
|
|
||||||
|
DeepRecursion(int depth, const Mark& mark_, const std::string& msg_);
|
||||||
|
|
||||||
|
// Returns the recursion depth when the exception was thrown
|
||||||
|
int depth() const {
|
||||||
|
return m_depth;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
int m_depth = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The DepthGuard class
|
||||||
|
* DepthGuard takes a reference to an integer. It increments the integer upon
|
||||||
|
* construction of DepthGuard and decrements the integer upon destruction.
|
||||||
|
*
|
||||||
|
* If the integer would be incremented past max_depth, then an exception is
|
||||||
|
* thrown. This is ideally geared toward guarding against deep recursion.
|
||||||
|
*
|
||||||
|
* @param max_depth
|
||||||
|
* compile-time configurable maximum depth.
|
||||||
|
*/
|
||||||
|
template <int max_depth = 2000>
|
||||||
|
class DepthGuard final {
|
||||||
|
public:
|
||||||
|
DepthGuard(int & depth_, const Mark& mark_, const std::string& msg_) : m_depth(depth_) {
|
||||||
|
++m_depth;
|
||||||
|
if ( max_depth <= m_depth ) {
|
||||||
|
throw DeepRecursion{m_depth, mark_, msg_};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DepthGuard(const DepthGuard & copy_ctor) = delete;
|
||||||
|
DepthGuard(DepthGuard && move_ctor) = delete;
|
||||||
|
DepthGuard & operator=(const DepthGuard & copy_assign) = delete;
|
||||||
|
DepthGuard & operator=(DepthGuard && move_assign) = delete;
|
||||||
|
|
||||||
|
~DepthGuard() {
|
||||||
|
--m_depth;
|
||||||
|
}
|
||||||
|
|
||||||
|
int current_depth() const {
|
||||||
|
return m_depth;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
int & m_depth;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace YAML
|
||||||
|
|
||||||
|
#endif // DEPTH_GUARD_H_00000000000000000000000000000000000000000000000000000000
|
80
3rdparty/yaml-cpp/include/yaml-cpp/dll.h
vendored
80
3rdparty/yaml-cpp/include/yaml-cpp/dll.h
vendored
@ -1,33 +1,61 @@
|
|||||||
#ifndef DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#ifndef DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
#define DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#define DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
|
||||||
#if defined(_MSC_VER) || \
|
// Definition YAML_CPP_STATIC_DEFINE using to building YAML-CPP as static
|
||||||
(defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || \
|
// library (definition created by CMake or defined manually)
|
||||||
(__GNUC__ >= 4)) // GCC supports "pragma once" correctly since 3.4
|
|
||||||
#pragma once
|
// Definition yaml_cpp_EXPORTS using to building YAML-CPP as dll/so library
|
||||||
|
// (definition created by CMake or defined manually)
|
||||||
|
|
||||||
|
#ifdef YAML_CPP_STATIC_DEFINE
|
||||||
|
# define YAML_CPP_API
|
||||||
|
# define YAML_CPP_NO_EXPORT
|
||||||
|
#else
|
||||||
|
# if defined(_MSC_VER) || defined(__MINGW32__) || defined(__MINGW64__)
|
||||||
|
# ifndef YAML_CPP_API
|
||||||
|
# ifdef yaml_cpp_EXPORTS
|
||||||
|
/* We are building this library */
|
||||||
|
# pragma message( "Defining YAML_CPP_API for DLL export" )
|
||||||
|
# define YAML_CPP_API __declspec(dllexport)
|
||||||
|
# else
|
||||||
|
/* We are using this library */
|
||||||
|
# pragma message( "Defining YAML_CPP_API for DLL import" )
|
||||||
|
# define YAML_CPP_API __declspec(dllimport)
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# ifndef YAML_CPP_NO_EXPORT
|
||||||
|
# define YAML_CPP_NO_EXPORT
|
||||||
|
# endif
|
||||||
|
# else /* No _MSC_VER */
|
||||||
|
# ifndef YAML_CPP_API
|
||||||
|
# ifdef yaml_cpp_EXPORTS
|
||||||
|
/* We are building this library */
|
||||||
|
# define YAML_CPP_API __attribute__((visibility("default")))
|
||||||
|
# else
|
||||||
|
/* We are using this library */
|
||||||
|
# define YAML_CPP_API __attribute__((visibility("default")))
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
# ifndef YAML_CPP_NO_EXPORT
|
||||||
|
# define YAML_CPP_NO_EXPORT __attribute__((visibility("hidden")))
|
||||||
|
# endif
|
||||||
|
# endif /* _MSC_VER */
|
||||||
|
#endif /* YAML_CPP_STATIC_DEFINE */
|
||||||
|
|
||||||
|
#ifndef YAML_CPP_DEPRECATED
|
||||||
|
# ifdef _MSC_VER
|
||||||
|
# define YAML_CPP_DEPRECATED __declspec(deprecated)
|
||||||
|
# else
|
||||||
|
# define YAML_CPP_DEPRECATED __attribute__ ((__deprecated__))
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// The following ifdef block is the standard way of creating macros which make
|
#ifndef YAML_CPP_DEPRECATED_EXPORT
|
||||||
// exporting from a DLL simpler. All files within this DLL are compiled with the
|
# define YAML_CPP_DEPRECATED_EXPORT YAML_CPP_API YAML_CPP_DEPRECATED
|
||||||
// yaml_cpp_EXPORTS symbol defined on the command line. This symbol should not
|
#endif
|
||||||
// be defined on any project that uses this DLL. This way any other project
|
|
||||||
// whose source files include this file see YAML_CPP_API functions as being
|
|
||||||
// imported from a DLL, whereas this DLL sees symbols defined with this macro as
|
|
||||||
// being exported.
|
|
||||||
#undef YAML_CPP_API
|
|
||||||
|
|
||||||
#ifdef YAML_CPP_DLL // Using or Building YAML-CPP DLL (definition defined
|
#ifndef YAML_CPP_DEPRECATED_NO_EXPORT
|
||||||
// manually)
|
# define YAML_CPP_DEPRECATED_NO_EXPORT YAML_CPP_NO_EXPORT YAML_CPP_DEPRECATED
|
||||||
#ifdef yaml_cpp_EXPORTS // Building YAML-CPP DLL (definition created by CMake
|
#endif
|
||||||
// or defined manually)
|
|
||||||
// #pragma message( "Defining YAML_CPP_API for DLL export" )
|
|
||||||
#define YAML_CPP_API __declspec(dllexport)
|
|
||||||
#else // yaml_cpp_EXPORTS
|
|
||||||
// #pragma message( "Defining YAML_CPP_API for DLL import" )
|
|
||||||
#define YAML_CPP_API __declspec(dllimport)
|
|
||||||
#endif // yaml_cpp_EXPORTS
|
|
||||||
#else // YAML_CPP_DLL
|
|
||||||
#define YAML_CPP_API
|
|
||||||
#endif // YAML_CPP_DLL
|
|
||||||
|
|
||||||
#endif // DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif /* DLL_H_62B23520_7C8E_11DE_8A39_0800200C9A66 */
|
||||||
|
@ -24,21 +24,21 @@ class EmitFromEvents : public EventHandler {
|
|||||||
public:
|
public:
|
||||||
EmitFromEvents(Emitter& emitter);
|
EmitFromEvents(Emitter& emitter);
|
||||||
|
|
||||||
virtual void OnDocumentStart(const Mark& mark);
|
void OnDocumentStart(const Mark& mark) override;
|
||||||
virtual void OnDocumentEnd();
|
void OnDocumentEnd() override;
|
||||||
|
|
||||||
virtual void OnNull(const Mark& mark, anchor_t anchor);
|
void OnNull(const Mark& mark, anchor_t anchor) override;
|
||||||
virtual void OnAlias(const Mark& mark, anchor_t anchor);
|
void OnAlias(const Mark& mark, anchor_t anchor) override;
|
||||||
virtual void OnScalar(const Mark& mark, const std::string& tag,
|
void OnScalar(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, const std::string& value);
|
anchor_t anchor, const std::string& value) override;
|
||||||
|
|
||||||
virtual void OnSequenceStart(const Mark& mark, const std::string& tag,
|
void OnSequenceStart(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, EmitterStyle::value style);
|
anchor_t anchor, EmitterStyle::value style) override;
|
||||||
virtual void OnSequenceEnd();
|
void OnSequenceEnd() override;
|
||||||
|
|
||||||
virtual void OnMapStart(const Mark& mark, const std::string& tag,
|
void OnMapStart(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, EmitterStyle::value style);
|
anchor_t anchor, EmitterStyle::value style) override;
|
||||||
virtual void OnMapEnd();
|
void OnMapEnd() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void BeginNode();
|
void BeginNode();
|
||||||
|
32
3rdparty/yaml-cpp/include/yaml-cpp/emitter.h
vendored
32
3rdparty/yaml-cpp/include/yaml-cpp/emitter.h
vendored
@ -7,16 +7,18 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
#include <limits>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <type_traits>
|
||||||
|
|
||||||
#include "yaml-cpp/binary.h"
|
#include "yaml-cpp/binary.h"
|
||||||
#include "yaml-cpp/dll.h"
|
#include "yaml-cpp/dll.h"
|
||||||
#include "yaml-cpp/emitterdef.h"
|
#include "yaml-cpp/emitterdef.h"
|
||||||
#include "yaml-cpp/emittermanip.h"
|
#include "yaml-cpp/emittermanip.h"
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
#include "yaml-cpp/null.h"
|
#include "yaml-cpp/null.h"
|
||||||
#include "yaml-cpp/ostream_wrapper.h"
|
#include "yaml-cpp/ostream_wrapper.h"
|
||||||
|
|
||||||
@ -28,10 +30,12 @@ struct _Null;
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
class EmitterState;
|
class EmitterState;
|
||||||
|
|
||||||
class YAML_CPP_API Emitter : private noncopyable {
|
class YAML_CPP_API Emitter {
|
||||||
public:
|
public:
|
||||||
Emitter();
|
Emitter();
|
||||||
explicit Emitter(std::ostream& stream);
|
explicit Emitter(std::ostream& stream);
|
||||||
|
Emitter(const Emitter&) = delete;
|
||||||
|
Emitter& operator=(const Emitter&) = delete;
|
||||||
~Emitter();
|
~Emitter();
|
||||||
|
|
||||||
// output
|
// output
|
||||||
@ -55,6 +59,7 @@ class YAML_CPP_API Emitter : private noncopyable {
|
|||||||
bool SetPostCommentIndent(std::size_t n);
|
bool SetPostCommentIndent(std::size_t n);
|
||||||
bool SetFloatPrecision(std::size_t n);
|
bool SetFloatPrecision(std::size_t n);
|
||||||
bool SetDoublePrecision(std::size_t n);
|
bool SetDoublePrecision(std::size_t n);
|
||||||
|
void RestoreGlobalModifiedSettings();
|
||||||
|
|
||||||
// local setters
|
// local setters
|
||||||
Emitter& SetLocalValue(EMITTER_MANIP value);
|
Emitter& SetLocalValue(EMITTER_MANIP value);
|
||||||
@ -120,6 +125,7 @@ class YAML_CPP_API Emitter : private noncopyable {
|
|||||||
void SpaceOrIndentTo(bool requireSpace, std::size_t indent);
|
void SpaceOrIndentTo(bool requireSpace, std::size_t indent);
|
||||||
|
|
||||||
const char* ComputeFullBoolName(bool b) const;
|
const char* ComputeFullBoolName(bool b) const;
|
||||||
|
const char* ComputeNullName() const;
|
||||||
bool CanEmitNewline() const;
|
bool CanEmitNewline() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -153,7 +159,27 @@ inline Emitter& Emitter::WriteStreamable(T value) {
|
|||||||
|
|
||||||
std::stringstream stream;
|
std::stringstream stream;
|
||||||
SetStreamablePrecision<T>(stream);
|
SetStreamablePrecision<T>(stream);
|
||||||
|
|
||||||
|
bool special = false;
|
||||||
|
if (std::is_floating_point<T>::value) {
|
||||||
|
if ((std::numeric_limits<T>::has_quiet_NaN ||
|
||||||
|
std::numeric_limits<T>::has_signaling_NaN) &&
|
||||||
|
std::isnan(value)) {
|
||||||
|
special = true;
|
||||||
|
stream << ".nan";
|
||||||
|
} else if (std::numeric_limits<T>::has_infinity && std::isinf(value)) {
|
||||||
|
special = true;
|
||||||
|
if (std::signbit(value)) {
|
||||||
|
stream << "-.inf";
|
||||||
|
} else {
|
||||||
|
stream << ".inf";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!special) {
|
||||||
stream << value;
|
stream << value;
|
||||||
|
}
|
||||||
m_stream << stream.str();
|
m_stream << stream.str();
|
||||||
|
|
||||||
StartedScalar();
|
StartedScalar();
|
||||||
@ -250,6 +276,6 @@ inline Emitter& operator<<(Emitter& emitter, _Indent indent) {
|
|||||||
inline Emitter& operator<<(Emitter& emitter, _Precision precision) {
|
inline Emitter& operator<<(Emitter& emitter, _Precision precision) {
|
||||||
return emitter.SetLocalPrecision(precision);
|
return emitter.SetLocalPrecision(precision);
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // EMITTER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // EMITTER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -27,6 +27,12 @@ enum EMITTER_MANIP {
|
|||||||
DoubleQuoted,
|
DoubleQuoted,
|
||||||
Literal,
|
Literal,
|
||||||
|
|
||||||
|
// null manipulators
|
||||||
|
LowerNull,
|
||||||
|
UpperNull,
|
||||||
|
CamelNull,
|
||||||
|
TildeNull,
|
||||||
|
|
||||||
// bool manipulators
|
// bool manipulators
|
||||||
YesNoBool, // yes, no
|
YesNoBool, // yes, no
|
||||||
TrueFalseBool, // true, false
|
TrueFalseBool, // true, false
|
||||||
@ -37,10 +43,6 @@ enum EMITTER_MANIP {
|
|||||||
LongBool, // yes, On
|
LongBool, // yes, On
|
||||||
ShortBool, // y, t
|
ShortBool, // y, t
|
||||||
|
|
||||||
// null manipulators
|
|
||||||
NullAsTilde, // ~
|
|
||||||
NullAsNull, // null
|
|
||||||
|
|
||||||
// int manipulators
|
// int manipulators
|
||||||
Dec,
|
Dec,
|
||||||
Hex,
|
Hex,
|
||||||
@ -79,14 +81,14 @@ struct _Alias {
|
|||||||
std::string content;
|
std::string content;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline _Alias Alias(const std::string content) { return _Alias(content); }
|
inline _Alias Alias(const std::string& content) { return _Alias(content); }
|
||||||
|
|
||||||
struct _Anchor {
|
struct _Anchor {
|
||||||
_Anchor(const std::string& content_) : content(content_) {}
|
_Anchor(const std::string& content_) : content(content_) {}
|
||||||
std::string content;
|
std::string content;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline _Anchor Anchor(const std::string content) { return _Anchor(content); }
|
inline _Anchor Anchor(const std::string& content) { return _Anchor(content); }
|
||||||
|
|
||||||
struct _Tag {
|
struct _Tag {
|
||||||
struct Type {
|
struct Type {
|
||||||
@ -101,11 +103,11 @@ struct _Tag {
|
|||||||
Type::value type;
|
Type::value type;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline _Tag VerbatimTag(const std::string content) {
|
inline _Tag VerbatimTag(const std::string& content) {
|
||||||
return _Tag("", content, _Tag::Type::Verbatim);
|
return _Tag("", content, _Tag::Type::Verbatim);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline _Tag LocalTag(const std::string content) {
|
inline _Tag LocalTag(const std::string& content) {
|
||||||
return _Tag("", content, _Tag::Type::PrimaryHandle);
|
return _Tag("", content, _Tag::Type::PrimaryHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,7 +115,7 @@ inline _Tag LocalTag(const std::string& prefix, const std::string content) {
|
|||||||
return _Tag(prefix, content, _Tag::Type::NamedHandle);
|
return _Tag(prefix, content, _Tag::Type::NamedHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline _Tag SecondaryTag(const std::string content) {
|
inline _Tag SecondaryTag(const std::string& content) {
|
||||||
return _Tag("", content, _Tag::Type::NamedHandle);
|
return _Tag("", content, _Tag::Type::NamedHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -122,7 +124,7 @@ struct _Comment {
|
|||||||
std::string content;
|
std::string content;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline _Comment Comment(const std::string content) { return _Comment(content); }
|
inline _Comment Comment(const std::string& content) { return _Comment(content); }
|
||||||
|
|
||||||
struct _Precision {
|
struct _Precision {
|
||||||
_Precision(int floatPrecision_, int doublePrecision_)
|
_Precision(int floatPrecision_, int doublePrecision_)
|
||||||
|
@ -17,7 +17,7 @@ struct Mark;
|
|||||||
|
|
||||||
class EventHandler {
|
class EventHandler {
|
||||||
public:
|
public:
|
||||||
virtual ~EventHandler() {}
|
virtual ~EventHandler() = default;
|
||||||
|
|
||||||
virtual void OnDocumentStart(const Mark& mark) = 0;
|
virtual void OnDocumentStart(const Mark& mark) = 0;
|
||||||
virtual void OnDocumentEnd() = 0;
|
virtual void OnDocumentEnd() = 0;
|
||||||
@ -34,7 +34,12 @@ class EventHandler {
|
|||||||
virtual void OnMapStart(const Mark& mark, const std::string& tag,
|
virtual void OnMapStart(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, EmitterStyle::value style) = 0;
|
anchor_t anchor, EmitterStyle::value style) = 0;
|
||||||
virtual void OnMapEnd() = 0;
|
virtual void OnMapEnd() = 0;
|
||||||
};
|
|
||||||
|
virtual void OnAnchor(const Mark& /*mark*/,
|
||||||
|
const std::string& /*anchor_name*/) {
|
||||||
|
// empty default implementation for compatibility
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // EVENTHANDLER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // EVENTHANDLER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
102
3rdparty/yaml-cpp/include/yaml-cpp/exceptions.h
vendored
102
3rdparty/yaml-cpp/include/yaml-cpp/exceptions.h
vendored
@ -7,19 +7,8 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef NOEXCEPT
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
#ifdef _NOEXCEPT
|
|
||||||
#define NOEXCEPT _NOEXCEPT
|
|
||||||
#else
|
|
||||||
#define NOEXCEPT
|
|
||||||
#endif // ifdef _NOEXCEPT
|
|
||||||
#else
|
|
||||||
#define NOEXCEPT noexcept
|
|
||||||
#endif // ifdef _MSC_VER
|
|
||||||
#endif // ifdef NOEXCEPT
|
|
||||||
|
|
||||||
#include "yaml-cpp/mark.h"
|
#include "yaml-cpp/mark.h"
|
||||||
|
#include "yaml-cpp/noexcept.h"
|
||||||
#include "yaml-cpp/traits.h"
|
#include "yaml-cpp/traits.h"
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
@ -76,7 +65,7 @@ const char* const ZERO_INDENT_IN_BLOCK =
|
|||||||
const char* const CHAR_IN_BLOCK = "unexpected character in block scalar";
|
const char* const CHAR_IN_BLOCK = "unexpected character in block scalar";
|
||||||
const char* const AMBIGUOUS_ANCHOR =
|
const char* const AMBIGUOUS_ANCHOR =
|
||||||
"cannot assign the same alias to multiple nodes";
|
"cannot assign the same alias to multiple nodes";
|
||||||
const char* const UNKNOWN_ANCHOR = "the referenced anchor is not defined";
|
const char* const UNKNOWN_ANCHOR = "the referenced anchor is not defined: ";
|
||||||
|
|
||||||
const char* const INVALID_NODE =
|
const char* const INVALID_NODE =
|
||||||
"invalid node; this may result from using a map iterator as a sequence "
|
"invalid node; this may result from using a map iterator as a sequence "
|
||||||
@ -111,6 +100,12 @@ inline const std::string KEY_NOT_FOUND_WITH_KEY(const std::string& key) {
|
|||||||
return stream.str();
|
return stream.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline const std::string KEY_NOT_FOUND_WITH_KEY(const char* key) {
|
||||||
|
std::stringstream stream;
|
||||||
|
stream << KEY_NOT_FOUND << ": " << key;
|
||||||
|
return stream.str();
|
||||||
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline const std::string KEY_NOT_FOUND_WITH_KEY(
|
inline const std::string KEY_NOT_FOUND_WITH_KEY(
|
||||||
const T& key, typename enable_if<is_numeric<T>>::type* = 0) {
|
const T& key, typename enable_if<is_numeric<T>>::type* = 0) {
|
||||||
@ -118,13 +113,48 @@ inline const std::string KEY_NOT_FOUND_WITH_KEY(
|
|||||||
stream << KEY_NOT_FOUND << ": " << key;
|
stream << KEY_NOT_FOUND << ": " << key;
|
||||||
return stream.str();
|
return stream.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline const std::string BAD_SUBSCRIPT_WITH_KEY(
|
||||||
|
const T&, typename disable_if<is_numeric<T>>::type* = nullptr) {
|
||||||
|
return BAD_SUBSCRIPT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline const std::string BAD_SUBSCRIPT_WITH_KEY(const std::string& key) {
|
||||||
|
std::stringstream stream;
|
||||||
|
stream << BAD_SUBSCRIPT << " (key: \"" << key << "\")";
|
||||||
|
return stream.str();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline const std::string BAD_SUBSCRIPT_WITH_KEY(const char* key) {
|
||||||
|
std::stringstream stream;
|
||||||
|
stream << BAD_SUBSCRIPT << " (key: \"" << key << "\")";
|
||||||
|
return stream.str();
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline const std::string BAD_SUBSCRIPT_WITH_KEY(
|
||||||
|
const T& key, typename enable_if<is_numeric<T>>::type* = nullptr) {
|
||||||
|
std::stringstream stream;
|
||||||
|
stream << BAD_SUBSCRIPT << " (key: \"" << key << "\")";
|
||||||
|
return stream.str();
|
||||||
|
}
|
||||||
|
|
||||||
|
inline const std::string INVALID_NODE_WITH_KEY(const std::string& key) {
|
||||||
|
std::stringstream stream;
|
||||||
|
if (key.empty()) {
|
||||||
|
return INVALID_NODE;
|
||||||
|
}
|
||||||
|
stream << "invalid node; first invalid key: \"" << key << "\"";
|
||||||
|
return stream.str();
|
||||||
|
}
|
||||||
|
} // namespace ErrorMsg
|
||||||
|
|
||||||
class YAML_CPP_API Exception : public std::runtime_error {
|
class YAML_CPP_API Exception : public std::runtime_error {
|
||||||
public:
|
public:
|
||||||
Exception(const Mark& mark_, const std::string& msg_)
|
Exception(const Mark& mark_, const std::string& msg_)
|
||||||
: std::runtime_error(build_what(mark_, msg_)), mark(mark_), msg(msg_) {}
|
: std::runtime_error(build_what(mark_, msg_)), mark(mark_), msg(msg_) {}
|
||||||
virtual ~Exception() NOEXCEPT;
|
~Exception() YAML_CPP_NOEXCEPT override;
|
||||||
|
|
||||||
Exception(const Exception&) = default;
|
Exception(const Exception&) = default;
|
||||||
|
|
||||||
@ -135,7 +165,7 @@ class YAML_CPP_API Exception : public std::runtime_error {
|
|||||||
static const std::string build_what(const Mark& mark,
|
static const std::string build_what(const Mark& mark,
|
||||||
const std::string& msg) {
|
const std::string& msg) {
|
||||||
if (mark.is_null()) {
|
if (mark.is_null()) {
|
||||||
return msg.c_str();
|
return msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::stringstream output;
|
std::stringstream output;
|
||||||
@ -150,7 +180,7 @@ class YAML_CPP_API ParserException : public Exception {
|
|||||||
ParserException(const Mark& mark_, const std::string& msg_)
|
ParserException(const Mark& mark_, const std::string& msg_)
|
||||||
: Exception(mark_, msg_) {}
|
: Exception(mark_, msg_) {}
|
||||||
ParserException(const ParserException&) = default;
|
ParserException(const ParserException&) = default;
|
||||||
virtual ~ParserException() NOEXCEPT;
|
~ParserException() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API RepresentationException : public Exception {
|
class YAML_CPP_API RepresentationException : public Exception {
|
||||||
@ -158,7 +188,7 @@ class YAML_CPP_API RepresentationException : public Exception {
|
|||||||
RepresentationException(const Mark& mark_, const std::string& msg_)
|
RepresentationException(const Mark& mark_, const std::string& msg_)
|
||||||
: Exception(mark_, msg_) {}
|
: Exception(mark_, msg_) {}
|
||||||
RepresentationException(const RepresentationException&) = default;
|
RepresentationException(const RepresentationException&) = default;
|
||||||
virtual ~RepresentationException() NOEXCEPT;
|
~RepresentationException() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
// representation exceptions
|
// representation exceptions
|
||||||
@ -167,7 +197,7 @@ class YAML_CPP_API InvalidScalar : public RepresentationException {
|
|||||||
InvalidScalar(const Mark& mark_)
|
InvalidScalar(const Mark& mark_)
|
||||||
: RepresentationException(mark_, ErrorMsg::INVALID_SCALAR) {}
|
: RepresentationException(mark_, ErrorMsg::INVALID_SCALAR) {}
|
||||||
InvalidScalar(const InvalidScalar&) = default;
|
InvalidScalar(const InvalidScalar&) = default;
|
||||||
virtual ~InvalidScalar() NOEXCEPT;
|
~InvalidScalar() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API KeyNotFound : public RepresentationException {
|
class YAML_CPP_API KeyNotFound : public RepresentationException {
|
||||||
@ -177,7 +207,7 @@ class YAML_CPP_API KeyNotFound : public RepresentationException {
|
|||||||
: RepresentationException(mark_, ErrorMsg::KEY_NOT_FOUND_WITH_KEY(key_)) {
|
: RepresentationException(mark_, ErrorMsg::KEY_NOT_FOUND_WITH_KEY(key_)) {
|
||||||
}
|
}
|
||||||
KeyNotFound(const KeyNotFound&) = default;
|
KeyNotFound(const KeyNotFound&) = default;
|
||||||
virtual ~KeyNotFound() NOEXCEPT;
|
~KeyNotFound() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -185,7 +215,7 @@ class YAML_CPP_API TypedKeyNotFound : public KeyNotFound {
|
|||||||
public:
|
public:
|
||||||
TypedKeyNotFound(const Mark& mark_, const T& key_)
|
TypedKeyNotFound(const Mark& mark_, const T& key_)
|
||||||
: KeyNotFound(mark_, key_), key(key_) {}
|
: KeyNotFound(mark_, key_), key(key_) {}
|
||||||
virtual ~TypedKeyNotFound() NOEXCEPT {}
|
~TypedKeyNotFound() YAML_CPP_NOEXCEPT override = default;
|
||||||
|
|
||||||
T key;
|
T key;
|
||||||
};
|
};
|
||||||
@ -198,10 +228,11 @@ inline TypedKeyNotFound<T> MakeTypedKeyNotFound(const Mark& mark,
|
|||||||
|
|
||||||
class YAML_CPP_API InvalidNode : public RepresentationException {
|
class YAML_CPP_API InvalidNode : public RepresentationException {
|
||||||
public:
|
public:
|
||||||
InvalidNode()
|
InvalidNode(const std::string& key)
|
||||||
: RepresentationException(Mark::null_mark(), ErrorMsg::INVALID_NODE) {}
|
: RepresentationException(Mark::null_mark(),
|
||||||
|
ErrorMsg::INVALID_NODE_WITH_KEY(key)) {}
|
||||||
InvalidNode(const InvalidNode&) = default;
|
InvalidNode(const InvalidNode&) = default;
|
||||||
virtual ~InvalidNode() NOEXCEPT;
|
~InvalidNode() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API BadConversion : public RepresentationException {
|
class YAML_CPP_API BadConversion : public RepresentationException {
|
||||||
@ -209,7 +240,7 @@ class YAML_CPP_API BadConversion : public RepresentationException {
|
|||||||
explicit BadConversion(const Mark& mark_)
|
explicit BadConversion(const Mark& mark_)
|
||||||
: RepresentationException(mark_, ErrorMsg::BAD_CONVERSION) {}
|
: RepresentationException(mark_, ErrorMsg::BAD_CONVERSION) {}
|
||||||
BadConversion(const BadConversion&) = default;
|
BadConversion(const BadConversion&) = default;
|
||||||
virtual ~BadConversion() NOEXCEPT;
|
~BadConversion() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
@ -223,15 +254,16 @@ class YAML_CPP_API BadDereference : public RepresentationException {
|
|||||||
BadDereference()
|
BadDereference()
|
||||||
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_DEREFERENCE) {}
|
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_DEREFERENCE) {}
|
||||||
BadDereference(const BadDereference&) = default;
|
BadDereference(const BadDereference&) = default;
|
||||||
virtual ~BadDereference() NOEXCEPT;
|
~BadDereference() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API BadSubscript : public RepresentationException {
|
class YAML_CPP_API BadSubscript : public RepresentationException {
|
||||||
public:
|
public:
|
||||||
BadSubscript()
|
template <typename Key>
|
||||||
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_SUBSCRIPT) {}
|
BadSubscript(const Mark& mark_, const Key& key)
|
||||||
|
: RepresentationException(mark_, ErrorMsg::BAD_SUBSCRIPT_WITH_KEY(key)) {}
|
||||||
BadSubscript(const BadSubscript&) = default;
|
BadSubscript(const BadSubscript&) = default;
|
||||||
virtual ~BadSubscript() NOEXCEPT;
|
~BadSubscript() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API BadPushback : public RepresentationException {
|
class YAML_CPP_API BadPushback : public RepresentationException {
|
||||||
@ -239,7 +271,7 @@ class YAML_CPP_API BadPushback : public RepresentationException {
|
|||||||
BadPushback()
|
BadPushback()
|
||||||
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_PUSHBACK) {}
|
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_PUSHBACK) {}
|
||||||
BadPushback(const BadPushback&) = default;
|
BadPushback(const BadPushback&) = default;
|
||||||
virtual ~BadPushback() NOEXCEPT;
|
~BadPushback() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API BadInsert : public RepresentationException {
|
class YAML_CPP_API BadInsert : public RepresentationException {
|
||||||
@ -247,7 +279,7 @@ class YAML_CPP_API BadInsert : public RepresentationException {
|
|||||||
BadInsert()
|
BadInsert()
|
||||||
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_INSERT) {}
|
: RepresentationException(Mark::null_mark(), ErrorMsg::BAD_INSERT) {}
|
||||||
BadInsert(const BadInsert&) = default;
|
BadInsert(const BadInsert&) = default;
|
||||||
virtual ~BadInsert() NOEXCEPT;
|
~BadInsert() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API EmitterException : public Exception {
|
class YAML_CPP_API EmitterException : public Exception {
|
||||||
@ -255,15 +287,17 @@ class YAML_CPP_API EmitterException : public Exception {
|
|||||||
EmitterException(const std::string& msg_)
|
EmitterException(const std::string& msg_)
|
||||||
: Exception(Mark::null_mark(), msg_) {}
|
: Exception(Mark::null_mark(), msg_) {}
|
||||||
EmitterException(const EmitterException&) = default;
|
EmitterException(const EmitterException&) = default;
|
||||||
virtual ~EmitterException() NOEXCEPT;
|
~EmitterException() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class YAML_CPP_API BadFile : public Exception {
|
class YAML_CPP_API BadFile : public Exception {
|
||||||
public:
|
public:
|
||||||
BadFile() : Exception(Mark::null_mark(), ErrorMsg::BAD_FILE) {}
|
explicit BadFile(const std::string& filename)
|
||||||
|
: Exception(Mark::null_mark(),
|
||||||
|
std::string(ErrorMsg::BAD_FILE) + ": " + filename) {}
|
||||||
BadFile(const BadFile&) = default;
|
BadFile(const BadFile&) = default;
|
||||||
virtual ~BadFile() NOEXCEPT;
|
~BadFile() YAML_CPP_NOEXCEPT override;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // EXCEPTIONS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // EXCEPTIONS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
198
3rdparty/yaml-cpp/include/yaml-cpp/node/convert.h
vendored
198
3rdparty/yaml-cpp/include/yaml-cpp/node/convert.h
vendored
@ -8,10 +8,14 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
|
#include <cmath>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
#include <unordered_map>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
#include <type_traits>
|
||||||
|
#include <valarray>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "yaml-cpp/binary.h"
|
#include "yaml-cpp/binary.h"
|
||||||
@ -21,6 +25,7 @@
|
|||||||
#include "yaml-cpp/node/type.h"
|
#include "yaml-cpp/node/type.h"
|
||||||
#include "yaml-cpp/null.h"
|
#include "yaml-cpp/null.h"
|
||||||
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
class Binary;
|
class Binary;
|
||||||
struct _Null;
|
struct _Null;
|
||||||
@ -71,12 +76,17 @@ struct convert<std::string> {
|
|||||||
// C-strings can only be encoded
|
// C-strings can only be encoded
|
||||||
template <>
|
template <>
|
||||||
struct convert<const char*> {
|
struct convert<const char*> {
|
||||||
static Node encode(const char*& rhs) { return Node(rhs); }
|
static Node encode(const char* rhs) { return Node(rhs); }
|
||||||
|
};
|
||||||
|
|
||||||
|
template <>
|
||||||
|
struct convert<char*> {
|
||||||
|
static Node encode(const char* rhs) { return Node(rhs); }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <std::size_t N>
|
template <std::size_t N>
|
||||||
struct convert<const char[N]> {
|
struct convert<char[N]> {
|
||||||
static Node encode(const char(&rhs)[N]) { return Node(rhs); }
|
static Node encode(const char* rhs) { return Node(rhs); }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
@ -88,24 +98,79 @@ struct convert<_Null> {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
namespace conversion {
|
||||||
|
template <typename T>
|
||||||
|
typename std::enable_if< std::is_floating_point<T>::value, void>::type
|
||||||
|
inner_encode(const T& rhs, std::stringstream& stream){
|
||||||
|
if (std::isnan(rhs)) {
|
||||||
|
stream << ".nan";
|
||||||
|
} else if (std::isinf(rhs)) {
|
||||||
|
if (std::signbit(rhs)) {
|
||||||
|
stream << "-.inf";
|
||||||
|
} else {
|
||||||
|
stream << ".inf";
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
stream << rhs;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
typename std::enable_if<!std::is_floating_point<T>::value, void>::type
|
||||||
|
inner_encode(const T& rhs, std::stringstream& stream){
|
||||||
|
stream << rhs;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
typename std::enable_if<(std::is_same<T, unsigned char>::value ||
|
||||||
|
std::is_same<T, signed char>::value), bool>::type
|
||||||
|
ConvertStreamTo(std::stringstream& stream, T& rhs) {
|
||||||
|
int num;
|
||||||
|
if ((stream >> std::noskipws >> num) && (stream >> std::ws).eof()) {
|
||||||
|
if (num >= (std::numeric_limits<T>::min)() &&
|
||||||
|
num <= (std::numeric_limits<T>::max)()) {
|
||||||
|
rhs = static_cast<T>(num);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
typename std::enable_if<!(std::is_same<T, unsigned char>::value ||
|
||||||
|
std::is_same<T, signed char>::value), bool>::type
|
||||||
|
ConvertStreamTo(std::stringstream& stream, T& rhs) {
|
||||||
|
if ((stream >> std::noskipws >> rhs) && (stream >> std::ws).eof()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#define YAML_DEFINE_CONVERT_STREAMABLE(type, negative_op) \
|
#define YAML_DEFINE_CONVERT_STREAMABLE(type, negative_op) \
|
||||||
template <> \
|
template <> \
|
||||||
struct convert<type> { \
|
struct convert<type> { \
|
||||||
|
\
|
||||||
static Node encode(const type& rhs) { \
|
static Node encode(const type& rhs) { \
|
||||||
std::stringstream stream; \
|
std::stringstream stream; \
|
||||||
stream.precision(std::numeric_limits<type>::digits10 + 1); \
|
stream.precision(std::numeric_limits<type>::max_digits10); \
|
||||||
stream << rhs; \
|
conversion::inner_encode(rhs, stream); \
|
||||||
return Node(stream.str()); \
|
return Node(stream.str()); \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
static bool decode(const Node& node, type& rhs) { \
|
static bool decode(const Node& node, type& rhs) { \
|
||||||
if (node.Type() != NodeType::Scalar) \
|
if (node.Type() != NodeType::Scalar) { \
|
||||||
return false; \
|
return false; \
|
||||||
|
} \
|
||||||
const std::string& input = node.Scalar(); \
|
const std::string& input = node.Scalar(); \
|
||||||
std::stringstream stream(input); \
|
std::stringstream stream(input); \
|
||||||
stream.unsetf(std::ios::dec); \
|
stream.unsetf(std::ios::dec); \
|
||||||
if ((stream >> std::noskipws >> rhs) && (stream >> std::ws).eof()) \
|
if ((stream.peek() == '-') && std::is_unsigned<type>::value) { \
|
||||||
|
return false; \
|
||||||
|
} \
|
||||||
|
if (conversion::ConvertStreamTo(stream, rhs)) { \
|
||||||
return true; \
|
return true; \
|
||||||
|
} \
|
||||||
if (std::numeric_limits<type>::has_infinity) { \
|
if (std::numeric_limits<type>::has_infinity) { \
|
||||||
if (conversion::IsInfinity(input)) { \
|
if (conversion::IsInfinity(input)) { \
|
||||||
rhs = std::numeric_limits<type>::infinity(); \
|
rhs = std::numeric_limits<type>::infinity(); \
|
||||||
@ -116,10 +181,11 @@ struct convert<_Null> {
|
|||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
if (std::numeric_limits<type>::has_quiet_NaN && \
|
if (std::numeric_limits<type>::has_quiet_NaN) { \
|
||||||
conversion::IsNaN(input)) { \
|
if (conversion::IsNaN(input)) { \
|
||||||
rhs = std::numeric_limits<type>::quiet_NaN(); \
|
rhs = std::numeric_limits<type>::quiet_NaN(); \
|
||||||
return true; \
|
return true; \
|
||||||
|
} \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
return false; \
|
return false; \
|
||||||
@ -162,81 +228,104 @@ struct convert<bool> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// std::map
|
// std::map
|
||||||
template <typename K, typename V>
|
template <typename K, typename V, typename C, typename A>
|
||||||
struct convert<std::map<K, V>> {
|
struct convert<std::map<K, V, C, A>> {
|
||||||
static Node encode(const std::map<K, V>& rhs) {
|
static Node encode(const std::map<K, V, C, A>& rhs) {
|
||||||
Node node(NodeType::Map);
|
Node node(NodeType::Map);
|
||||||
for (typename std::map<K, V>::const_iterator it = rhs.begin();
|
for (const auto& element : rhs)
|
||||||
it != rhs.end(); ++it)
|
node.force_insert(element.first, element.second);
|
||||||
node.force_insert(it->first, it->second);
|
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool decode(const Node& node, std::map<K, V>& rhs) {
|
static bool decode(const Node& node, std::map<K, V, C, A>& rhs) {
|
||||||
if (!node.IsMap())
|
if (!node.IsMap())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
rhs.clear();
|
rhs.clear();
|
||||||
for (const_iterator it = node.begin(); it != node.end(); ++it)
|
for (const auto& element : node)
|
||||||
#if defined(__GNUC__) && __GNUC__ < 4
|
#if defined(__GNUC__) && __GNUC__ < 4
|
||||||
// workaround for GCC 3:
|
// workaround for GCC 3:
|
||||||
rhs[it->first.template as<K>()] = it->second.template as<V>();
|
rhs[element.first.template as<K>()] = element.second.template as<V>();
|
||||||
#else
|
#else
|
||||||
rhs[it->first.as<K>()] = it->second.as<V>();
|
rhs[element.first.as<K>()] = element.second.as<V>();
|
||||||
|
#endif
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// std::unordered_map
|
||||||
|
template <typename K, typename V, typename H, typename P, typename A>
|
||||||
|
struct convert<std::unordered_map<K, V, H, P, A>> {
|
||||||
|
static Node encode(const std::unordered_map<K, V, H, P, A>& rhs) {
|
||||||
|
Node node(NodeType::Map);
|
||||||
|
for (const auto& element : rhs)
|
||||||
|
node.force_insert(element.first, element.second);
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool decode(const Node& node, std::unordered_map<K, V, H, P, A>& rhs) {
|
||||||
|
if (!node.IsMap())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
rhs.clear();
|
||||||
|
for (const auto& element : node)
|
||||||
|
#if defined(__GNUC__) && __GNUC__ < 4
|
||||||
|
// workaround for GCC 3:
|
||||||
|
rhs[element.first.template as<K>()] = element.second.template as<V>();
|
||||||
|
#else
|
||||||
|
rhs[element.first.as<K>()] = element.second.as<V>();
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// std::vector
|
// std::vector
|
||||||
template <typename T>
|
template <typename T, typename A>
|
||||||
struct convert<std::vector<T>> {
|
struct convert<std::vector<T, A>> {
|
||||||
static Node encode(const std::vector<T>& rhs) {
|
static Node encode(const std::vector<T, A>& rhs) {
|
||||||
Node node(NodeType::Sequence);
|
Node node(NodeType::Sequence);
|
||||||
for (typename std::vector<T>::const_iterator it = rhs.begin();
|
for (const auto& element : rhs)
|
||||||
it != rhs.end(); ++it)
|
node.push_back(element);
|
||||||
node.push_back(*it);
|
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool decode(const Node& node, std::vector<T>& rhs) {
|
static bool decode(const Node& node, std::vector<T, A>& rhs) {
|
||||||
if (!node.IsSequence())
|
if (!node.IsSequence())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
rhs.clear();
|
rhs.clear();
|
||||||
for (const_iterator it = node.begin(); it != node.end(); ++it)
|
for (const auto& element : node)
|
||||||
#if defined(__GNUC__) && __GNUC__ < 4
|
#if defined(__GNUC__) && __GNUC__ < 4
|
||||||
// workaround for GCC 3:
|
// workaround for GCC 3:
|
||||||
rhs.push_back(it->template as<T>());
|
rhs.push_back(element.template as<T>());
|
||||||
#else
|
#else
|
||||||
rhs.push_back(it->as<T>());
|
rhs.push_back(element.as<T>());
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// std::list
|
// std::list
|
||||||
template <typename T>
|
template <typename T, typename A>
|
||||||
struct convert<std::list<T>> {
|
struct convert<std::list<T,A>> {
|
||||||
static Node encode(const std::list<T>& rhs) {
|
static Node encode(const std::list<T,A>& rhs) {
|
||||||
Node node(NodeType::Sequence);
|
Node node(NodeType::Sequence);
|
||||||
for (typename std::list<T>::const_iterator it = rhs.begin();
|
for (const auto& element : rhs)
|
||||||
it != rhs.end(); ++it)
|
node.push_back(element);
|
||||||
node.push_back(*it);
|
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool decode(const Node& node, std::list<T>& rhs) {
|
static bool decode(const Node& node, std::list<T,A>& rhs) {
|
||||||
if (!node.IsSequence())
|
if (!node.IsSequence())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
rhs.clear();
|
rhs.clear();
|
||||||
for (const_iterator it = node.begin(); it != node.end(); ++it)
|
for (const auto& element : node)
|
||||||
#if defined(__GNUC__) && __GNUC__ < 4
|
#if defined(__GNUC__) && __GNUC__ < 4
|
||||||
// workaround for GCC 3:
|
// workaround for GCC 3:
|
||||||
rhs.push_back(it->template as<T>());
|
rhs.push_back(element.template as<T>());
|
||||||
#else
|
#else
|
||||||
rhs.push_back(it->as<T>());
|
rhs.push_back(element.as<T>());
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -275,6 +364,37 @@ struct convert<std::array<T, N>> {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// std::valarray
|
||||||
|
template <typename T>
|
||||||
|
struct convert<std::valarray<T>> {
|
||||||
|
static Node encode(const std::valarray<T>& rhs) {
|
||||||
|
Node node(NodeType::Sequence);
|
||||||
|
for (const auto& element : rhs) {
|
||||||
|
node.push_back(element);
|
||||||
|
}
|
||||||
|
return node;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool decode(const Node& node, std::valarray<T>& rhs) {
|
||||||
|
if (!node.IsSequence()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
rhs.resize(node.size());
|
||||||
|
for (auto i = 0u; i < node.size(); ++i) {
|
||||||
|
#if defined(__GNUC__) && __GNUC__ < 4
|
||||||
|
// workaround for GCC 3:
|
||||||
|
rhs[i] = node[i].template as<T>();
|
||||||
|
#else
|
||||||
|
rhs[i] = node[i].as<T>();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// std::pair
|
// std::pair
|
||||||
template <typename T, typename U>
|
template <typename T, typename U>
|
||||||
struct convert<std::pair<T, U>> {
|
struct convert<std::pair<T, U>> {
|
||||||
|
@ -9,6 +9,8 @@
|
|||||||
|
|
||||||
#include "yaml-cpp/node/detail/node.h"
|
#include "yaml-cpp/node/detail/node.h"
|
||||||
#include "yaml-cpp/node/detail/node_data.h"
|
#include "yaml-cpp/node/detail/node_data.h"
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
@ -17,7 +19,7 @@ template <typename Key, typename Enable = void>
|
|||||||
struct get_idx {
|
struct get_idx {
|
||||||
static node* get(const std::vector<node*>& /* sequence */,
|
static node* get(const std::vector<node*>& /* sequence */,
|
||||||
const Key& /* key */, shared_memory_holder /* pMemory */) {
|
const Key& /* key */, shared_memory_holder /* pMemory */) {
|
||||||
return 0;
|
return nullptr;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -27,13 +29,13 @@ struct get_idx<Key,
|
|||||||
!std::is_same<Key, bool>::value>::type> {
|
!std::is_same<Key, bool>::value>::type> {
|
||||||
static node* get(const std::vector<node*>& sequence, const Key& key,
|
static node* get(const std::vector<node*>& sequence, const Key& key,
|
||||||
shared_memory_holder /* pMemory */) {
|
shared_memory_holder /* pMemory */) {
|
||||||
return key < sequence.size() ? sequence[key] : 0;
|
return key < sequence.size() ? sequence[key] : nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static node* get(std::vector<node*>& sequence, const Key& key,
|
static node* get(std::vector<node*>& sequence, const Key& key,
|
||||||
shared_memory_holder pMemory) {
|
shared_memory_holder pMemory) {
|
||||||
if (key > sequence.size() || (key > 0 && !sequence[key - 1]->is_defined()))
|
if (key > sequence.size() || (key > 0 && !sequence[key - 1]->is_defined()))
|
||||||
return 0;
|
return nullptr;
|
||||||
if (key == sequence.size())
|
if (key == sequence.size())
|
||||||
sequence.push_back(&pMemory->create_node());
|
sequence.push_back(&pMemory->create_node());
|
||||||
return sequence[key];
|
return sequence[key];
|
||||||
@ -46,13 +48,51 @@ struct get_idx<Key, typename std::enable_if<std::is_signed<Key>::value>::type> {
|
|||||||
shared_memory_holder pMemory) {
|
shared_memory_holder pMemory) {
|
||||||
return key >= 0 ? get_idx<std::size_t>::get(
|
return key >= 0 ? get_idx<std::size_t>::get(
|
||||||
sequence, static_cast<std::size_t>(key), pMemory)
|
sequence, static_cast<std::size_t>(key), pMemory)
|
||||||
: 0;
|
: nullptr;
|
||||||
}
|
}
|
||||||
static node* get(std::vector<node*>& sequence, const Key& key,
|
static node* get(std::vector<node*>& sequence, const Key& key,
|
||||||
shared_memory_holder pMemory) {
|
shared_memory_holder pMemory) {
|
||||||
return key >= 0 ? get_idx<std::size_t>::get(
|
return key >= 0 ? get_idx<std::size_t>::get(
|
||||||
sequence, static_cast<std::size_t>(key), pMemory)
|
sequence, static_cast<std::size_t>(key), pMemory)
|
||||||
: 0;
|
: nullptr;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename Key, typename Enable = void>
|
||||||
|
struct remove_idx {
|
||||||
|
static bool remove(std::vector<node*>&, const Key&, std::size_t&) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename Key>
|
||||||
|
struct remove_idx<
|
||||||
|
Key, typename std::enable_if<std::is_unsigned<Key>::value &&
|
||||||
|
!std::is_same<Key, bool>::value>::type> {
|
||||||
|
|
||||||
|
static bool remove(std::vector<node*>& sequence, const Key& key,
|
||||||
|
std::size_t& seqSize) {
|
||||||
|
if (key >= sequence.size()) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
sequence.erase(sequence.begin() + key);
|
||||||
|
if (seqSize > key) {
|
||||||
|
--seqSize;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename Key>
|
||||||
|
struct remove_idx<Key,
|
||||||
|
typename std::enable_if<std::is_signed<Key>::value>::type> {
|
||||||
|
|
||||||
|
static bool remove(std::vector<node*>& sequence, const Key& key,
|
||||||
|
std::size_t& seqSize) {
|
||||||
|
return key >= 0 ? remove_idx<std::size_t>::remove(
|
||||||
|
sequence, static_cast<std::size_t>(key), seqSize)
|
||||||
|
: false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -66,7 +106,11 @@ inline bool node::equals(const T& rhs, shared_memory_holder pMemory) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline bool node::equals(const char* rhs, shared_memory_holder pMemory) {
|
inline bool node::equals(const char* rhs, shared_memory_holder pMemory) {
|
||||||
return equals<std::string>(rhs, pMemory);
|
std::string lhs;
|
||||||
|
if (convert<std::string>::decode(Node(*this, std::move(pMemory)), lhs)) {
|
||||||
|
return lhs == rhs;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// indexing
|
// indexing
|
||||||
@ -78,22 +122,20 @@ inline node* node_data::get(const Key& key,
|
|||||||
break;
|
break;
|
||||||
case NodeType::Undefined:
|
case NodeType::Undefined:
|
||||||
case NodeType::Null:
|
case NodeType::Null:
|
||||||
return NULL;
|
return nullptr;
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
if (node* pNode = get_idx<Key>::get(m_sequence, key, pMemory))
|
if (node* pNode = get_idx<Key>::get(m_sequence, key, pMemory))
|
||||||
return pNode;
|
return pNode;
|
||||||
return NULL;
|
return nullptr;
|
||||||
case NodeType::Scalar:
|
case NodeType::Scalar:
|
||||||
throw BadSubscript();
|
throw BadSubscript(m_mark, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (node_map::const_iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
auto it = std::find_if(m_map.begin(), m_map.end(), [&](const kv_pair m) {
|
||||||
if (it->first->equals(key, pMemory)) {
|
return m.first->equals(key, pMemory);
|
||||||
return it->second;
|
});
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
return it != m_map.end() ? it->second : nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
@ -112,14 +154,16 @@ inline node& node_data::get(const Key& key, shared_memory_holder pMemory) {
|
|||||||
convert_to_map(pMemory);
|
convert_to_map(pMemory);
|
||||||
break;
|
break;
|
||||||
case NodeType::Scalar:
|
case NodeType::Scalar:
|
||||||
throw BadSubscript();
|
throw BadSubscript(m_mark, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (node_map::const_iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
auto it = std::find_if(m_map.begin(), m_map.end(), [&](const kv_pair m) {
|
||||||
if (it->first->equals(key, pMemory)) {
|
return m.first->equals(key, pMemory);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (it != m_map.end()) {
|
||||||
return *it->second;
|
return *it->second;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
node& k = convert_to_node(key, pMemory);
|
node& k = convert_to_node(key, pMemory);
|
||||||
node& v = pMemory->create_node();
|
node& v = pMemory->create_node();
|
||||||
@ -129,20 +173,26 @@ inline node& node_data::get(const Key& key, shared_memory_holder pMemory) {
|
|||||||
|
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
inline bool node_data::remove(const Key& key, shared_memory_holder pMemory) {
|
inline bool node_data::remove(const Key& key, shared_memory_holder pMemory) {
|
||||||
if (m_type != NodeType::Map)
|
if (m_type == NodeType::Sequence) {
|
||||||
return false;
|
return remove_idx<Key>::remove(m_sequence, key, m_seqSize);
|
||||||
|
}
|
||||||
|
|
||||||
for (kv_pairs::iterator it = m_undefinedPairs.begin();
|
if (m_type == NodeType::Map) {
|
||||||
it != m_undefinedPairs.end();) {
|
kv_pairs::iterator it = m_undefinedPairs.begin();
|
||||||
|
while (it != m_undefinedPairs.end()) {
|
||||||
kv_pairs::iterator jt = std::next(it);
|
kv_pairs::iterator jt = std::next(it);
|
||||||
if (it->first->equals(key, pMemory))
|
if (it->first->equals(key, pMemory)) {
|
||||||
m_undefinedPairs.erase(it);
|
m_undefinedPairs.erase(it);
|
||||||
|
}
|
||||||
it = jt;
|
it = jt;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (node_map::iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
auto iter = std::find_if(m_map.begin(), m_map.end(), [&](const kv_pair m) {
|
||||||
if (it->first->equals(key, pMemory)) {
|
return m.first->equals(key, pMemory);
|
||||||
m_map.erase(it);
|
});
|
||||||
|
|
||||||
|
if (iter != m_map.end()) {
|
||||||
|
m_map.erase(iter);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,24 +8,25 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/dll.h"
|
#include "yaml-cpp/dll.h"
|
||||||
#include "yaml-cpp/node/ptr.h"
|
|
||||||
#include "yaml-cpp/node/detail/node_iterator.h"
|
#include "yaml-cpp/node/detail/node_iterator.h"
|
||||||
|
#include "yaml-cpp/node/node.h"
|
||||||
|
#include "yaml-cpp/node/ptr.h"
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
struct iterator_value;
|
struct iterator_value;
|
||||||
|
|
||||||
template <typename V>
|
template <typename V>
|
||||||
class iterator_base : public std::iterator<std::forward_iterator_tag, V,
|
class iterator_base {
|
||||||
std::ptrdiff_t, V*, V> {
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
template <typename>
|
template <typename>
|
||||||
friend class iterator_base;
|
friend class iterator_base;
|
||||||
struct enabler {};
|
struct enabler {};
|
||||||
typedef node_iterator base_type;
|
using base_type = node_iterator;
|
||||||
|
|
||||||
struct proxy {
|
struct proxy {
|
||||||
explicit proxy(const V& x) : m_ref(x) {}
|
explicit proxy(const V& x) : m_ref(x) {}
|
||||||
@ -36,7 +37,11 @@ class iterator_base : public std::iterator<std::forward_iterator_tag, V,
|
|||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef typename iterator_base::value_type value_type;
|
using iterator_category = std::forward_iterator_tag;
|
||||||
|
using value_type = V;
|
||||||
|
using difference_type = std::ptrdiff_t;
|
||||||
|
using pointer = V*;
|
||||||
|
using reference = V;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
iterator_base() : m_iterator(), m_pMemory() {}
|
iterator_base() : m_iterator(), m_pMemory() {}
|
||||||
@ -85,7 +90,7 @@ class iterator_base : public std::iterator<std::forward_iterator_tag, V,
|
|||||||
base_type m_iterator;
|
base_type m_iterator;
|
||||||
shared_memory_holder m_pMemory;
|
shared_memory_holder m_pMemory;
|
||||||
};
|
};
|
||||||
}
|
} // namespace detail
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // VALUE_DETAIL_ITERATOR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // VALUE_DETAIL_ITERATOR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -20,8 +20,8 @@ template <typename V>
|
|||||||
class iterator_base;
|
class iterator_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef detail::iterator_base<detail::iterator_value> iterator;
|
using iterator = detail::iterator_base<detail::iterator_value>;
|
||||||
typedef detail::iterator_base<const detail::iterator_value> const_iterator;
|
using const_iterator = detail::iterator_base<const detail::iterator_value>;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // VALUE_DETAIL_ITERATOR_FWD_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // VALUE_DETAIL_ITERATOR_FWD_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -22,11 +22,12 @@ namespace YAML {
|
|||||||
namespace detail {
|
namespace detail {
|
||||||
class YAML_CPP_API memory {
|
class YAML_CPP_API memory {
|
||||||
public:
|
public:
|
||||||
|
memory() : m_nodes{} {}
|
||||||
node& create_node();
|
node& create_node();
|
||||||
void merge(const memory& rhs);
|
void merge(const memory& rhs);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef std::set<shared_node> Nodes;
|
using Nodes = std::set<shared_node>;
|
||||||
Nodes m_nodes;
|
Nodes m_nodes;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -40,7 +41,7 @@ class YAML_CPP_API memory_holder {
|
|||||||
private:
|
private:
|
||||||
shared_memory m_pMemory;
|
shared_memory m_pMemory;
|
||||||
};
|
};
|
||||||
}
|
} // namespace detail
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // VALUE_DETAIL_MEMORY_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // VALUE_DETAIL_MEMORY_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -7,18 +7,24 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/emitterstyle.h"
|
|
||||||
#include "yaml-cpp/dll.h"
|
#include "yaml-cpp/dll.h"
|
||||||
#include "yaml-cpp/node/type.h"
|
#include "yaml-cpp/emitterstyle.h"
|
||||||
#include "yaml-cpp/node/ptr.h"
|
|
||||||
#include "yaml-cpp/node/detail/node_ref.h"
|
#include "yaml-cpp/node/detail/node_ref.h"
|
||||||
|
#include "yaml-cpp/node/ptr.h"
|
||||||
|
#include "yaml-cpp/node/type.h"
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <atomic>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
class node {
|
class node {
|
||||||
|
private:
|
||||||
|
struct less {
|
||||||
|
bool operator ()(const node* l, const node* r) const {return l->m_index < r->m_index;}
|
||||||
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
node() : m_pRef(new node_ref) {}
|
node() : m_pRef(new node_ref), m_dependencies{}, m_index{} {}
|
||||||
node(const node&) = delete;
|
node(const node&) = delete;
|
||||||
node& operator=(const node&) = delete;
|
node& operator=(const node&) = delete;
|
||||||
|
|
||||||
@ -42,9 +48,8 @@ class node {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
m_pRef->mark_defined();
|
m_pRef->mark_defined();
|
||||||
for (nodes::iterator it = m_dependencies.begin();
|
for (node* dependency : m_dependencies)
|
||||||
it != m_dependencies.end(); ++it)
|
dependency->mark_defined();
|
||||||
(*it)->mark_defined();
|
|
||||||
m_dependencies.clear();
|
m_dependencies.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -109,6 +114,7 @@ class node {
|
|||||||
void push_back(node& input, shared_memory_holder pMemory) {
|
void push_back(node& input, shared_memory_holder pMemory) {
|
||||||
m_pRef->push_back(input, pMemory);
|
m_pRef->push_back(input, pMemory);
|
||||||
input.add_dependency(*this);
|
input.add_dependency(*this);
|
||||||
|
m_index = m_amount.fetch_add(1);
|
||||||
}
|
}
|
||||||
void insert(node& key, node& value, shared_memory_holder pMemory) {
|
void insert(node& key, node& value, shared_memory_holder pMemory) {
|
||||||
m_pRef->insert(key, value, pMemory);
|
m_pRef->insert(key, value, pMemory);
|
||||||
@ -120,7 +126,7 @@ class node {
|
|||||||
template <typename Key>
|
template <typename Key>
|
||||||
node* get(const Key& key, shared_memory_holder pMemory) const {
|
node* get(const Key& key, shared_memory_holder pMemory) const {
|
||||||
// NOTE: this returns a non-const node so that the top-level Node can wrap
|
// NOTE: this returns a non-const node so that the top-level Node can wrap
|
||||||
// it, and returns a pointer so that it can be NULL (if there is no such
|
// it, and returns a pointer so that it can be nullptr (if there is no such
|
||||||
// key).
|
// key).
|
||||||
return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
|
return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
|
||||||
}
|
}
|
||||||
@ -137,7 +143,7 @@ class node {
|
|||||||
|
|
||||||
node* get(node& key, shared_memory_holder pMemory) const {
|
node* get(node& key, shared_memory_holder pMemory) const {
|
||||||
// NOTE: this returns a non-const node so that the top-level Node can wrap
|
// NOTE: this returns a non-const node so that the top-level Node can wrap
|
||||||
// it, and returns a pointer so that it can be NULL (if there is no such
|
// it, and returns a pointer so that it can be nullptr (if there is no such
|
||||||
// key).
|
// key).
|
||||||
return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
|
return static_cast<const node_ref&>(*m_pRef).get(key, pMemory);
|
||||||
}
|
}
|
||||||
@ -160,10 +166,12 @@ class node {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
shared_node_ref m_pRef;
|
shared_node_ref m_pRef;
|
||||||
typedef std::set<node*> nodes;
|
using nodes = std::set<node*, less>;
|
||||||
nodes m_dependencies;
|
nodes m_dependencies;
|
||||||
|
size_t m_index;
|
||||||
|
static YAML_CPP_API std::atomic<size_t> m_amount;
|
||||||
};
|
};
|
||||||
}
|
} // namespace detail
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // NODE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // NODE_DETAIL_NODE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -60,8 +60,8 @@ class YAML_CPP_API node_data {
|
|||||||
node_iterator end();
|
node_iterator end();
|
||||||
|
|
||||||
// sequence
|
// sequence
|
||||||
void push_back(node& node, shared_memory_holder pMemory);
|
void push_back(node& node, const shared_memory_holder& pMemory);
|
||||||
void insert(node& key, node& value, shared_memory_holder pMemory);
|
void insert(node& key, node& value, const shared_memory_holder& pMemory);
|
||||||
|
|
||||||
// indexing
|
// indexing
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
@ -71,9 +71,9 @@ class YAML_CPP_API node_data {
|
|||||||
template <typename Key>
|
template <typename Key>
|
||||||
bool remove(const Key& key, shared_memory_holder pMemory);
|
bool remove(const Key& key, shared_memory_holder pMemory);
|
||||||
|
|
||||||
node* get(node& key, shared_memory_holder pMemory) const;
|
node* get(node& key, const shared_memory_holder& pMemory) const;
|
||||||
node& get(node& key, shared_memory_holder pMemory);
|
node& get(node& key, const shared_memory_holder& pMemory);
|
||||||
bool remove(node& key, shared_memory_holder pMemory);
|
bool remove(node& key, const shared_memory_holder& pMemory);
|
||||||
|
|
||||||
// map
|
// map
|
||||||
template <typename Key, typename Value>
|
template <typename Key, typename Value>
|
||||||
@ -81,7 +81,7 @@ class YAML_CPP_API node_data {
|
|||||||
shared_memory_holder pMemory);
|
shared_memory_holder pMemory);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static std::string empty_scalar;
|
static const std::string& empty_scalar();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void compute_seq_size() const;
|
void compute_seq_size() const;
|
||||||
@ -91,8 +91,8 @@ class YAML_CPP_API node_data {
|
|||||||
void reset_map();
|
void reset_map();
|
||||||
|
|
||||||
void insert_map_pair(node& key, node& value);
|
void insert_map_pair(node& key, node& value);
|
||||||
void convert_to_map(shared_memory_holder pMemory);
|
void convert_to_map(const shared_memory_holder& pMemory);
|
||||||
void convert_sequence_to_map(shared_memory_holder pMemory);
|
void convert_sequence_to_map(const shared_memory_holder& pMemory);
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
static node& convert_to_node(const T& rhs, shared_memory_holder pMemory);
|
static node& convert_to_node(const T& rhs, shared_memory_holder pMemory);
|
||||||
@ -108,17 +108,17 @@ class YAML_CPP_API node_data {
|
|||||||
std::string m_scalar;
|
std::string m_scalar;
|
||||||
|
|
||||||
// sequence
|
// sequence
|
||||||
typedef std::vector<node*> node_seq;
|
using node_seq = std::vector<node *>;
|
||||||
node_seq m_sequence;
|
node_seq m_sequence;
|
||||||
|
|
||||||
mutable std::size_t m_seqSize;
|
mutable std::size_t m_seqSize;
|
||||||
|
|
||||||
// map
|
// map
|
||||||
typedef std::vector<std::pair<node*, node*>> node_map;
|
using node_map = std::vector<std::pair<node*, node*>>;
|
||||||
node_map m_map;
|
node_map m_map;
|
||||||
|
|
||||||
typedef std::pair<node*, node*> kv_pair;
|
using kv_pair = std::pair<node*, node*>;
|
||||||
typedef std::list<kv_pair> kv_pairs;
|
using kv_pairs = std::list<kv_pair>;
|
||||||
mutable kv_pairs m_undefinedPairs;
|
mutable kv_pairs m_undefinedPairs;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -19,16 +19,16 @@
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
struct iterator_type {
|
struct iterator_type {
|
||||||
enum value { None, Sequence, Map };
|
enum value { NoneType, Sequence, Map };
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename V>
|
template <typename V>
|
||||||
struct node_iterator_value : public std::pair<V*, V*> {
|
struct node_iterator_value : public std::pair<V*, V*> {
|
||||||
typedef std::pair<V*, V*> kv;
|
using kv = std::pair<V*, V*>;
|
||||||
|
|
||||||
node_iterator_value() : kv(), pNode(0) {}
|
node_iterator_value() : kv(), pNode(nullptr) {}
|
||||||
explicit node_iterator_value(V& rhs) : kv(), pNode(&rhs) {}
|
explicit node_iterator_value(V& rhs) : kv(), pNode(&rhs) {}
|
||||||
explicit node_iterator_value(V& key, V& value) : kv(&key, &value), pNode(0) {}
|
explicit node_iterator_value(V& key, V& value) : kv(&key, &value), pNode(nullptr) {}
|
||||||
|
|
||||||
V& operator*() const { return *pNode; }
|
V& operator*() const { return *pNode; }
|
||||||
V& operator->() const { return *pNode; }
|
V& operator->() const { return *pNode; }
|
||||||
@ -36,26 +36,23 @@ struct node_iterator_value : public std::pair<V*, V*> {
|
|||||||
V* pNode;
|
V* pNode;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::vector<node*> node_seq;
|
using node_seq = std::vector<node *>;
|
||||||
typedef std::vector<std::pair<node*, node*>> node_map;
|
using node_map = std::vector<std::pair<node*, node*>>;
|
||||||
|
|
||||||
template <typename V>
|
template <typename V>
|
||||||
struct node_iterator_type {
|
struct node_iterator_type {
|
||||||
typedef node_seq::iterator seq;
|
using seq = node_seq::iterator;
|
||||||
typedef node_map::iterator map;
|
using map = node_map::iterator;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename V>
|
template <typename V>
|
||||||
struct node_iterator_type<const V> {
|
struct node_iterator_type<const V> {
|
||||||
typedef node_seq::const_iterator seq;
|
using seq = node_seq::const_iterator;
|
||||||
typedef node_map::const_iterator map;
|
using map = node_map::const_iterator;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename V>
|
template <typename V>
|
||||||
class node_iterator_base
|
class node_iterator_base {
|
||||||
: public std::iterator<std::forward_iterator_tag, node_iterator_value<V>,
|
|
||||||
std::ptrdiff_t, node_iterator_value<V>*,
|
|
||||||
node_iterator_value<V>> {
|
|
||||||
private:
|
private:
|
||||||
struct enabler {};
|
struct enabler {};
|
||||||
|
|
||||||
@ -68,12 +65,16 @@ class node_iterator_base
|
|||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef typename node_iterator_type<V>::seq SeqIter;
|
using iterator_category = std::forward_iterator_tag;
|
||||||
typedef typename node_iterator_type<V>::map MapIter;
|
using value_type = node_iterator_value<V>;
|
||||||
typedef node_iterator_value<V> value_type;
|
using difference_type = std::ptrdiff_t;
|
||||||
|
using pointer = node_iterator_value<V>*;
|
||||||
|
using reference = node_iterator_value<V>;
|
||||||
|
using SeqIter = typename node_iterator_type<V>::seq;
|
||||||
|
using MapIter = typename node_iterator_type<V>::map;
|
||||||
|
|
||||||
node_iterator_base()
|
node_iterator_base()
|
||||||
: m_type(iterator_type::None), m_seqIt(), m_mapIt(), m_mapEnd() {}
|
: m_type(iterator_type::NoneType), m_seqIt(), m_mapIt(), m_mapEnd() {}
|
||||||
explicit node_iterator_base(SeqIter seqIt)
|
explicit node_iterator_base(SeqIter seqIt)
|
||||||
: m_type(iterator_type::Sequence),
|
: m_type(iterator_type::Sequence),
|
||||||
m_seqIt(seqIt),
|
m_seqIt(seqIt),
|
||||||
@ -105,7 +106,7 @@ class node_iterator_base
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case iterator_type::None:
|
case iterator_type::NoneType:
|
||||||
return true;
|
return true;
|
||||||
case iterator_type::Sequence:
|
case iterator_type::Sequence:
|
||||||
return m_seqIt == rhs.m_seqIt;
|
return m_seqIt == rhs.m_seqIt;
|
||||||
@ -122,7 +123,7 @@ class node_iterator_base
|
|||||||
|
|
||||||
node_iterator_base<V>& operator++() {
|
node_iterator_base<V>& operator++() {
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case iterator_type::None:
|
case iterator_type::NoneType:
|
||||||
break;
|
break;
|
||||||
case iterator_type::Sequence:
|
case iterator_type::Sequence:
|
||||||
++m_seqIt;
|
++m_seqIt;
|
||||||
@ -143,7 +144,7 @@ class node_iterator_base
|
|||||||
|
|
||||||
value_type operator*() const {
|
value_type operator*() const {
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case iterator_type::None:
|
case iterator_type::NoneType:
|
||||||
return value_type();
|
return value_type();
|
||||||
case iterator_type::Sequence:
|
case iterator_type::Sequence:
|
||||||
return value_type(**m_seqIt);
|
return value_type(**m_seqIt);
|
||||||
@ -172,8 +173,8 @@ class node_iterator_base
|
|||||||
MapIter m_mapIt, m_mapEnd;
|
MapIter m_mapIt, m_mapEnd;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef node_iterator_base<node> node_iterator;
|
using node_iterator = node_iterator_base<node>;
|
||||||
typedef node_iterator_base<const node> const_node_iterator;
|
using const_node_iterator = node_iterator_base<const node>;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
173
3rdparty/yaml-cpp/include/yaml-cpp/node/impl.h
vendored
173
3rdparty/yaml-cpp/include/yaml-cpp/node/impl.h
vendored
@ -7,18 +7,21 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/node/node.h"
|
#include "yaml-cpp/exceptions.h"
|
||||||
#include "yaml-cpp/node/iterator.h"
|
|
||||||
#include "yaml-cpp/node/detail/memory.h"
|
#include "yaml-cpp/node/detail/memory.h"
|
||||||
#include "yaml-cpp/node/detail/node.h"
|
#include "yaml-cpp/node/detail/node.h"
|
||||||
#include "yaml-cpp/exceptions.h"
|
#include "yaml-cpp/node/iterator.h"
|
||||||
|
#include "yaml-cpp/node/node.h"
|
||||||
|
#include <sstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
inline Node::Node() : m_isValid(true), m_pNode(NULL) {}
|
inline Node::Node()
|
||||||
|
: m_isValid(true), m_invalidKey{}, m_pMemory(nullptr), m_pNode(nullptr) {}
|
||||||
|
|
||||||
inline Node::Node(NodeType::value type)
|
inline Node::Node(NodeType::value type)
|
||||||
: m_isValid(true),
|
: m_isValid(true),
|
||||||
|
m_invalidKey{},
|
||||||
m_pMemory(new detail::memory_holder),
|
m_pMemory(new detail::memory_holder),
|
||||||
m_pNode(&m_pMemory->create_node()) {
|
m_pNode(&m_pMemory->create_node()) {
|
||||||
m_pNode->set_type(type);
|
m_pNode->set_type(type);
|
||||||
@ -27,6 +30,7 @@ inline Node::Node(NodeType::value type)
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline Node::Node(const T& rhs)
|
inline Node::Node(const T& rhs)
|
||||||
: m_isValid(true),
|
: m_isValid(true),
|
||||||
|
m_invalidKey{},
|
||||||
m_pMemory(new detail::memory_holder),
|
m_pMemory(new detail::memory_holder),
|
||||||
m_pNode(&m_pMemory->create_node()) {
|
m_pNode(&m_pMemory->create_node()) {
|
||||||
Assign(rhs);
|
Assign(rhs);
|
||||||
@ -34,24 +38,26 @@ inline Node::Node(const T& rhs)
|
|||||||
|
|
||||||
inline Node::Node(const detail::iterator_value& rhs)
|
inline Node::Node(const detail::iterator_value& rhs)
|
||||||
: m_isValid(rhs.m_isValid),
|
: m_isValid(rhs.m_isValid),
|
||||||
|
m_invalidKey(rhs.m_invalidKey),
|
||||||
m_pMemory(rhs.m_pMemory),
|
m_pMemory(rhs.m_pMemory),
|
||||||
m_pNode(rhs.m_pNode) {}
|
m_pNode(rhs.m_pNode) {}
|
||||||
|
|
||||||
inline Node::Node(const Node& rhs)
|
inline Node::Node(const Node&) = default;
|
||||||
: m_isValid(rhs.m_isValid),
|
|
||||||
m_pMemory(rhs.m_pMemory),
|
|
||||||
m_pNode(rhs.m_pNode) {}
|
|
||||||
|
|
||||||
inline Node::Node(Zombie) : m_isValid(false), m_pNode(NULL) {}
|
inline Node::Node(Zombie)
|
||||||
|
: m_isValid(false), m_invalidKey{}, m_pMemory{}, m_pNode(nullptr) {}
|
||||||
|
|
||||||
|
inline Node::Node(Zombie, const std::string& key)
|
||||||
|
: m_isValid(false), m_invalidKey(key), m_pMemory{}, m_pNode(nullptr) {}
|
||||||
|
|
||||||
inline Node::Node(detail::node& node, detail::shared_memory_holder pMemory)
|
inline Node::Node(detail::node& node, detail::shared_memory_holder pMemory)
|
||||||
: m_isValid(true), m_pMemory(pMemory), m_pNode(&node) {}
|
: m_isValid(true), m_invalidKey{}, m_pMemory(pMemory), m_pNode(&node) {}
|
||||||
|
|
||||||
inline Node::~Node() {}
|
inline Node::~Node() = default;
|
||||||
|
|
||||||
inline void Node::EnsureNodeExists() const {
|
inline void Node::EnsureNodeExists() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
if (!m_pNode) {
|
if (!m_pNode) {
|
||||||
m_pMemory.reset(new detail::memory_holder);
|
m_pMemory.reset(new detail::memory_holder);
|
||||||
m_pNode = &m_pMemory->create_node();
|
m_pNode = &m_pMemory->create_node();
|
||||||
@ -68,14 +74,14 @@ inline bool Node::IsDefined() const {
|
|||||||
|
|
||||||
inline Mark Node::Mark() const {
|
inline Mark Node::Mark() const {
|
||||||
if (!m_isValid) {
|
if (!m_isValid) {
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
}
|
}
|
||||||
return m_pNode ? m_pNode->mark() : Mark::null_mark();
|
return m_pNode ? m_pNode->mark() : Mark::null_mark();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline NodeType::value Node::Type() const {
|
inline NodeType::value Node::Type() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return m_pNode ? m_pNode->type() : NodeType::Null;
|
return m_pNode ? m_pNode->type() : NodeType::Null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,6 +110,8 @@ struct as_if<std::string, S> {
|
|||||||
const Node& node;
|
const Node& node;
|
||||||
|
|
||||||
std::string operator()(const S& fallback) const {
|
std::string operator()(const S& fallback) const {
|
||||||
|
if (node.Type() == NodeType::Null)
|
||||||
|
return "null";
|
||||||
if (node.Type() != NodeType::Scalar)
|
if (node.Type() != NodeType::Scalar)
|
||||||
return fallback;
|
return fallback;
|
||||||
return node.Scalar();
|
return node.Scalar();
|
||||||
@ -132,6 +140,8 @@ struct as_if<std::string, void> {
|
|||||||
const Node& node;
|
const Node& node;
|
||||||
|
|
||||||
std::string operator()() const {
|
std::string operator()() const {
|
||||||
|
if (node.Type() == NodeType::Null)
|
||||||
|
return "null";
|
||||||
if (node.Type() != NodeType::Scalar)
|
if (node.Type() != NodeType::Scalar)
|
||||||
throw TypedBadConversion<std::string>(node.Mark());
|
throw TypedBadConversion<std::string>(node.Mark());
|
||||||
return node.Scalar();
|
return node.Scalar();
|
||||||
@ -142,7 +152,7 @@ struct as_if<std::string, void> {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline T Node::as() const {
|
inline T Node::as() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return as_if<T, void>(*this)();
|
return as_if<T, void>(*this)();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,32 +165,28 @@ inline T Node::as(const S& fallback) const {
|
|||||||
|
|
||||||
inline const std::string& Node::Scalar() const {
|
inline const std::string& Node::Scalar() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return m_pNode ? m_pNode->scalar() : detail::node_data::empty_scalar;
|
return m_pNode ? m_pNode->scalar() : detail::node_data::empty_scalar();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const std::string& Node::Tag() const {
|
inline const std::string& Node::Tag() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return m_pNode ? m_pNode->tag() : detail::node_data::empty_scalar;
|
return m_pNode ? m_pNode->tag() : detail::node_data::empty_scalar();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::SetTag(const std::string& tag) {
|
inline void Node::SetTag(const std::string& tag) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->set_tag(tag);
|
m_pNode->set_tag(tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline EmitterStyle::value Node::Style() const {
|
inline EmitterStyle::value Node::Style() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return m_pNode ? m_pNode->style() : EmitterStyle::Default;
|
return m_pNode ? m_pNode->style() : EmitterStyle::Default;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::SetStyle(EmitterStyle::value style) {
|
inline void Node::SetStyle(EmitterStyle::value style) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->set_style(style);
|
m_pNode->set_style(style);
|
||||||
}
|
}
|
||||||
@ -188,7 +194,7 @@ inline void Node::SetStyle(EmitterStyle::value style) {
|
|||||||
// assignment
|
// assignment
|
||||||
inline bool Node::is(const Node& rhs) const {
|
inline bool Node::is(const Node& rhs) const {
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
if (!m_isValid || !rhs.m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
if (!m_pNode || !rhs.m_pNode)
|
if (!m_pNode || !rhs.m_pNode)
|
||||||
return false;
|
return false;
|
||||||
return m_pNode->is(*rhs.m_pNode);
|
return m_pNode->is(*rhs.m_pNode);
|
||||||
@ -196,15 +202,20 @@ inline bool Node::is(const Node& rhs) const {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline Node& Node::operator=(const T& rhs) {
|
inline Node& Node::operator=(const T& rhs) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
Assign(rhs);
|
Assign(rhs);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline Node& Node::operator=(const Node& rhs) {
|
||||||
|
if (is(rhs))
|
||||||
|
return *this;
|
||||||
|
AssignNode(rhs);
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
inline void Node::reset(const YAML::Node& rhs) {
|
inline void Node::reset(const YAML::Node& rhs) {
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
if (!m_isValid || !rhs.m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
m_pMemory = rhs.m_pMemory;
|
m_pMemory = rhs.m_pMemory;
|
||||||
m_pNode = rhs.m_pNode;
|
m_pNode = rhs.m_pNode;
|
||||||
}
|
}
|
||||||
@ -212,44 +223,27 @@ inline void Node::reset(const YAML::Node& rhs) {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline void Node::Assign(const T& rhs) {
|
inline void Node::Assign(const T& rhs) {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
AssignData(convert<T>::encode(rhs));
|
AssignData(convert<T>::encode(rhs));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
inline void Node::Assign(const std::string& rhs) {
|
inline void Node::Assign(const std::string& rhs) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->set_scalar(rhs);
|
m_pNode->set_scalar(rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::Assign(const char* rhs) {
|
inline void Node::Assign(const char* rhs) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->set_scalar(rhs);
|
m_pNode->set_scalar(rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::Assign(char* rhs) {
|
inline void Node::Assign(char* rhs) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->set_scalar(rhs);
|
m_pNode->set_scalar(rhs);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Node& Node::operator=(const Node& rhs) {
|
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
if (is(rhs))
|
|
||||||
return *this;
|
|
||||||
AssignNode(rhs);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void Node::AssignData(const Node& rhs) {
|
inline void Node::AssignData(const Node& rhs) {
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
rhs.EnsureNodeExists();
|
rhs.EnsureNodeExists();
|
||||||
|
|
||||||
@ -258,8 +252,8 @@ inline void Node::AssignData(const Node& rhs) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::AssignNode(const Node& rhs) {
|
inline void Node::AssignNode(const Node& rhs) {
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
rhs.EnsureNodeExists();
|
rhs.EnsureNodeExists();
|
||||||
|
|
||||||
if (!m_pNode) {
|
if (!m_pNode) {
|
||||||
@ -276,7 +270,7 @@ inline void Node::AssignNode(const Node& rhs) {
|
|||||||
// size/iterator
|
// size/iterator
|
||||||
inline std::size_t Node::size() const {
|
inline std::size_t Node::size() const {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
return m_pNode ? m_pNode->size() : 0;
|
return m_pNode ? m_pNode->size() : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -309,13 +303,11 @@ inline iterator Node::end() {
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
inline void Node::push_back(const T& rhs) {
|
inline void Node::push_back(const T& rhs) {
|
||||||
if (!m_isValid)
|
if (!m_isValid)
|
||||||
throw InvalidNode();
|
throw InvalidNode(m_invalidKey);
|
||||||
push_back(Node(rhs));
|
push_back(Node(rhs));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Node::push_back(const Node& rhs) {
|
inline void Node::push_back(const Node& rhs) {
|
||||||
if (!m_isValid || !rhs.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
rhs.EnsureNodeExists();
|
rhs.EnsureNodeExists();
|
||||||
|
|
||||||
@ -323,99 +315,49 @@ inline void Node::push_back(const Node& rhs) {
|
|||||||
m_pMemory->merge(*rhs.m_pMemory);
|
m_pMemory->merge(*rhs.m_pMemory);
|
||||||
}
|
}
|
||||||
|
|
||||||
// helpers for indexing
|
template<typename Key>
|
||||||
namespace detail {
|
std::string key_to_string(const Key& key) {
|
||||||
template <typename T>
|
return streamable_to_string<Key, is_streamable<std::stringstream, Key>::value>().impl(key);
|
||||||
struct to_value_t {
|
|
||||||
explicit to_value_t(const T& t_) : t(t_) {}
|
|
||||||
const T& t;
|
|
||||||
typedef const T& return_type;
|
|
||||||
|
|
||||||
const T& operator()() const { return t; }
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct to_value_t<const char*> {
|
|
||||||
explicit to_value_t(const char* t_) : t(t_) {}
|
|
||||||
const char* t;
|
|
||||||
typedef std::string return_type;
|
|
||||||
|
|
||||||
const std::string operator()() const { return t; }
|
|
||||||
};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct to_value_t<char*> {
|
|
||||||
explicit to_value_t(char* t_) : t(t_) {}
|
|
||||||
const char* t;
|
|
||||||
typedef std::string return_type;
|
|
||||||
|
|
||||||
const std::string operator()() const { return t; }
|
|
||||||
};
|
|
||||||
|
|
||||||
template <std::size_t N>
|
|
||||||
struct to_value_t<char[N]> {
|
|
||||||
explicit to_value_t(const char* t_) : t(t_) {}
|
|
||||||
const char* t;
|
|
||||||
typedef std::string return_type;
|
|
||||||
|
|
||||||
const std::string operator()() const { return t; }
|
|
||||||
};
|
|
||||||
|
|
||||||
// converts C-strings to std::strings so they can be copied
|
|
||||||
template <typename T>
|
|
||||||
inline typename to_value_t<T>::return_type to_value(const T& t) {
|
|
||||||
return to_value_t<T>(t)();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// indexing
|
// indexing
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
inline const Node Node::operator[](const Key& key) const {
|
inline const Node Node::operator[](const Key& key) const {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
detail::node* value = static_cast<const detail::node&>(*m_pNode)
|
detail::node* value =
|
||||||
.get(detail::to_value(key), m_pMemory);
|
static_cast<const detail::node&>(*m_pNode).get(key, m_pMemory);
|
||||||
if (!value) {
|
if (!value) {
|
||||||
return Node(ZombieNode);
|
return Node(ZombieNode, key_to_string(key));
|
||||||
}
|
}
|
||||||
return Node(*value, m_pMemory);
|
return Node(*value, m_pMemory);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
inline Node Node::operator[](const Key& key) {
|
inline Node Node::operator[](const Key& key) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
detail::node& value = m_pNode->get(detail::to_value(key), m_pMemory);
|
detail::node& value = m_pNode->get(key, m_pMemory);
|
||||||
return Node(value, m_pMemory);
|
return Node(value, m_pMemory);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Key>
|
template <typename Key>
|
||||||
inline bool Node::remove(const Key& key) {
|
inline bool Node::remove(const Key& key) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
return m_pNode->remove(detail::to_value(key), m_pMemory);
|
return m_pNode->remove(key, m_pMemory);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const Node Node::operator[](const Node& key) const {
|
inline const Node Node::operator[](const Node& key) const {
|
||||||
if (!m_isValid || !key.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
key.EnsureNodeExists();
|
key.EnsureNodeExists();
|
||||||
m_pMemory->merge(*key.m_pMemory);
|
m_pMemory->merge(*key.m_pMemory);
|
||||||
detail::node* value =
|
detail::node* value =
|
||||||
static_cast<const detail::node&>(*m_pNode).get(*key.m_pNode, m_pMemory);
|
static_cast<const detail::node&>(*m_pNode).get(*key.m_pNode, m_pMemory);
|
||||||
if (!value) {
|
if (!value) {
|
||||||
return Node(ZombieNode);
|
return Node(ZombieNode, key_to_string(key));
|
||||||
}
|
}
|
||||||
return Node(*value, m_pMemory);
|
return Node(*value, m_pMemory);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Node Node::operator[](const Node& key) {
|
inline Node Node::operator[](const Node& key) {
|
||||||
if (!m_isValid || !key.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
key.EnsureNodeExists();
|
key.EnsureNodeExists();
|
||||||
m_pMemory->merge(*key.m_pMemory);
|
m_pMemory->merge(*key.m_pMemory);
|
||||||
@ -424,8 +366,6 @@ inline Node Node::operator[](const Node& key) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline bool Node::remove(const Node& key) {
|
inline bool Node::remove(const Node& key) {
|
||||||
if (!m_isValid || !key.m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
key.EnsureNodeExists();
|
key.EnsureNodeExists();
|
||||||
return m_pNode->remove(*key.m_pNode, m_pMemory);
|
return m_pNode->remove(*key.m_pNode, m_pMemory);
|
||||||
@ -434,15 +374,12 @@ inline bool Node::remove(const Node& key) {
|
|||||||
// map
|
// map
|
||||||
template <typename Key, typename Value>
|
template <typename Key, typename Value>
|
||||||
inline void Node::force_insert(const Key& key, const Value& value) {
|
inline void Node::force_insert(const Key& key, const Value& value) {
|
||||||
if (!m_isValid)
|
|
||||||
throw InvalidNode();
|
|
||||||
EnsureNodeExists();
|
EnsureNodeExists();
|
||||||
m_pNode->force_insert(detail::to_value(key), detail::to_value(value),
|
m_pNode->force_insert(key, value, m_pMemory);
|
||||||
m_pMemory);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// free functions
|
// free functions
|
||||||
inline bool operator==(const Node& lhs, const Node& rhs) { return lhs.is(rhs); }
|
inline bool operator==(const Node& lhs, const Node& rhs) { return lhs.is(rhs); }
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // NODE_IMPL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // NODE_IMPL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -15,10 +15,13 @@
|
|||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
// Assert in place so gcc + libc++ combination properly builds
|
||||||
|
static_assert(std::is_constructible<YAML::Node, const YAML::Node&>::value, "Node must be copy constructable");
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
struct iterator_value : public Node, std::pair<Node, Node> {
|
struct iterator_value : public Node, std::pair<Node, Node> {
|
||||||
iterator_value() {}
|
iterator_value() = default;
|
||||||
explicit iterator_value(const Node& rhs)
|
explicit iterator_value(const Node& rhs)
|
||||||
: Node(rhs),
|
: Node(rhs),
|
||||||
std::pair<Node, Node>(Node(Node::ZombieNode), Node(Node::ZombieNode)) {}
|
std::pair<Node, Node>(Node(Node::ZombieNode), Node(Node::ZombieNode)) {}
|
||||||
|
11
3rdparty/yaml-cpp/include/yaml-cpp/node/node.h
vendored
11
3rdparty/yaml-cpp/include/yaml-cpp/node/node.h
vendored
@ -8,11 +8,11 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
#include "yaml-cpp/dll.h"
|
#include "yaml-cpp/dll.h"
|
||||||
#include "yaml-cpp/emitterstyle.h"
|
#include "yaml-cpp/emitterstyle.h"
|
||||||
#include "yaml-cpp/mark.h"
|
#include "yaml-cpp/mark.h"
|
||||||
#include "yaml-cpp/node/detail/bool_type.h"
|
|
||||||
#include "yaml-cpp/node/detail/iterator_fwd.h"
|
#include "yaml-cpp/node/detail/iterator_fwd.h"
|
||||||
#include "yaml-cpp/node/ptr.h"
|
#include "yaml-cpp/node/ptr.h"
|
||||||
#include "yaml-cpp/node/type.h"
|
#include "yaml-cpp/node/type.h"
|
||||||
@ -38,8 +38,8 @@ class YAML_CPP_API Node {
|
|||||||
template <typename T, typename S>
|
template <typename T, typename S>
|
||||||
friend struct as_if;
|
friend struct as_if;
|
||||||
|
|
||||||
typedef YAML::iterator iterator;
|
using iterator = YAML::iterator;
|
||||||
typedef YAML::const_iterator const_iterator;
|
using const_iterator = YAML::const_iterator;
|
||||||
|
|
||||||
Node();
|
Node();
|
||||||
explicit Node(NodeType::value type);
|
explicit Node(NodeType::value type);
|
||||||
@ -58,7 +58,7 @@ class YAML_CPP_API Node {
|
|||||||
bool IsMap() const { return Type() == NodeType::Map; }
|
bool IsMap() const { return Type() == NodeType::Map; }
|
||||||
|
|
||||||
// bool conversions
|
// bool conversions
|
||||||
YAML_CPP_OPERATOR_BOOL()
|
explicit operator bool() const { return IsDefined(); }
|
||||||
bool operator!() const { return !IsDefined(); }
|
bool operator!() const { return !IsDefined(); }
|
||||||
|
|
||||||
// access
|
// access
|
||||||
@ -116,6 +116,7 @@ class YAML_CPP_API Node {
|
|||||||
private:
|
private:
|
||||||
enum Zombie { ZombieNode };
|
enum Zombie { ZombieNode };
|
||||||
explicit Node(Zombie);
|
explicit Node(Zombie);
|
||||||
|
explicit Node(Zombie, const std::string&);
|
||||||
explicit Node(detail::node& node, detail::shared_memory_holder pMemory);
|
explicit Node(detail::node& node, detail::shared_memory_holder pMemory);
|
||||||
|
|
||||||
void EnsureNodeExists() const;
|
void EnsureNodeExists() const;
|
||||||
@ -130,6 +131,8 @@ class YAML_CPP_API Node {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_isValid;
|
bool m_isValid;
|
||||||
|
// String representation of invalid key, if the node is invalid.
|
||||||
|
std::string m_invalidKey;
|
||||||
mutable detail::shared_memory_holder m_pMemory;
|
mutable detail::shared_memory_holder m_pMemory;
|
||||||
mutable detail::node* m_pNode;
|
mutable detail::node* m_pNode;
|
||||||
};
|
};
|
||||||
|
11
3rdparty/yaml-cpp/include/yaml-cpp/node/ptr.h
vendored
11
3rdparty/yaml-cpp/include/yaml-cpp/node/ptr.h
vendored
@ -7,7 +7,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/dll.h"
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
@ -18,11 +17,11 @@ class node_data;
|
|||||||
class memory;
|
class memory;
|
||||||
class memory_holder;
|
class memory_holder;
|
||||||
|
|
||||||
typedef std::shared_ptr<node> shared_node;
|
using shared_node = std::shared_ptr<node>;
|
||||||
typedef std::shared_ptr<node_ref> shared_node_ref;
|
using shared_node_ref = std::shared_ptr<node_ref>;
|
||||||
typedef std::shared_ptr<node_data> shared_node_data;
|
using shared_node_data = std::shared_ptr<node_data>;
|
||||||
typedef std::shared_ptr<memory_holder> shared_memory_holder;
|
using shared_memory_holder = std::shared_ptr<memory_holder>;
|
||||||
typedef std::shared_ptr<memory> shared_memory;
|
using shared_memory = std::shared_ptr<memory>;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
18
3rdparty/yaml-cpp/include/yaml-cpp/noexcept.h
vendored
Normal file
18
3rdparty/yaml-cpp/include/yaml-cpp/noexcept.h
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#ifndef NOEXCEPT_H_768872DA_476C_11EA_88B8_90B11C0C0FF8
|
||||||
|
#define NOEXCEPT_H_768872DA_476C_11EA_88B8_90B11C0C0FF8
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) || \
|
||||||
|
(defined(__GNUC__) && (__GNUC__ == 3 && __GNUC_MINOR__ >= 4) || \
|
||||||
|
(__GNUC__ >= 4)) // GCC supports "pragma once" correctly since 3.4
|
||||||
|
#pragma once
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// This is here for compatibility with older versions of Visual Studio
|
||||||
|
// which don't support noexcept.
|
||||||
|
#if defined(_MSC_VER) && _MSC_VER < 1900
|
||||||
|
#define YAML_CPP_NOEXCEPT _NOEXCEPT
|
||||||
|
#else
|
||||||
|
#define YAML_CPP_NOEXCEPT noexcept
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
@ -17,6 +17,10 @@ class YAML_CPP_API ostream_wrapper {
|
|||||||
public:
|
public:
|
||||||
ostream_wrapper();
|
ostream_wrapper();
|
||||||
explicit ostream_wrapper(std::ostream& stream);
|
explicit ostream_wrapper(std::ostream& stream);
|
||||||
|
ostream_wrapper(const ostream_wrapper&) = delete;
|
||||||
|
ostream_wrapper(ostream_wrapper&&) = delete;
|
||||||
|
ostream_wrapper& operator=(const ostream_wrapper&) = delete;
|
||||||
|
ostream_wrapper& operator=(ostream_wrapper&&) = delete;
|
||||||
~ostream_wrapper();
|
~ostream_wrapper();
|
||||||
|
|
||||||
void write(const std::string& str);
|
void write(const std::string& str);
|
||||||
@ -26,7 +30,7 @@ class YAML_CPP_API ostream_wrapper {
|
|||||||
|
|
||||||
const char* str() const {
|
const char* str() const {
|
||||||
if (m_pStream) {
|
if (m_pStream) {
|
||||||
return 0;
|
return nullptr;
|
||||||
} else {
|
} else {
|
||||||
m_buffer[m_pos] = '\0';
|
m_buffer[m_pos] = '\0';
|
||||||
return &m_buffer[0];
|
return &m_buffer[0];
|
||||||
@ -67,6 +71,6 @@ inline ostream_wrapper& operator<<(ostream_wrapper& stream, char ch) {
|
|||||||
stream.write(&ch, 1);
|
stream.write(&ch, 1);
|
||||||
return stream;
|
return stream;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // OSTREAM_WRAPPER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // OSTREAM_WRAPPER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
10
3rdparty/yaml-cpp/include/yaml-cpp/parser.h
vendored
10
3rdparty/yaml-cpp/include/yaml-cpp/parser.h
vendored
@ -11,7 +11,6 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#include "yaml-cpp/dll.h"
|
#include "yaml-cpp/dll.h"
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
class EventHandler;
|
class EventHandler;
|
||||||
@ -24,11 +23,16 @@ struct Token;
|
|||||||
* A parser turns a stream of bytes into one stream of "events" per YAML
|
* A parser turns a stream of bytes into one stream of "events" per YAML
|
||||||
* document in the input stream.
|
* document in the input stream.
|
||||||
*/
|
*/
|
||||||
class YAML_CPP_API Parser : private noncopyable {
|
class YAML_CPP_API Parser {
|
||||||
public:
|
public:
|
||||||
/** Constructs an empty parser (with no input. */
|
/** Constructs an empty parser (with no input. */
|
||||||
Parser();
|
Parser();
|
||||||
|
|
||||||
|
Parser(const Parser&) = delete;
|
||||||
|
Parser(Parser&&) = delete;
|
||||||
|
Parser& operator=(const Parser&) = delete;
|
||||||
|
Parser& operator=(Parser&&) = delete;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a parser from the given input stream. The input stream must
|
* Constructs a parser from the given input stream. The input stream must
|
||||||
* live as long as the parser.
|
* live as long as the parser.
|
||||||
@ -81,6 +85,6 @@ class YAML_CPP_API Parser : private noncopyable {
|
|||||||
std::unique_ptr<Scanner> m_pScanner;
|
std::unique_ptr<Scanner> m_pScanner;
|
||||||
std::unique_ptr<Directives> m_pDirectives;
|
std::unique_ptr<Directives> m_pDirectives;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // PARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // PARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -16,8 +16,8 @@ namespace YAML {
|
|||||||
template <typename Seq>
|
template <typename Seq>
|
||||||
inline Emitter& EmitSeq(Emitter& emitter, const Seq& seq) {
|
inline Emitter& EmitSeq(Emitter& emitter, const Seq& seq) {
|
||||||
emitter << BeginSeq;
|
emitter << BeginSeq;
|
||||||
for (typename Seq::const_iterator it = seq.begin(); it != seq.end(); ++it)
|
for (const auto& v : seq)
|
||||||
emitter << *it;
|
emitter << v;
|
||||||
emitter << EndSeq;
|
emitter << EndSeq;
|
||||||
return emitter;
|
return emitter;
|
||||||
}
|
}
|
||||||
@ -39,10 +39,9 @@ inline Emitter& operator<<(Emitter& emitter, const std::set<T>& v) {
|
|||||||
|
|
||||||
template <typename K, typename V>
|
template <typename K, typename V>
|
||||||
inline Emitter& operator<<(Emitter& emitter, const std::map<K, V>& m) {
|
inline Emitter& operator<<(Emitter& emitter, const std::map<K, V>& m) {
|
||||||
typedef typename std::map<K, V> map;
|
|
||||||
emitter << BeginMap;
|
emitter << BeginMap;
|
||||||
for (typename map::const_iterator it = m.begin(); it != m.end(); ++it)
|
for (const auto& v : m)
|
||||||
emitter << Key << it->first << Value << it->second;
|
emitter << Key << v.first << Value << v.second;
|
||||||
emitter << EndMap;
|
emitter << EndMap;
|
||||||
return emitter;
|
return emitter;
|
||||||
}
|
}
|
||||||
|
36
3rdparty/yaml-cpp/include/yaml-cpp/traits.h
vendored
36
3rdparty/yaml-cpp/include/yaml-cpp/traits.h
vendored
@ -7,6 +7,11 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <type_traits>
|
||||||
|
#include <utility>
|
||||||
|
#include <string>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
template <typename>
|
template <typename>
|
||||||
struct is_numeric {
|
struct is_numeric {
|
||||||
@ -79,7 +84,7 @@ struct is_numeric<long double> {
|
|||||||
|
|
||||||
template <bool, class T = void>
|
template <bool, class T = void>
|
||||||
struct enable_if_c {
|
struct enable_if_c {
|
||||||
typedef T type;
|
using type = T;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
@ -90,7 +95,7 @@ struct enable_if : public enable_if_c<Cond::value, T> {};
|
|||||||
|
|
||||||
template <bool, class T = void>
|
template <bool, class T = void>
|
||||||
struct disable_if_c {
|
struct disable_if_c {
|
||||||
typedef T type;
|
using type = T;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
@ -100,4 +105,31 @@ template <class Cond, class T = void>
|
|||||||
struct disable_if : public disable_if_c<Cond::value, T> {};
|
struct disable_if : public disable_if_c<Cond::value, T> {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename S, typename T>
|
||||||
|
struct is_streamable {
|
||||||
|
template <typename StreamT, typename ValueT>
|
||||||
|
static auto test(int)
|
||||||
|
-> decltype(std::declval<StreamT&>() << std::declval<ValueT>(), std::true_type());
|
||||||
|
|
||||||
|
template <typename, typename>
|
||||||
|
static auto test(...) -> std::false_type;
|
||||||
|
|
||||||
|
static const bool value = decltype(test<S, T>(0))::value;
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename Key, bool Streamable>
|
||||||
|
struct streamable_to_string {
|
||||||
|
static std::string impl(const Key& key) {
|
||||||
|
std::stringstream ss;
|
||||||
|
ss << key;
|
||||||
|
return ss.str();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template<typename Key>
|
||||||
|
struct streamable_to_string<Key, false> {
|
||||||
|
static std::string impl(const Key&) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
};
|
||||||
#endif // TRAITS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // TRAITS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
17
3rdparty/yaml-cpp/src/binary.cpp
vendored
17
3rdparty/yaml-cpp/src/binary.cpp
vendored
@ -1,5 +1,7 @@
|
|||||||
#include "yaml-cpp/binary.h"
|
#include "yaml-cpp/binary.h"
|
||||||
|
|
||||||
|
#include <cctype>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
static const char encoding[] =
|
static const char encoding[] =
|
||||||
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
@ -64,7 +66,7 @@ static const unsigned char decoding[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
std::vector<unsigned char> DecodeBase64(const std::string &input) {
|
std::vector<unsigned char> DecodeBase64(const std::string &input) {
|
||||||
typedef std::vector<unsigned char> ret_type;
|
using ret_type = std::vector<unsigned char>;
|
||||||
if (input.empty())
|
if (input.empty())
|
||||||
return ret_type();
|
return ret_type();
|
||||||
|
|
||||||
@ -72,22 +74,27 @@ std::vector<unsigned char> DecodeBase64(const std::string &input) {
|
|||||||
unsigned char *out = &ret[0];
|
unsigned char *out = &ret[0];
|
||||||
|
|
||||||
unsigned value = 0;
|
unsigned value = 0;
|
||||||
for (std::size_t i = 0; i < input.size(); i++) {
|
for (std::size_t i = 0, cnt = 0; i < input.size(); i++) {
|
||||||
unsigned char d = decoding[static_cast<unsigned>(input[i])];
|
if (std::isspace(static_cast<unsigned char>(input[i]))) {
|
||||||
|
// skip newlines
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
unsigned char d = decoding[static_cast<unsigned char>(input[i])];
|
||||||
if (d == 255)
|
if (d == 255)
|
||||||
return ret_type();
|
return ret_type();
|
||||||
|
|
||||||
value = (value << 6) | d;
|
value = (value << 6) | d;
|
||||||
if (i % 4 == 3) {
|
if (cnt % 4 == 3) {
|
||||||
*out++ = value >> 16;
|
*out++ = value >> 16;
|
||||||
if (i > 0 && input[i - 1] != '=')
|
if (i > 0 && input[i - 1] != '=')
|
||||||
*out++ = value >> 8;
|
*out++ = value >> 8;
|
||||||
if (input[i] != '=')
|
if (input[i] != '=')
|
||||||
*out++ = value;
|
*out++ = value;
|
||||||
}
|
}
|
||||||
|
++cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret.resize(out - &ret[0]);
|
ret.resize(out - &ret[0]);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
6
3rdparty/yaml-cpp/src/collectionstack.h
vendored
6
3rdparty/yaml-cpp/src/collectionstack.h
vendored
@ -7,8 +7,8 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <stack>
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
#include <stack>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
struct CollectionType {
|
struct CollectionType {
|
||||||
@ -17,6 +17,7 @@ struct CollectionType {
|
|||||||
|
|
||||||
class CollectionStack {
|
class CollectionStack {
|
||||||
public:
|
public:
|
||||||
|
CollectionStack() : collectionStack{} {}
|
||||||
CollectionType::value GetCurCollectionType() const {
|
CollectionType::value GetCurCollectionType() const {
|
||||||
if (collectionStack.empty())
|
if (collectionStack.empty())
|
||||||
return CollectionType::NoCollection;
|
return CollectionType::NoCollection;
|
||||||
@ -28,12 +29,13 @@ class CollectionStack {
|
|||||||
}
|
}
|
||||||
void PopCollectionType(CollectionType::value type) {
|
void PopCollectionType(CollectionType::value type) {
|
||||||
assert(type == GetCurCollectionType());
|
assert(type == GetCurCollectionType());
|
||||||
|
(void)type;
|
||||||
collectionStack.pop();
|
collectionStack.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::stack<CollectionType::value> collectionStack;
|
std::stack<CollectionType::value> collectionStack;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // COLLECTIONSTACK_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // COLLECTIONSTACK_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
@ -10,8 +10,7 @@ void* BuildGraphOfNextDocument(Parser& parser,
|
|||||||
GraphBuilderAdapter eventHandler(graphBuilder);
|
GraphBuilderAdapter eventHandler(graphBuilder);
|
||||||
if (parser.HandleNextDocument(eventHandler)) {
|
if (parser.HandleNextDocument(eventHandler)) {
|
||||||
return eventHandler.RootNode();
|
return eventHandler.RootNode();
|
||||||
} else {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
} // namespace YAML
|
||||||
|
@ -49,7 +49,7 @@ void GraphBuilderAdapter::OnMapStart(const Mark &mark, const std::string &tag,
|
|||||||
EmitterStyle::value /* style */) {
|
EmitterStyle::value /* style */) {
|
||||||
void *pNode = m_builder.NewMap(mark, tag, GetCurrentParent());
|
void *pNode = m_builder.NewMap(mark, tag, GetCurrentParent());
|
||||||
m_containers.push(ContainerFrame(pNode, m_pKeyNode));
|
m_containers.push(ContainerFrame(pNode, m_pKeyNode));
|
||||||
m_pKeyNode = NULL;
|
m_pKeyNode = nullptr;
|
||||||
RegisterAnchor(anchor, pNode);
|
RegisterAnchor(anchor, pNode);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -62,7 +62,7 @@ void GraphBuilderAdapter::OnMapEnd() {
|
|||||||
|
|
||||||
void *GraphBuilderAdapter::GetCurrentParent() const {
|
void *GraphBuilderAdapter::GetCurrentParent() const {
|
||||||
if (m_containers.empty()) {
|
if (m_containers.empty()) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return m_containers.top().pContainer;
|
return m_containers.top().pContainer;
|
||||||
}
|
}
|
||||||
@ -83,7 +83,7 @@ void GraphBuilderAdapter::DispositionNode(void *pNode) {
|
|||||||
if (m_containers.top().isMap()) {
|
if (m_containers.top().isMap()) {
|
||||||
if (m_pKeyNode) {
|
if (m_pKeyNode) {
|
||||||
m_builder.AssignInMap(pContainer, m_pKeyNode, pNode);
|
m_builder.AssignInMap(pContainer, m_pKeyNode, pNode);
|
||||||
m_pKeyNode = NULL;
|
m_pKeyNode = nullptr;
|
||||||
} else {
|
} else {
|
||||||
m_pKeyNode = pNode;
|
m_pKeyNode = pNode;
|
||||||
}
|
}
|
||||||
@ -91,4 +91,4 @@ void GraphBuilderAdapter::DispositionNode(void *pNode) {
|
|||||||
m_builder.AppendToSequence(pContainer, pNode);
|
m_builder.AppendToSequence(pContainer, pNode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
@ -13,7 +13,6 @@
|
|||||||
|
|
||||||
#include "yaml-cpp/anchor.h"
|
#include "yaml-cpp/anchor.h"
|
||||||
#include "yaml-cpp/contrib/anchordict.h"
|
#include "yaml-cpp/contrib/anchordict.h"
|
||||||
#include "yaml-cpp/contrib/graphbuilder.h"
|
|
||||||
#include "yaml-cpp/emitterstyle.h"
|
#include "yaml-cpp/emitterstyle.h"
|
||||||
#include "yaml-cpp/eventhandler.h"
|
#include "yaml-cpp/eventhandler.h"
|
||||||
|
|
||||||
@ -26,7 +25,15 @@ namespace YAML {
|
|||||||
class GraphBuilderAdapter : public EventHandler {
|
class GraphBuilderAdapter : public EventHandler {
|
||||||
public:
|
public:
|
||||||
GraphBuilderAdapter(GraphBuilderInterface& builder)
|
GraphBuilderAdapter(GraphBuilderInterface& builder)
|
||||||
: m_builder(builder), m_pRootNode(NULL), m_pKeyNode(NULL) {}
|
: m_builder(builder),
|
||||||
|
m_containers{},
|
||||||
|
m_anchors{},
|
||||||
|
m_pRootNode(nullptr),
|
||||||
|
m_pKeyNode(nullptr) {}
|
||||||
|
GraphBuilderAdapter(const GraphBuilderAdapter&) = delete;
|
||||||
|
GraphBuilderAdapter(GraphBuilderAdapter&&) = delete;
|
||||||
|
GraphBuilderAdapter& operator=(const GraphBuilderAdapter&) = delete;
|
||||||
|
GraphBuilderAdapter& operator=(GraphBuilderAdapter&&) = delete;
|
||||||
|
|
||||||
virtual void OnDocumentStart(const Mark& mark) { (void)mark; }
|
virtual void OnDocumentStart(const Mark& mark) { (void)mark; }
|
||||||
virtual void OnDocumentEnd() {}
|
virtual void OnDocumentEnd() {}
|
||||||
@ -50,8 +57,8 @@ class GraphBuilderAdapter : public EventHandler {
|
|||||||
struct ContainerFrame {
|
struct ContainerFrame {
|
||||||
ContainerFrame(void* pSequence)
|
ContainerFrame(void* pSequence)
|
||||||
: pContainer(pSequence), pPrevKeyNode(&sequenceMarker) {}
|
: pContainer(pSequence), pPrevKeyNode(&sequenceMarker) {}
|
||||||
ContainerFrame(void* pMap, void* pPrevKeyNode_)
|
ContainerFrame(void* pMap, void* pPreviousKeyNode)
|
||||||
: pContainer(pMap), pPrevKeyNode(pPrevKeyNode_) {}
|
: pContainer(pMap), pPrevKeyNode(pPreviousKeyNode) {}
|
||||||
|
|
||||||
void* pContainer;
|
void* pContainer;
|
||||||
void* pPrevKeyNode;
|
void* pPrevKeyNode;
|
||||||
@ -74,6 +81,6 @@ class GraphBuilderAdapter : public EventHandler {
|
|||||||
void RegisterAnchor(anchor_t anchor, void* pNode);
|
void RegisterAnchor(anchor_t anchor, void* pNode);
|
||||||
void DispositionNode(void* pNode);
|
void DispositionNode(void* pNode);
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // GRAPHBUILDERADAPTER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // GRAPHBUILDERADAPTER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
32
3rdparty/yaml-cpp/src/contrib/yaml-cpp.natvis
vendored
Normal file
32
3rdparty/yaml-cpp/src/contrib/yaml-cpp.natvis
vendored
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- MSVC Debugger visualization hints for YAML::Node and YAML::detail::node -->
|
||||||
|
<AutoVisualizer xmlns="http://schemas.microsoft.com/vstudio/debugger/natvis/2010">
|
||||||
|
<Type Name="YAML::Node">
|
||||||
|
<DisplayString Condition="!m_isValid">{{invalid}}</DisplayString>
|
||||||
|
<DisplayString Condition="!m_pNode">{{pNode==nullptr}}</DisplayString>
|
||||||
|
<DisplayString>{{ {*m_pNode} }}</DisplayString>
|
||||||
|
<Expand>
|
||||||
|
<Item Condition="m_pNode->m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Scalar" Name="scalar">m_pNode->m_pRef._Ptr->m_pData._Ptr->m_scalar</Item>
|
||||||
|
<Item Condition="m_pNode->m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Sequence" Name="sequence">m_pNode->m_pRef._Ptr->m_pData._Ptr->m_sequence</Item>
|
||||||
|
<Item Condition="m_pNode->m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Map" Name="map">m_pNode->m_pRef._Ptr->m_pData._Ptr->m_map</Item>
|
||||||
|
<Item Name="[details]" >m_pNode->m_pRef._Ptr->m_pData._Ptr</Item>
|
||||||
|
</Expand>
|
||||||
|
</Type>
|
||||||
|
|
||||||
|
<Type Name="YAML::detail::node">
|
||||||
|
<DisplayString Condition="!m_pRef._Ptr">{{node:pRef==nullptr}}</DisplayString>
|
||||||
|
<DisplayString Condition="!m_pRef._Ptr->m_pData._Ptr">{{node:pRef->pData==nullptr}}</DisplayString>
|
||||||
|
<DisplayString Condition="!m_pRef._Ptr->m_pData._Ptr->m_isDefined">{{undefined}}</DisplayString>
|
||||||
|
<DisplayString Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Scalar">{{{m_pRef._Ptr->m_pData._Ptr->m_scalar}}}</DisplayString>
|
||||||
|
<DisplayString Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Map">{{ Map {m_pRef._Ptr->m_pData._Ptr->m_map}}}</DisplayString>
|
||||||
|
<DisplayString Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Sequence">{{ Seq {m_pRef._Ptr->m_pData._Ptr->m_sequence}}}</DisplayString>
|
||||||
|
<DisplayString>{{{m_pRef._Ptr->m_pData._Ptr->m_type}}}</DisplayString>
|
||||||
|
<Expand>
|
||||||
|
<Item Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Scalar" Name="scalar">m_pRef._Ptr->m_pData._Ptr->m_scalar</Item>
|
||||||
|
<Item Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Sequence" Name="sequence">m_pRef._Ptr->m_pData._Ptr->m_sequence</Item>
|
||||||
|
<Item Condition="m_pRef._Ptr->m_pData._Ptr->m_type==YAML::NodeType::Map" Name="map">m_pRef._Ptr->m_pData._Ptr->m_map</Item>
|
||||||
|
<Item Name="[details]" >m_pRef._Ptr->m_pData._Ptr</Item>
|
||||||
|
</Expand>
|
||||||
|
</Type>
|
||||||
|
|
||||||
|
</AutoVisualizer>
|
9
3rdparty/yaml-cpp/src/contrib/yaml-cpp.natvis.md
vendored
Normal file
9
3rdparty/yaml-cpp/src/contrib/yaml-cpp.natvis.md
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# MSVC debugger visualizer for YAML::Node
|
||||||
|
|
||||||
|
## How to use
|
||||||
|
Add yaml-cpp.natvis to your Visual C++ project like any other source file. It will be included in the debug information, and improve debugger display on YAML::Node and contained types.
|
||||||
|
|
||||||
|
## Compatibility and Troubleshooting
|
||||||
|
|
||||||
|
This has been tested for MSVC 2017. It is expected to be compatible with VS 2015 and VS 2019. If you have any problems, you can open an issue here: https://github.com/peterchen-cp/yaml-cpp-natvis
|
||||||
|
|
21
3rdparty/yaml-cpp/src/convert.cpp
vendored
21
3rdparty/yaml-cpp/src/convert.cpp
vendored
@ -16,11 +16,7 @@ std::string tolower(const std::string& str) {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
bool IsEntirely(const std::string& str, T func) {
|
bool IsEntirely(const std::string& str, T func) {
|
||||||
for (std::size_t i = 0; i < str.size(); i++)
|
return std::all_of(str.begin(), str.end(), [=](char ch) { return func(ch); });
|
||||||
if (!func(str[i]))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsFlexibleCase
|
// IsFlexibleCase
|
||||||
@ -39,7 +35,7 @@ bool IsFlexibleCase(const std::string& str) {
|
|||||||
std::string rest = str.substr(1);
|
std::string rest = str.substr(1);
|
||||||
return firstcaps && (IsEntirely(rest, IsLower) || IsEntirely(rest, IsUpper));
|
return firstcaps && (IsEntirely(rest, IsLower) || IsEntirely(rest, IsUpper));
|
||||||
}
|
}
|
||||||
}
|
} // namespace
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
bool convert<bool>::decode(const Node& node, bool& rhs) {
|
bool convert<bool>::decode(const Node& node, bool& rhs) {
|
||||||
@ -52,19 +48,22 @@ bool convert<bool>::decode(const Node& node, bool& rhs) {
|
|||||||
static const struct {
|
static const struct {
|
||||||
std::string truename, falsename;
|
std::string truename, falsename;
|
||||||
} names[] = {
|
} names[] = {
|
||||||
{"y", "n"}, {"yes", "no"}, {"true", "false"}, {"on", "off"},
|
{"y", "n"},
|
||||||
|
{"yes", "no"},
|
||||||
|
{"true", "false"},
|
||||||
|
{"on", "off"},
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!IsFlexibleCase(node.Scalar()))
|
if (!IsFlexibleCase(node.Scalar()))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (unsigned i = 0; i < sizeof(names) / sizeof(names[0]); i++) {
|
for (const auto& name : names) {
|
||||||
if (names[i].truename == tolower(node.Scalar())) {
|
if (name.truename == tolower(node.Scalar())) {
|
||||||
rhs = true;
|
rhs = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (names[i].falsename == tolower(node.Scalar())) {
|
if (name.falsename == tolower(node.Scalar())) {
|
||||||
rhs = false;
|
rhs = false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -72,4 +71,4 @@ bool convert<bool>::decode(const Node& node, bool& rhs) {
|
|||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
9
3rdparty/yaml-cpp/src/depthguard.cpp
vendored
Normal file
9
3rdparty/yaml-cpp/src/depthguard.cpp
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
#include "yaml-cpp/depthguard.h"
|
||||||
|
|
||||||
|
namespace YAML {
|
||||||
|
|
||||||
|
DeepRecursion::DeepRecursion(int depth, const Mark& mark_,
|
||||||
|
const std::string& msg_)
|
||||||
|
: ParserException(mark_, msg_), m_depth(depth) {}
|
||||||
|
|
||||||
|
} // namespace YAML
|
13
3rdparty/yaml-cpp/src/directives.cpp
vendored
13
3rdparty/yaml-cpp/src/directives.cpp
vendored
@ -1,16 +1,11 @@
|
|||||||
#include "directives.h"
|
#include "directives.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
Directives::Directives() {
|
Directives::Directives() : version{true, 1, 2}, tags{} {}
|
||||||
// version
|
|
||||||
version.isDefault = true;
|
|
||||||
version.major = 1;
|
|
||||||
version.minor = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string Directives::TranslateTagHandle(
|
std::string Directives::TranslateTagHandle(
|
||||||
const std::string& handle) const {
|
const std::string& handle) const {
|
||||||
std::map<std::string, std::string>::const_iterator it = tags.find(handle);
|
auto it = tags.find(handle);
|
||||||
if (it == tags.end()) {
|
if (it == tags.end()) {
|
||||||
if (handle == "!!")
|
if (handle == "!!")
|
||||||
return "tag:yaml.org,2002:";
|
return "tag:yaml.org,2002:";
|
||||||
@ -19,4 +14,4 @@ const std::string Directives::TranslateTagHandle(
|
|||||||
|
|
||||||
return it->second;
|
return it->second;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
2
3rdparty/yaml-cpp/src/directives.h
vendored
2
3rdparty/yaml-cpp/src/directives.h
vendored
@ -19,7 +19,7 @@ struct Version {
|
|||||||
struct Directives {
|
struct Directives {
|
||||||
Directives();
|
Directives();
|
||||||
|
|
||||||
const std::string TranslateTagHandle(const std::string& handle) const;
|
std::string TranslateTagHandle(const std::string& handle) const;
|
||||||
|
|
||||||
Version version;
|
Version version;
|
||||||
std::map<std::string, std::string> tags;
|
std::map<std::string, std::string> tags;
|
||||||
|
2
3rdparty/yaml-cpp/src/emit.cpp
vendored
2
3rdparty/yaml-cpp/src/emit.cpp
vendored
@ -1,7 +1,7 @@
|
|||||||
#include "yaml-cpp/node/emit.h"
|
#include "yaml-cpp/node/emit.h"
|
||||||
|
#include "nodeevents.h"
|
||||||
#include "yaml-cpp/emitfromevents.h"
|
#include "yaml-cpp/emitfromevents.h"
|
||||||
#include "yaml-cpp/emitter.h"
|
#include "yaml-cpp/emitter.h"
|
||||||
#include "nodeevents.h"
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
Emitter& operator<<(Emitter& out, const Node& node) {
|
Emitter& operator<<(Emitter& out, const Node& node) {
|
||||||
|
11
3rdparty/yaml-cpp/src/emitfromevents.cpp
vendored
11
3rdparty/yaml-cpp/src/emitfromevents.cpp
vendored
@ -16,10 +16,11 @@ std::string ToString(YAML::anchor_t anchor) {
|
|||||||
stream << anchor;
|
stream << anchor;
|
||||||
return stream.str();
|
return stream.str();
|
||||||
}
|
}
|
||||||
}
|
} // namespace
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
EmitFromEvents::EmitFromEvents(Emitter& emitter) : m_emitter(emitter) {}
|
EmitFromEvents::EmitFromEvents(Emitter& emitter)
|
||||||
|
: m_emitter(emitter), m_stateStack{} {}
|
||||||
|
|
||||||
void EmitFromEvents::OnDocumentStart(const Mark&) {}
|
void EmitFromEvents::OnDocumentStart(const Mark&) {}
|
||||||
|
|
||||||
@ -58,6 +59,8 @@ void EmitFromEvents::OnSequenceStart(const Mark&, const std::string& tag,
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
// Restore the global settings to eliminate the override from node style
|
||||||
|
m_emitter.RestoreGlobalModifiedSettings();
|
||||||
m_emitter << BeginSeq;
|
m_emitter << BeginSeq;
|
||||||
m_stateStack.push(State::WaitingForSequenceEntry);
|
m_stateStack.push(State::WaitingForSequenceEntry);
|
||||||
}
|
}
|
||||||
@ -82,6 +85,8 @@ void EmitFromEvents::OnMapStart(const Mark&, const std::string& tag,
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
// Restore the global settings to eliminate the override from node style
|
||||||
|
m_emitter.RestoreGlobalModifiedSettings();
|
||||||
m_emitter << BeginMap;
|
m_emitter << BeginMap;
|
||||||
m_stateStack.push(State::WaitingForKey);
|
m_stateStack.push(State::WaitingForKey);
|
||||||
}
|
}
|
||||||
@ -116,4 +121,4 @@ void EmitFromEvents::EmitProps(const std::string& tag, anchor_t anchor) {
|
|||||||
if (anchor)
|
if (anchor)
|
||||||
m_emitter << Anchor(ToString(anchor));
|
m_emitter << Anchor(ToString(anchor));
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
91
3rdparty/yaml-cpp/src/emitter.cpp
vendored
91
3rdparty/yaml-cpp/src/emitter.cpp
vendored
@ -11,12 +11,12 @@ namespace YAML {
|
|||||||
class Binary;
|
class Binary;
|
||||||
struct _Null;
|
struct _Null;
|
||||||
|
|
||||||
Emitter::Emitter() : m_pState(new EmitterState) {}
|
Emitter::Emitter() : m_pState(new EmitterState), m_stream{} {}
|
||||||
|
|
||||||
Emitter::Emitter(std::ostream& stream)
|
Emitter::Emitter(std::ostream& stream)
|
||||||
: m_pState(new EmitterState), m_stream(stream) {}
|
: m_pState(new EmitterState), m_stream(stream) {}
|
||||||
|
|
||||||
Emitter::~Emitter() {}
|
Emitter::~Emitter() = default;
|
||||||
|
|
||||||
const char* Emitter::c_str() const { return m_stream.str(); }
|
const char* Emitter::c_str() const { return m_stream.str(); }
|
||||||
|
|
||||||
@ -90,6 +90,10 @@ bool Emitter::SetDoublePrecision(std::size_t n) {
|
|||||||
return m_pState->SetDoublePrecision(n, FmtScope::Global);
|
return m_pState->SetDoublePrecision(n, FmtScope::Global);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Emitter::RestoreGlobalModifiedSettings() {
|
||||||
|
m_pState->RestoreGlobalModifiedSettings();
|
||||||
|
}
|
||||||
|
|
||||||
// SetLocalValue
|
// SetLocalValue
|
||||||
// . Either start/end a group, or set a modifier locally
|
// . Either start/end a group, or set a modifier locally
|
||||||
Emitter& Emitter::SetLocalValue(EMITTER_MANIP value) {
|
Emitter& Emitter::SetLocalValue(EMITTER_MANIP value) {
|
||||||
@ -201,6 +205,7 @@ void Emitter::EmitBeginSeq() {
|
|||||||
void Emitter::EmitEndSeq() {
|
void Emitter::EmitEndSeq() {
|
||||||
if (!good())
|
if (!good())
|
||||||
return;
|
return;
|
||||||
|
FlowType::value originalType = m_pState->CurGroupFlowType();
|
||||||
|
|
||||||
if (m_pState->CurGroupChildCount() == 0)
|
if (m_pState->CurGroupChildCount() == 0)
|
||||||
m_pState->ForceFlow();
|
m_pState->ForceFlow();
|
||||||
@ -209,8 +214,12 @@ void Emitter::EmitEndSeq() {
|
|||||||
if (m_stream.comment())
|
if (m_stream.comment())
|
||||||
m_stream << "\n";
|
m_stream << "\n";
|
||||||
m_stream << IndentTo(m_pState->CurIndent());
|
m_stream << IndentTo(m_pState->CurIndent());
|
||||||
if (m_pState->CurGroupChildCount() == 0)
|
if (originalType == FlowType::Block) {
|
||||||
m_stream << "[";
|
m_stream << "[";
|
||||||
|
} else {
|
||||||
|
if (m_pState->CurGroupChildCount() == 0 && !m_pState->HasBegunNode())
|
||||||
|
m_stream << "[";
|
||||||
|
}
|
||||||
m_stream << "]";
|
m_stream << "]";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -231,6 +240,7 @@ void Emitter::EmitBeginMap() {
|
|||||||
void Emitter::EmitEndMap() {
|
void Emitter::EmitEndMap() {
|
||||||
if (!good())
|
if (!good())
|
||||||
return;
|
return;
|
||||||
|
FlowType::value originalType = m_pState->CurGroupFlowType();
|
||||||
|
|
||||||
if (m_pState->CurGroupChildCount() == 0)
|
if (m_pState->CurGroupChildCount() == 0)
|
||||||
m_pState->ForceFlow();
|
m_pState->ForceFlow();
|
||||||
@ -239,8 +249,12 @@ void Emitter::EmitEndMap() {
|
|||||||
if (m_stream.comment())
|
if (m_stream.comment())
|
||||||
m_stream << "\n";
|
m_stream << "\n";
|
||||||
m_stream << IndentTo(m_pState->CurIndent());
|
m_stream << IndentTo(m_pState->CurIndent());
|
||||||
if (m_pState->CurGroupChildCount() == 0)
|
if (originalType == FlowType::Block) {
|
||||||
m_stream << "{";
|
m_stream << "{";
|
||||||
|
} else {
|
||||||
|
if (m_pState->CurGroupChildCount() == 0 && !m_pState->HasBegunNode())
|
||||||
|
m_stream << "{";
|
||||||
|
}
|
||||||
m_stream << "}";
|
m_stream << "}";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -289,10 +303,8 @@ void Emitter::PrepareTopNode(EmitterNodeType::value child) {
|
|||||||
if (child == EmitterNodeType::NoType)
|
if (child == EmitterNodeType::NoType)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (m_pState->CurGroupChildCount() > 0 && m_stream.col() > 0) {
|
if (m_pState->CurGroupChildCount() > 0 && m_stream.col() > 0)
|
||||||
if (child != EmitterNodeType::NoType)
|
|
||||||
EmitBeginDoc();
|
EmitBeginDoc();
|
||||||
}
|
|
||||||
|
|
||||||
switch (child) {
|
switch (child) {
|
||||||
case EmitterNodeType::NoType:
|
case EmitterNodeType::NoType:
|
||||||
@ -492,6 +504,9 @@ void Emitter::FlowMapPrepareSimpleKeyValue(EmitterNodeType::value child) {
|
|||||||
if (m_stream.comment())
|
if (m_stream.comment())
|
||||||
m_stream << "\n";
|
m_stream << "\n";
|
||||||
m_stream << IndentTo(lastIndent);
|
m_stream << IndentTo(lastIndent);
|
||||||
|
if (m_pState->HasAlias()) {
|
||||||
|
m_stream << " ";
|
||||||
|
}
|
||||||
m_stream << ":";
|
m_stream << ":";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -518,7 +533,8 @@ void Emitter::BlockMapPrepareNode(EmitterNodeType::value child) {
|
|||||||
if (m_pState->GetMapKeyFormat() == LongKey)
|
if (m_pState->GetMapKeyFormat() == LongKey)
|
||||||
m_pState->SetLongKey();
|
m_pState->SetLongKey();
|
||||||
if (child == EmitterNodeType::BlockSeq ||
|
if (child == EmitterNodeType::BlockSeq ||
|
||||||
child == EmitterNodeType::BlockMap)
|
child == EmitterNodeType::BlockMap ||
|
||||||
|
child == EmitterNodeType::Property)
|
||||||
m_pState->SetLongKey();
|
m_pState->SetLongKey();
|
||||||
|
|
||||||
if (m_pState->CurGroupLongKey())
|
if (m_pState->CurGroupLongKey())
|
||||||
@ -562,6 +578,8 @@ void Emitter::BlockMapPrepareLongKey(EmitterNodeType::value child) {
|
|||||||
break;
|
break;
|
||||||
case EmitterNodeType::BlockSeq:
|
case EmitterNodeType::BlockSeq:
|
||||||
case EmitterNodeType::BlockMap:
|
case EmitterNodeType::BlockMap:
|
||||||
|
if (m_pState->HasBegunContent())
|
||||||
|
m_stream << "\n";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -585,8 +603,12 @@ void Emitter::BlockMapPrepareLongKeyValue(EmitterNodeType::value child) {
|
|||||||
case EmitterNodeType::Scalar:
|
case EmitterNodeType::Scalar:
|
||||||
case EmitterNodeType::FlowSeq:
|
case EmitterNodeType::FlowSeq:
|
||||||
case EmitterNodeType::FlowMap:
|
case EmitterNodeType::FlowMap:
|
||||||
|
SpaceOrIndentTo(true, curIndent + 1);
|
||||||
|
break;
|
||||||
case EmitterNodeType::BlockSeq:
|
case EmitterNodeType::BlockSeq:
|
||||||
case EmitterNodeType::BlockMap:
|
case EmitterNodeType::BlockMap:
|
||||||
|
if (m_pState->HasBegunContent())
|
||||||
|
m_stream << "\n";
|
||||||
SpaceOrIndentTo(true, curIndent + 1);
|
SpaceOrIndentTo(true, curIndent + 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -625,6 +647,9 @@ void Emitter::BlockMapPrepareSimpleKeyValue(EmitterNodeType::value child) {
|
|||||||
const std::size_t nextIndent = curIndent + m_pState->CurGroupIndent();
|
const std::size_t nextIndent = curIndent + m_pState->CurGroupIndent();
|
||||||
|
|
||||||
if (!m_pState->HasBegunNode()) {
|
if (!m_pState->HasBegunNode()) {
|
||||||
|
if (m_pState->HasAlias()) {
|
||||||
|
m_stream << " ";
|
||||||
|
}
|
||||||
m_stream << ":";
|
m_stream << ":";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -678,25 +703,29 @@ void Emitter::StartedScalar() { m_pState->StartedScalar(); }
|
|||||||
// *******************************************************************************************
|
// *******************************************************************************************
|
||||||
// overloads of Write
|
// overloads of Write
|
||||||
|
|
||||||
|
StringEscaping::value GetStringEscapingStyle(const EMITTER_MANIP emitterManip) {
|
||||||
|
switch (emitterManip) {
|
||||||
|
case EscapeNonAscii:
|
||||||
|
return StringEscaping::NonAscii;
|
||||||
|
case EscapeAsJson:
|
||||||
|
return StringEscaping::JSON;
|
||||||
|
default:
|
||||||
|
return StringEscaping::None;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Emitter& Emitter::Write(const std::string& str) {
|
Emitter& Emitter::Write(const std::string& str) {
|
||||||
if (!good())
|
if (!good())
|
||||||
return *this;
|
return *this;
|
||||||
|
|
||||||
StringEscaping::value stringEscaping = StringEscaping::None;
|
StringEscaping::value stringEscaping = GetStringEscapingStyle(m_pState->GetOutputCharset());
|
||||||
switch (m_pState->GetOutputCharset()) {
|
|
||||||
case EscapeNonAscii:
|
|
||||||
stringEscaping = StringEscaping::NonAscii;
|
|
||||||
break;
|
|
||||||
case EscapeAsJson:
|
|
||||||
stringEscaping = StringEscaping::JSON;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
const StringFormat::value strFormat =
|
const StringFormat::value strFormat =
|
||||||
Utils::ComputeStringFormat(str, m_pState->GetStringFormat(),
|
Utils::ComputeStringFormat(str, m_pState->GetStringFormat(),
|
||||||
m_pState->CurGroupFlowType(), stringEscaping == StringEscaping::NonAscii);
|
m_pState->CurGroupFlowType(), stringEscaping == StringEscaping::NonAscii);
|
||||||
|
|
||||||
if (strFormat == StringFormat::Literal)
|
if (strFormat == StringFormat::Literal || str.size() > 1024)
|
||||||
m_pState->SetMapKeyFormat(YAML::LongKey, FmtScope::Local);
|
m_pState->SetMapKeyFormat(YAML::LongKey, FmtScope::Local);
|
||||||
|
|
||||||
PrepareNode(EmitterNodeType::Scalar);
|
PrepareNode(EmitterNodeType::Scalar);
|
||||||
@ -779,6 +808,21 @@ const char* Emitter::ComputeFullBoolName(bool b) const {
|
|||||||
// these answers
|
// these answers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char* Emitter::ComputeNullName() const {
|
||||||
|
switch (m_pState->GetNullFormat()) {
|
||||||
|
case LowerNull:
|
||||||
|
return "null";
|
||||||
|
case UpperNull:
|
||||||
|
return "NULL";
|
||||||
|
case CamelNull:
|
||||||
|
return "Null";
|
||||||
|
case TildeNull:
|
||||||
|
// fallthrough
|
||||||
|
default:
|
||||||
|
return "~";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Emitter& Emitter::Write(bool b) {
|
Emitter& Emitter::Write(bool b) {
|
||||||
if (!good())
|
if (!good())
|
||||||
return *this;
|
return *this;
|
||||||
@ -803,7 +847,7 @@ Emitter& Emitter::Write(char ch) {
|
|||||||
|
|
||||||
|
|
||||||
PrepareNode(EmitterNodeType::Scalar);
|
PrepareNode(EmitterNodeType::Scalar);
|
||||||
Utils::WriteChar(m_stream, ch, m_pState->GetOutputCharset() == EscapeAsJson);
|
Utils::WriteChar(m_stream, ch, GetStringEscapingStyle(m_pState->GetOutputCharset()));
|
||||||
StartedScalar();
|
StartedScalar();
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
@ -827,6 +871,8 @@ Emitter& Emitter::Write(const _Alias& alias) {
|
|||||||
|
|
||||||
StartedScalar();
|
StartedScalar();
|
||||||
|
|
||||||
|
m_pState->SetAlias();
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -904,10 +950,7 @@ Emitter& Emitter::Write(const _Null& /*null*/) {
|
|||||||
|
|
||||||
PrepareNode(EmitterNodeType::Scalar);
|
PrepareNode(EmitterNodeType::Scalar);
|
||||||
|
|
||||||
if (m_pState->GetNullFormat() == NullAsNull)
|
m_stream << ComputeNullName();
|
||||||
m_stream << "null";
|
|
||||||
else
|
|
||||||
m_stream << "~";
|
|
||||||
|
|
||||||
StartedScalar();
|
StartedScalar();
|
||||||
|
|
||||||
@ -926,4 +969,4 @@ Emitter& Emitter::Write(const Binary& binary) {
|
|||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
79
3rdparty/yaml-cpp/src/emitterstate.cpp
vendored
79
3rdparty/yaml-cpp/src/emitterstate.cpp
vendored
@ -6,30 +6,35 @@
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
EmitterState::EmitterState()
|
EmitterState::EmitterState()
|
||||||
: m_isGood(true),
|
: m_isGood(true),
|
||||||
|
m_lastError{},
|
||||||
|
// default global manipulators
|
||||||
|
m_charset(EmitNonAscii),
|
||||||
|
m_strFmt(Auto),
|
||||||
|
m_boolFmt(TrueFalseBool),
|
||||||
|
m_boolLengthFmt(LongBool),
|
||||||
|
m_boolCaseFmt(LowerCase),
|
||||||
|
m_nullFmt(TildeNull),
|
||||||
|
m_intFmt(Dec),
|
||||||
|
m_indent(2),
|
||||||
|
m_preCommentIndent(2),
|
||||||
|
m_postCommentIndent(1),
|
||||||
|
m_seqFmt(Block),
|
||||||
|
m_mapFmt(Block),
|
||||||
|
m_mapKeyFmt(Auto),
|
||||||
|
m_floatPrecision(std::numeric_limits<float>::max_digits10),
|
||||||
|
m_doublePrecision(std::numeric_limits<double>::max_digits10),
|
||||||
|
//
|
||||||
|
m_modifiedSettings{},
|
||||||
|
m_globalModifiedSettings{},
|
||||||
|
m_groups{},
|
||||||
m_curIndent(0),
|
m_curIndent(0),
|
||||||
m_hasAnchor(false),
|
m_hasAnchor(false),
|
||||||
|
m_hasAlias(false),
|
||||||
m_hasTag(false),
|
m_hasTag(false),
|
||||||
m_hasNonContent(false),
|
m_hasNonContent(false),
|
||||||
m_docCount(0) {
|
m_docCount(0) {}
|
||||||
// set default global manipulators
|
|
||||||
m_charset.set(EmitNonAscii);
|
|
||||||
m_strFmt.set(Auto);
|
|
||||||
m_boolFmt.set(TrueFalseBool);
|
|
||||||
m_nullFmt.set(NullAsTilde);
|
|
||||||
m_boolLengthFmt.set(LongBool);
|
|
||||||
m_boolCaseFmt.set(LowerCase);
|
|
||||||
m_intFmt.set(Dec);
|
|
||||||
m_indent.set(2);
|
|
||||||
m_preCommentIndent.set(2);
|
|
||||||
m_postCommentIndent.set(1);
|
|
||||||
m_seqFmt.set(Block);
|
|
||||||
m_mapFmt.set(Block);
|
|
||||||
m_mapKeyFmt.set(Auto);
|
|
||||||
m_floatPrecision.set(std::numeric_limits<float>::digits10 + 1);
|
|
||||||
m_doublePrecision.set(std::numeric_limits<double>::digits10 + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
EmitterState::~EmitterState() {}
|
EmitterState::~EmitterState() = default;
|
||||||
|
|
||||||
// SetLocalValue
|
// SetLocalValue
|
||||||
// . We blindly tries to set all possible formatters to this value
|
// . We blindly tries to set all possible formatters to this value
|
||||||
@ -49,6 +54,8 @@ void EmitterState::SetLocalValue(EMITTER_MANIP value) {
|
|||||||
|
|
||||||
void EmitterState::SetAnchor() { m_hasAnchor = true; }
|
void EmitterState::SetAnchor() { m_hasAnchor = true; }
|
||||||
|
|
||||||
|
void EmitterState::SetAlias() { m_hasAlias = true; }
|
||||||
|
|
||||||
void EmitterState::SetTag() { m_hasTag = true; }
|
void EmitterState::SetTag() { m_hasTag = true; }
|
||||||
|
|
||||||
void EmitterState::SetNonContent() { m_hasNonContent = true; }
|
void EmitterState::SetNonContent() { m_hasNonContent = true; }
|
||||||
@ -83,6 +90,7 @@ void EmitterState::StartedNode() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_hasAnchor = false;
|
m_hasAnchor = false;
|
||||||
|
m_hasAlias = false;
|
||||||
m_hasTag = false;
|
m_hasTag = false;
|
||||||
m_hasNonContent = false;
|
m_hasNonContent = false;
|
||||||
}
|
}
|
||||||
@ -92,14 +100,12 @@ EmitterNodeType::value EmitterState::NextGroupType(
|
|||||||
if (type == GroupType::Seq) {
|
if (type == GroupType::Seq) {
|
||||||
if (GetFlowType(type) == Block)
|
if (GetFlowType(type) == Block)
|
||||||
return EmitterNodeType::BlockSeq;
|
return EmitterNodeType::BlockSeq;
|
||||||
else
|
|
||||||
return EmitterNodeType::FlowSeq;
|
return EmitterNodeType::FlowSeq;
|
||||||
} else {
|
}
|
||||||
|
|
||||||
if (GetFlowType(type) == Block)
|
if (GetFlowType(type) == Block)
|
||||||
return EmitterNodeType::BlockMap;
|
return EmitterNodeType::BlockMap;
|
||||||
else
|
|
||||||
return EmitterNodeType::FlowMap;
|
return EmitterNodeType::FlowMap;
|
||||||
}
|
|
||||||
|
|
||||||
// can't happen
|
// can't happen
|
||||||
assert(false);
|
assert(false);
|
||||||
@ -154,9 +160,15 @@ void EmitterState::EndedGroup(GroupType::value type) {
|
|||||||
if (m_groups.empty()) {
|
if (m_groups.empty()) {
|
||||||
if (type == GroupType::Seq) {
|
if (type == GroupType::Seq) {
|
||||||
return SetError(ErrorMsg::UNEXPECTED_END_SEQ);
|
return SetError(ErrorMsg::UNEXPECTED_END_SEQ);
|
||||||
} else {
|
}
|
||||||
return SetError(ErrorMsg::UNEXPECTED_END_MAP);
|
return SetError(ErrorMsg::UNEXPECTED_END_MAP);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_hasTag) {
|
||||||
|
SetError(ErrorMsg::INVALID_TAG);
|
||||||
|
}
|
||||||
|
if (m_hasAnchor) {
|
||||||
|
SetError(ErrorMsg::INVALID_ANCHOR);
|
||||||
}
|
}
|
||||||
|
|
||||||
// get rid of the current group
|
// get rid of the current group
|
||||||
@ -178,6 +190,9 @@ void EmitterState::EndedGroup(GroupType::value type) {
|
|||||||
m_globalModifiedSettings.restore();
|
m_globalModifiedSettings.restore();
|
||||||
|
|
||||||
ClearModifiedSettings();
|
ClearModifiedSettings();
|
||||||
|
m_hasAnchor = false;
|
||||||
|
m_hasTag = false;
|
||||||
|
m_hasNonContent = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
EmitterNodeType::value EmitterState::CurGroupNodeType() const {
|
EmitterNodeType::value EmitterState::CurGroupNodeType() const {
|
||||||
@ -218,6 +233,10 @@ std::size_t EmitterState::LastIndent() const {
|
|||||||
|
|
||||||
void EmitterState::ClearModifiedSettings() { m_modifiedSettings.clear(); }
|
void EmitterState::ClearModifiedSettings() { m_modifiedSettings.clear(); }
|
||||||
|
|
||||||
|
void EmitterState::RestoreGlobalModifiedSettings() {
|
||||||
|
m_globalModifiedSettings.restore();
|
||||||
|
}
|
||||||
|
|
||||||
bool EmitterState::SetOutputCharset(EMITTER_MANIP value,
|
bool EmitterState::SetOutputCharset(EMITTER_MANIP value,
|
||||||
FmtScope::value scope) {
|
FmtScope::value scope) {
|
||||||
switch (value) {
|
switch (value) {
|
||||||
@ -283,8 +302,10 @@ bool EmitterState::SetBoolCaseFormat(EMITTER_MANIP value,
|
|||||||
|
|
||||||
bool EmitterState::SetNullFormat(EMITTER_MANIP value, FmtScope::value scope) {
|
bool EmitterState::SetNullFormat(EMITTER_MANIP value, FmtScope::value scope) {
|
||||||
switch (value) {
|
switch (value) {
|
||||||
case NullAsTilde:
|
case LowerNull:
|
||||||
case NullAsNull:
|
case UpperNull:
|
||||||
|
case CamelNull:
|
||||||
|
case TildeNull:
|
||||||
_Set(m_nullFmt, value, scope);
|
_Set(m_nullFmt, value, scope);
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
@ -363,7 +384,7 @@ bool EmitterState::SetMapKeyFormat(EMITTER_MANIP value, FmtScope::value scope) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool EmitterState::SetFloatPrecision(std::size_t value, FmtScope::value scope) {
|
bool EmitterState::SetFloatPrecision(std::size_t value, FmtScope::value scope) {
|
||||||
if (value > std::numeric_limits<float>::digits10 + 1)
|
if (value > std::numeric_limits<float>::max_digits10)
|
||||||
return false;
|
return false;
|
||||||
_Set(m_floatPrecision, value, scope);
|
_Set(m_floatPrecision, value, scope);
|
||||||
return true;
|
return true;
|
||||||
@ -371,9 +392,9 @@ bool EmitterState::SetFloatPrecision(std::size_t value, FmtScope::value scope) {
|
|||||||
|
|
||||||
bool EmitterState::SetDoublePrecision(std::size_t value,
|
bool EmitterState::SetDoublePrecision(std::size_t value,
|
||||||
FmtScope::value scope) {
|
FmtScope::value scope) {
|
||||||
if (value > std::numeric_limits<double>::digits10 + 1)
|
if (value > std::numeric_limits<double>::max_digits10)
|
||||||
return false;
|
return false;
|
||||||
_Set(m_doublePrecision, value, scope);
|
_Set(m_doublePrecision, value, scope);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
15
3rdparty/yaml-cpp/src/emitterstate.h
vendored
15
3rdparty/yaml-cpp/src/emitterstate.h
vendored
@ -43,6 +43,7 @@ class EmitterState {
|
|||||||
|
|
||||||
// node handling
|
// node handling
|
||||||
void SetAnchor();
|
void SetAnchor();
|
||||||
|
void SetAlias();
|
||||||
void SetTag();
|
void SetTag();
|
||||||
void SetNonContent();
|
void SetNonContent();
|
||||||
void SetLongKey();
|
void SetLongKey();
|
||||||
@ -65,6 +66,7 @@ class EmitterState {
|
|||||||
std::size_t LastIndent() const;
|
std::size_t LastIndent() const;
|
||||||
std::size_t CurIndent() const { return m_curIndent; }
|
std::size_t CurIndent() const { return m_curIndent; }
|
||||||
bool HasAnchor() const { return m_hasAnchor; }
|
bool HasAnchor() const { return m_hasAnchor; }
|
||||||
|
bool HasAlias() const { return m_hasAlias; }
|
||||||
bool HasTag() const { return m_hasTag; }
|
bool HasTag() const { return m_hasTag; }
|
||||||
bool HasBegunNode() const {
|
bool HasBegunNode() const {
|
||||||
return m_hasAnchor || m_hasTag || m_hasNonContent;
|
return m_hasAnchor || m_hasTag || m_hasNonContent;
|
||||||
@ -72,6 +74,7 @@ class EmitterState {
|
|||||||
bool HasBegunContent() const { return m_hasAnchor || m_hasTag; }
|
bool HasBegunContent() const { return m_hasAnchor || m_hasTag; }
|
||||||
|
|
||||||
void ClearModifiedSettings();
|
void ClearModifiedSettings();
|
||||||
|
void RestoreGlobalModifiedSettings();
|
||||||
|
|
||||||
// formatters
|
// formatters
|
||||||
void SetLocalValue(EMITTER_MANIP value);
|
void SetLocalValue(EMITTER_MANIP value);
|
||||||
@ -132,9 +135,9 @@ class EmitterState {
|
|||||||
Setting<EMITTER_MANIP> m_charset;
|
Setting<EMITTER_MANIP> m_charset;
|
||||||
Setting<EMITTER_MANIP> m_strFmt;
|
Setting<EMITTER_MANIP> m_strFmt;
|
||||||
Setting<EMITTER_MANIP> m_boolFmt;
|
Setting<EMITTER_MANIP> m_boolFmt;
|
||||||
Setting<EMITTER_MANIP> m_nullFmt;
|
|
||||||
Setting<EMITTER_MANIP> m_boolLengthFmt;
|
Setting<EMITTER_MANIP> m_boolLengthFmt;
|
||||||
Setting<EMITTER_MANIP> m_boolCaseFmt;
|
Setting<EMITTER_MANIP> m_boolCaseFmt;
|
||||||
|
Setting<EMITTER_MANIP> m_nullFmt;
|
||||||
Setting<EMITTER_MANIP> m_intFmt;
|
Setting<EMITTER_MANIP> m_intFmt;
|
||||||
Setting<std::size_t> m_indent;
|
Setting<std::size_t> m_indent;
|
||||||
Setting<std::size_t> m_preCommentIndent, m_postCommentIndent;
|
Setting<std::size_t> m_preCommentIndent, m_postCommentIndent;
|
||||||
@ -149,7 +152,12 @@ class EmitterState {
|
|||||||
|
|
||||||
struct Group {
|
struct Group {
|
||||||
explicit Group(GroupType::value type_)
|
explicit Group(GroupType::value type_)
|
||||||
: type(type_), indent(0), childCount(0), longKey(false) {}
|
: type(type_),
|
||||||
|
flowType{},
|
||||||
|
indent(0),
|
||||||
|
childCount(0),
|
||||||
|
longKey(false),
|
||||||
|
modifiedSettings{} {}
|
||||||
|
|
||||||
GroupType::value type;
|
GroupType::value type;
|
||||||
FlowType::value flowType;
|
FlowType::value flowType;
|
||||||
@ -181,6 +189,7 @@ class EmitterState {
|
|||||||
std::vector<std::unique_ptr<Group>> m_groups;
|
std::vector<std::unique_ptr<Group>> m_groups;
|
||||||
std::size_t m_curIndent;
|
std::size_t m_curIndent;
|
||||||
bool m_hasAnchor;
|
bool m_hasAnchor;
|
||||||
|
bool m_hasAlias;
|
||||||
bool m_hasTag;
|
bool m_hasTag;
|
||||||
bool m_hasNonContent;
|
bool m_hasNonContent;
|
||||||
std::size_t m_docCount;
|
std::size_t m_docCount;
|
||||||
@ -202,6 +211,6 @@ void EmitterState::_Set(Setting<T>& fmt, T value, FmtScope::value scope) {
|
|||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // EMITTERSTATE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // EMITTERSTATE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
93
3rdparty/yaml-cpp/src/emitterutils.cpp
vendored
93
3rdparty/yaml-cpp/src/emitterutils.cpp
vendored
@ -1,3 +1,4 @@
|
|||||||
|
#include <algorithm>
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
@ -8,8 +9,8 @@
|
|||||||
#include "regeximpl.h"
|
#include "regeximpl.h"
|
||||||
#include "stringsource.h"
|
#include "stringsource.h"
|
||||||
#include "yaml-cpp/binary.h" // IWYU pragma: keep
|
#include "yaml-cpp/binary.h" // IWYU pragma: keep
|
||||||
#include "yaml-cpp/ostream_wrapper.h"
|
|
||||||
#include "yaml-cpp/null.h"
|
#include "yaml-cpp/null.h"
|
||||||
|
#include "yaml-cpp/ostream_wrapper.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace Utils {
|
namespace Utils {
|
||||||
@ -134,12 +135,12 @@ void WriteCodePoint(ostream_wrapper& out, int codePoint) {
|
|||||||
if (codePoint < 0 || codePoint > 0x10FFFF) {
|
if (codePoint < 0 || codePoint > 0x10FFFF) {
|
||||||
codePoint = REPLACEMENT_CHARACTER;
|
codePoint = REPLACEMENT_CHARACTER;
|
||||||
}
|
}
|
||||||
if (codePoint < 0x7F) {
|
if (codePoint <= 0x7F) {
|
||||||
out << static_cast<char>(codePoint);
|
out << static_cast<char>(codePoint);
|
||||||
} else if (codePoint < 0x7FF) {
|
} else if (codePoint <= 0x7FF) {
|
||||||
out << static_cast<char>(0xC0 | (codePoint >> 6))
|
out << static_cast<char>(0xC0 | (codePoint >> 6))
|
||||||
<< static_cast<char>(0x80 | (codePoint & 0x3F));
|
<< static_cast<char>(0x80 | (codePoint & 0x3F));
|
||||||
} else if (codePoint < 0xFFFF) {
|
} else if (codePoint <= 0xFFFF) {
|
||||||
out << static_cast<char>(0xE0 | (codePoint >> 12))
|
out << static_cast<char>(0xE0 | (codePoint >> 12))
|
||||||
<< static_cast<char>(0x80 | ((codePoint >> 6) & 0x3F))
|
<< static_cast<char>(0x80 | ((codePoint >> 6) & 0x3F))
|
||||||
<< static_cast<char>(0x80 | (codePoint & 0x3F));
|
<< static_cast<char>(0x80 | (codePoint & 0x3F));
|
||||||
@ -173,13 +174,13 @@ bool IsValidPlainScalar(const std::string& str, FlowType::value flowType,
|
|||||||
|
|
||||||
// then check until something is disallowed
|
// then check until something is disallowed
|
||||||
static const RegEx& disallowed_flow =
|
static const RegEx& disallowed_flow =
|
||||||
Exp::EndScalarInFlow() || (Exp::BlankOrBreak() + Exp::Comment()) ||
|
Exp::EndScalarInFlow() | (Exp::BlankOrBreak() + Exp::Comment()) |
|
||||||
Exp::NotPrintable() || Exp::Utf8_ByteOrderMark() || Exp::Break() ||
|
Exp::NotPrintable() | Exp::Utf8_ByteOrderMark() | Exp::Break() |
|
||||||
Exp::Tab();
|
Exp::Tab() | Exp::Ampersand();
|
||||||
static const RegEx& disallowed_block =
|
static const RegEx& disallowed_block =
|
||||||
Exp::EndScalar() || (Exp::BlankOrBreak() + Exp::Comment()) ||
|
Exp::EndScalar() | (Exp::BlankOrBreak() + Exp::Comment()) |
|
||||||
Exp::NotPrintable() || Exp::Utf8_ByteOrderMark() || Exp::Break() ||
|
Exp::NotPrintable() | Exp::Utf8_ByteOrderMark() | Exp::Break() |
|
||||||
Exp::Tab();
|
Exp::Tab() | Exp::Ampersand();
|
||||||
const RegEx& disallowed =
|
const RegEx& disallowed =
|
||||||
flowType == FlowType::Flow ? disallowed_flow : disallowed_block;
|
flowType == FlowType::Flow ? disallowed_flow : disallowed_block;
|
||||||
|
|
||||||
@ -199,15 +200,10 @@ bool IsValidPlainScalar(const std::string& str, FlowType::value flowType,
|
|||||||
|
|
||||||
bool IsValidSingleQuotedScalar(const std::string& str, bool escapeNonAscii) {
|
bool IsValidSingleQuotedScalar(const std::string& str, bool escapeNonAscii) {
|
||||||
// TODO: check for non-printable characters?
|
// TODO: check for non-printable characters?
|
||||||
for (std::size_t i = 0; i < str.size(); i++) {
|
return std::none_of(str.begin(), str.end(), [=](char ch) {
|
||||||
if (escapeNonAscii && (0x80 <= static_cast<unsigned char>(str[i]))) {
|
return (escapeNonAscii && (0x80 <= static_cast<unsigned char>(ch))) ||
|
||||||
return false;
|
(ch == '\n');
|
||||||
}
|
});
|
||||||
if (str[i] == '\n') {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IsValidLiteralScalar(const std::string& str, FlowType::value flowType,
|
bool IsValidLiteralScalar(const std::string& str, FlowType::value flowType,
|
||||||
@ -217,12 +213,9 @@ bool IsValidLiteralScalar(const std::string& str, FlowType::value flowType,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO: check for non-printable characters?
|
// TODO: check for non-printable characters?
|
||||||
for (std::size_t i = 0; i < str.size(); i++) {
|
return std::none_of(str.begin(), str.end(), [=](char ch) {
|
||||||
if (escapeNonAscii && (0x80 <= static_cast<unsigned char>(str[i]))) {
|
return (escapeNonAscii && (0x80 <= static_cast<unsigned char>(ch)));
|
||||||
return false;
|
});
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::pair<uint16_t, uint16_t> EncodeUTF16SurrogatePair(int codePoint) {
|
std::pair<uint16_t, uint16_t> EncodeUTF16SurrogatePair(int codePoint) {
|
||||||
@ -234,24 +227,24 @@ std::pair<uint16_t, uint16_t> EncodeUTF16SurrogatePair(int codePoint) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
void WriteDoubleQuoteEscapeSequence(ostream_wrapper& out, int codePoint, bool escapeAsJson) {
|
void WriteDoubleQuoteEscapeSequence(ostream_wrapper& out, int codePoint, StringEscaping::value stringEscapingStyle) {
|
||||||
static const char hexDigits[] = "0123456789abcdef";
|
static const char hexDigits[] = "0123456789abcdef";
|
||||||
|
|
||||||
out << "\\";
|
out << "\\";
|
||||||
int digits = 8;
|
int digits = 8;
|
||||||
if (codePoint < 0xFF && !escapeAsJson) {
|
if (codePoint < 0xFF && stringEscapingStyle != StringEscaping::JSON) {
|
||||||
out << "x";
|
out << "x";
|
||||||
digits = 2;
|
digits = 2;
|
||||||
} else if (codePoint < 0xFFFF) {
|
} else if (codePoint < 0xFFFF) {
|
||||||
out << "u";
|
out << "u";
|
||||||
digits = 4;
|
digits = 4;
|
||||||
} else if (!escapeAsJson) {
|
} else if (stringEscapingStyle != StringEscaping::JSON) {
|
||||||
out << "U";
|
out << "U";
|
||||||
digits = 8;
|
digits = 8;
|
||||||
} else {
|
} else {
|
||||||
auto surrogatePair = EncodeUTF16SurrogatePair(codePoint);
|
auto surrogatePair = EncodeUTF16SurrogatePair(codePoint);
|
||||||
WriteDoubleQuoteEscapeSequence(out, surrogatePair.first, true);
|
WriteDoubleQuoteEscapeSequence(out, surrogatePair.first, stringEscapingStyle);
|
||||||
WriteDoubleQuoteEscapeSequence(out, surrogatePair.second, true);
|
WriteDoubleQuoteEscapeSequence(out, surrogatePair.second, stringEscapingStyle);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -272,7 +265,7 @@ bool WriteAliasName(ostream_wrapper& out, const std::string& str) {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
} // namespace
|
||||||
|
|
||||||
StringFormat::value ComputeStringFormat(const std::string& str,
|
StringFormat::value ComputeStringFormat(const std::string& str,
|
||||||
EMITTER_MANIP strFormat,
|
EMITTER_MANIP strFormat,
|
||||||
@ -355,12 +348,12 @@ bool WriteDoubleQuotedString(ostream_wrapper& out, const std::string& str,
|
|||||||
if (codePoint < 0x20 ||
|
if (codePoint < 0x20 ||
|
||||||
(codePoint >= 0x80 &&
|
(codePoint >= 0x80 &&
|
||||||
codePoint <= 0xA0)) { // Control characters and non-breaking space
|
codePoint <= 0xA0)) { // Control characters and non-breaking space
|
||||||
WriteDoubleQuoteEscapeSequence(out, codePoint, stringEscaping == StringEscaping::JSON);
|
WriteDoubleQuoteEscapeSequence(out, codePoint, stringEscaping);
|
||||||
} else if (codePoint == 0xFEFF) { // Byte order marks (ZWNS) should be
|
} else if (codePoint == 0xFEFF) { // Byte order marks (ZWNS) should be
|
||||||
// escaped (YAML 1.2, sec. 5.2)
|
// escaped (YAML 1.2, sec. 5.2)
|
||||||
WriteDoubleQuoteEscapeSequence(out, codePoint, stringEscaping == StringEscaping::JSON);
|
WriteDoubleQuoteEscapeSequence(out, codePoint, stringEscaping);
|
||||||
} else if (stringEscaping == StringEscaping::NonAscii && codePoint > 0x7E) {
|
} else if (stringEscaping == StringEscaping::NonAscii && codePoint > 0x7E) {
|
||||||
WriteDoubleQuoteEscapeSequence(out, codePoint, false);
|
WriteDoubleQuoteEscapeSequence(out, codePoint, stringEscaping);
|
||||||
} else {
|
} else {
|
||||||
WriteCodePoint(out, codePoint);
|
WriteCodePoint(out, codePoint);
|
||||||
}
|
}
|
||||||
@ -373,41 +366,41 @@ bool WriteDoubleQuotedString(ostream_wrapper& out, const std::string& str,
|
|||||||
bool WriteLiteralString(ostream_wrapper& out, const std::string& str,
|
bool WriteLiteralString(ostream_wrapper& out, const std::string& str,
|
||||||
std::size_t indent) {
|
std::size_t indent) {
|
||||||
out << "|\n";
|
out << "|\n";
|
||||||
out << IndentTo(indent);
|
|
||||||
int codePoint;
|
int codePoint;
|
||||||
for (std::string::const_iterator i = str.begin();
|
for (std::string::const_iterator i = str.begin();
|
||||||
GetNextCodePointAndAdvance(codePoint, i, str.end());) {
|
GetNextCodePointAndAdvance(codePoint, i, str.end());) {
|
||||||
if (codePoint == '\n') {
|
if (codePoint == '\n') {
|
||||||
out << "\n" << IndentTo(indent);
|
out << "\n";
|
||||||
} else {
|
} else {
|
||||||
|
out<< IndentTo(indent);
|
||||||
WriteCodePoint(out, codePoint);
|
WriteCodePoint(out, codePoint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WriteChar(ostream_wrapper& out, char ch, bool escapeAsJson) {
|
bool WriteChar(ostream_wrapper& out, char ch, StringEscaping::value stringEscapingStyle) {
|
||||||
if (('a' <= ch && ch <= 'z') || ('A' <= ch && ch <= 'Z')) {
|
if (('a' <= ch && ch <= 'z') || ('A' <= ch && ch <= 'Z')) {
|
||||||
out << ch;
|
out << ch;
|
||||||
} else if (ch == '\"') {
|
} else if (ch == '\"') {
|
||||||
out << "\"\\\"\"";
|
out << R"("\"")";
|
||||||
} else if (ch == '\t') {
|
} else if (ch == '\t') {
|
||||||
out << "\"\\t\"";
|
out << R"("\t")";
|
||||||
} else if (ch == '\n') {
|
} else if (ch == '\n') {
|
||||||
out << "\"\\n\"";
|
out << R"("\n")";
|
||||||
} else if (ch == '\b') {
|
} else if (ch == '\b') {
|
||||||
out << "\"\\b\"";
|
out << R"("\b")";
|
||||||
} else if (ch == '\r') {
|
} else if (ch == '\r') {
|
||||||
out << "\"\\r\"";
|
out << R"("\r")";
|
||||||
} else if (ch == '\f') {
|
} else if (ch == '\f') {
|
||||||
out << "\"\\f\"";
|
out << R"("\f")";
|
||||||
} else if (ch == '\\') {
|
} else if (ch == '\\') {
|
||||||
out << "\"\\\\\"";
|
out << R"("\\")";
|
||||||
} else if ((0x20 <= ch && ch <= 0x7e) || ch == ' ') {
|
} else if (0x20 <= ch && ch <= 0x7e) {
|
||||||
out << "\"" << ch << "\"";
|
out << "\"" << ch << "\"";
|
||||||
} else {
|
} else {
|
||||||
out << "\"";
|
out << "\"";
|
||||||
WriteDoubleQuoteEscapeSequence(out, ch, escapeAsJson);
|
WriteDoubleQuoteEscapeSequence(out, ch, stringEscapingStyle);
|
||||||
out << "\"";
|
out << "\"";
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -422,8 +415,8 @@ bool WriteComment(ostream_wrapper& out, const std::string& str,
|
|||||||
for (std::string::const_iterator i = str.begin();
|
for (std::string::const_iterator i = str.begin();
|
||||||
GetNextCodePointAndAdvance(codePoint, i, str.end());) {
|
GetNextCodePointAndAdvance(codePoint, i, str.end());) {
|
||||||
if (codePoint == '\n') {
|
if (codePoint == '\n') {
|
||||||
out << "\n" << IndentTo(curIndent) << "#"
|
out << "\n"
|
||||||
<< Indentation(postCommentIndent);
|
<< IndentTo(curIndent) << "#" << Indentation(postCommentIndent);
|
||||||
out.set_comment();
|
out.set_comment();
|
||||||
} else {
|
} else {
|
||||||
WriteCodePoint(out, codePoint);
|
WriteCodePoint(out, codePoint);
|
||||||
@ -500,5 +493,5 @@ bool WriteBinary(ostream_wrapper& out, const Binary& binary) {
|
|||||||
StringEscaping::None);
|
StringEscaping::None);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
} // namespace Utils
|
||||||
}
|
} // namespace YAML
|
||||||
|
3
3rdparty/yaml-cpp/src/emitterutils.h
vendored
3
3rdparty/yaml-cpp/src/emitterutils.h
vendored
@ -39,7 +39,8 @@ bool WriteDoubleQuotedString(ostream_wrapper& out, const std::string& str,
|
|||||||
StringEscaping::value stringEscaping);
|
StringEscaping::value stringEscaping);
|
||||||
bool WriteLiteralString(ostream_wrapper& out, const std::string& str,
|
bool WriteLiteralString(ostream_wrapper& out, const std::string& str,
|
||||||
std::size_t indent);
|
std::size_t indent);
|
||||||
bool WriteChar(ostream_wrapper& out, char ch, bool escapeAsJson);
|
bool WriteChar(ostream_wrapper& out, char ch,
|
||||||
|
StringEscaping::value stringEscapingStyle);
|
||||||
bool WriteComment(ostream_wrapper& out, const std::string& str,
|
bool WriteComment(ostream_wrapper& out, const std::string& str,
|
||||||
std::size_t postCommentIndent);
|
std::size_t postCommentIndent);
|
||||||
bool WriteAlias(ostream_wrapper& out, const std::string& str);
|
bool WriteAlias(ostream_wrapper& out, const std::string& str);
|
||||||
|
29
3rdparty/yaml-cpp/src/exceptions.cpp
vendored
29
3rdparty/yaml-cpp/src/exceptions.cpp
vendored
@ -1,19 +1,20 @@
|
|||||||
#include "yaml-cpp/exceptions.h"
|
#include "yaml-cpp/exceptions.h"
|
||||||
|
#include "yaml-cpp/noexcept.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
|
|
||||||
// These destructors are defined out-of-line so the vtable is only emitted once.
|
// These destructors are defined out-of-line so the vtable is only emitted once.
|
||||||
Exception::~Exception() NOEXCEPT {}
|
Exception::~Exception() YAML_CPP_NOEXCEPT = default;
|
||||||
ParserException::~ParserException() NOEXCEPT {}
|
ParserException::~ParserException() YAML_CPP_NOEXCEPT = default;
|
||||||
RepresentationException::~RepresentationException() NOEXCEPT {}
|
RepresentationException::~RepresentationException() YAML_CPP_NOEXCEPT = default;
|
||||||
InvalidScalar::~InvalidScalar() NOEXCEPT {}
|
InvalidScalar::~InvalidScalar() YAML_CPP_NOEXCEPT = default;
|
||||||
KeyNotFound::~KeyNotFound() NOEXCEPT {}
|
KeyNotFound::~KeyNotFound() YAML_CPP_NOEXCEPT = default;
|
||||||
InvalidNode::~InvalidNode() NOEXCEPT {}
|
InvalidNode::~InvalidNode() YAML_CPP_NOEXCEPT = default;
|
||||||
BadConversion::~BadConversion() NOEXCEPT {}
|
BadConversion::~BadConversion() YAML_CPP_NOEXCEPT = default;
|
||||||
BadDereference::~BadDereference() NOEXCEPT {}
|
BadDereference::~BadDereference() YAML_CPP_NOEXCEPT = default;
|
||||||
BadSubscript::~BadSubscript() NOEXCEPT {}
|
BadSubscript::~BadSubscript() YAML_CPP_NOEXCEPT = default;
|
||||||
BadPushback::~BadPushback() NOEXCEPT {}
|
BadPushback::~BadPushback() YAML_CPP_NOEXCEPT = default;
|
||||||
BadInsert::~BadInsert() NOEXCEPT {}
|
BadInsert::~BadInsert() YAML_CPP_NOEXCEPT = default;
|
||||||
EmitterException::~EmitterException() NOEXCEPT {}
|
EmitterException::~EmitterException() YAML_CPP_NOEXCEPT = default;
|
||||||
BadFile::~BadFile() NOEXCEPT {}
|
BadFile::~BadFile() YAML_CPP_NOEXCEPT = default;
|
||||||
}
|
} // namespace YAML
|
||||||
|
17
3rdparty/yaml-cpp/src/exp.cpp
vendored
17
3rdparty/yaml-cpp/src/exp.cpp
vendored
@ -12,8 +12,7 @@ namespace YAML {
|
|||||||
namespace Exp {
|
namespace Exp {
|
||||||
unsigned ParseHex(const std::string& str, const Mark& mark) {
|
unsigned ParseHex(const std::string& str, const Mark& mark) {
|
||||||
unsigned value = 0;
|
unsigned value = 0;
|
||||||
for (std::size_t i = 0; i < str.size(); i++) {
|
for (char ch : str) {
|
||||||
char ch = str[i];
|
|
||||||
int digit = 0;
|
int digit = 0;
|
||||||
if ('a' <= ch && ch <= 'f')
|
if ('a' <= ch && ch <= 'f')
|
||||||
digit = ch - 'a' + 10;
|
digit = ch - 'a' + 10;
|
||||||
@ -55,12 +54,14 @@ std::string Escape(Stream& in, int codeLength) {
|
|||||||
// now break it up into chars
|
// now break it up into chars
|
||||||
if (value <= 0x7F)
|
if (value <= 0x7F)
|
||||||
return Str(value);
|
return Str(value);
|
||||||
else if (value <= 0x7FF)
|
|
||||||
|
if (value <= 0x7FF)
|
||||||
return Str(0xC0 + (value >> 6)) + Str(0x80 + (value & 0x3F));
|
return Str(0xC0 + (value >> 6)) + Str(0x80 + (value & 0x3F));
|
||||||
else if (value <= 0xFFFF)
|
|
||||||
|
if (value <= 0xFFFF)
|
||||||
return Str(0xE0 + (value >> 12)) + Str(0x80 + ((value >> 6) & 0x3F)) +
|
return Str(0xE0 + (value >> 12)) + Str(0x80 + ((value >> 6) & 0x3F)) +
|
||||||
Str(0x80 + (value & 0x3F));
|
Str(0x80 + (value & 0x3F));
|
||||||
else
|
|
||||||
return Str(0xF0 + (value >> 18)) + Str(0x80 + ((value >> 12) & 0x3F)) +
|
return Str(0xF0 + (value >> 18)) + Str(0x80 + ((value >> 12) & 0x3F)) +
|
||||||
Str(0x80 + ((value >> 6) & 0x3F)) + Str(0x80 + (value & 0x3F));
|
Str(0x80 + ((value >> 6) & 0x3F)) + Str(0x80 + (value & 0x3F));
|
||||||
}
|
}
|
||||||
@ -104,7 +105,7 @@ std::string Escape(Stream& in) {
|
|||||||
case 'e':
|
case 'e':
|
||||||
return "\x1B";
|
return "\x1B";
|
||||||
case ' ':
|
case ' ':
|
||||||
return "\x20";
|
return R"( )";
|
||||||
case '\"':
|
case '\"':
|
||||||
return "\"";
|
return "\"";
|
||||||
case '\'':
|
case '\'':
|
||||||
@ -132,5 +133,5 @@ std::string Escape(Stream& in) {
|
|||||||
std::stringstream msg;
|
std::stringstream msg;
|
||||||
throw ParserException(in.mark(), std::string(ErrorMsg::INVALID_ESCAPE) + ch);
|
throw ParserException(in.mark(), std::string(ErrorMsg::INVALID_ESCAPE) + ch);
|
||||||
}
|
}
|
||||||
}
|
} // namespace Exp
|
||||||
}
|
} // namespace YAML
|
||||||
|
72
3rdparty/yaml-cpp/src/exp.h
vendored
72
3rdparty/yaml-cpp/src/exp.h
vendored
@ -33,15 +33,15 @@ inline const RegEx& Tab() {
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Blank() {
|
inline const RegEx& Blank() {
|
||||||
static const RegEx e = Space() || Tab();
|
static const RegEx e = Space() | Tab();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Break() {
|
inline const RegEx& Break() {
|
||||||
static const RegEx e = RegEx('\n') || RegEx("\r\n");
|
static const RegEx e = RegEx('\n') | RegEx("\r\n") | RegEx('\r');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& BlankOrBreak() {
|
inline const RegEx& BlankOrBreak() {
|
||||||
static const RegEx e = Blank() || Break();
|
static const RegEx e = Blank() | Break();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Digit() {
|
inline const RegEx& Digit() {
|
||||||
@ -49,29 +49,29 @@ inline const RegEx& Digit() {
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Alpha() {
|
inline const RegEx& Alpha() {
|
||||||
static const RegEx e = RegEx('a', 'z') || RegEx('A', 'Z');
|
static const RegEx e = RegEx('a', 'z') | RegEx('A', 'Z');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& AlphaNumeric() {
|
inline const RegEx& AlphaNumeric() {
|
||||||
static const RegEx e = Alpha() || Digit();
|
static const RegEx e = Alpha() | Digit();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Word() {
|
inline const RegEx& Word() {
|
||||||
static const RegEx e = AlphaNumeric() || RegEx('-');
|
static const RegEx e = AlphaNumeric() | RegEx('-');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Hex() {
|
inline const RegEx& Hex() {
|
||||||
static const RegEx e = Digit() || RegEx('A', 'F') || RegEx('a', 'f');
|
static const RegEx e = Digit() | RegEx('A', 'F') | RegEx('a', 'f');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
// Valid Unicode code points that are not part of c-printable (YAML 1.2, sec.
|
// Valid Unicode code points that are not part of c-printable (YAML 1.2, sec.
|
||||||
// 5.1)
|
// 5.1)
|
||||||
inline const RegEx& NotPrintable() {
|
inline const RegEx& NotPrintable() {
|
||||||
static const RegEx e =
|
static const RegEx e =
|
||||||
RegEx(0) ||
|
RegEx(0) |
|
||||||
RegEx("\x01\x02\x03\x04\x05\x06\x07\x08\x0B\x0C\x7F", REGEX_OR) ||
|
RegEx("\x01\x02\x03\x04\x05\x06\x07\x08\x0B\x0C\x7F", REGEX_OR) |
|
||||||
RegEx(0x0E, 0x1F) ||
|
RegEx(0x0E, 0x1F) |
|
||||||
(RegEx('\xC2') + (RegEx('\x80', '\x84') || RegEx('\x86', '\x9F')));
|
(RegEx('\xC2') + (RegEx('\x80', '\x84') | RegEx('\x86', '\x9F')));
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Utf8_ByteOrderMark() {
|
inline const RegEx& Utf8_ByteOrderMark() {
|
||||||
@ -82,19 +82,19 @@ inline const RegEx& Utf8_ByteOrderMark() {
|
|||||||
// actual tags
|
// actual tags
|
||||||
|
|
||||||
inline const RegEx& DocStart() {
|
inline const RegEx& DocStart() {
|
||||||
static const RegEx e = RegEx("---") + (BlankOrBreak() || RegEx());
|
static const RegEx e = RegEx("---") + (BlankOrBreak() | RegEx());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& DocEnd() {
|
inline const RegEx& DocEnd() {
|
||||||
static const RegEx e = RegEx("...") + (BlankOrBreak() || RegEx());
|
static const RegEx e = RegEx("...") + (BlankOrBreak() | RegEx());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& DocIndicator() {
|
inline const RegEx& DocIndicator() {
|
||||||
static const RegEx e = DocStart() || DocEnd();
|
static const RegEx e = DocStart() | DocEnd();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& BlockEntry() {
|
inline const RegEx& BlockEntry() {
|
||||||
static const RegEx e = RegEx('-') + (BlankOrBreak() || RegEx());
|
static const RegEx e = RegEx('-') + (BlankOrBreak() | RegEx());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Key() {
|
inline const RegEx& Key() {
|
||||||
@ -106,36 +106,40 @@ inline const RegEx& KeyInFlow() {
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Value() {
|
inline const RegEx& Value() {
|
||||||
static const RegEx e = RegEx(':') + (BlankOrBreak() || RegEx());
|
static const RegEx e = RegEx(':') + (BlankOrBreak() | RegEx());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& ValueInFlow() {
|
inline const RegEx& ValueInFlow() {
|
||||||
static const RegEx e = RegEx(':') + (BlankOrBreak() || RegEx(",}", REGEX_OR));
|
static const RegEx e = RegEx(':') + (BlankOrBreak() | RegEx(",]}", REGEX_OR));
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& ValueInJSONFlow() {
|
inline const RegEx& ValueInJSONFlow() {
|
||||||
static const RegEx e = RegEx(':');
|
static const RegEx e = RegEx(':');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
inline const RegEx& Ampersand() {
|
||||||
|
static const RegEx e = RegEx('&');
|
||||||
|
return e;
|
||||||
|
}
|
||||||
inline const RegEx Comment() {
|
inline const RegEx Comment() {
|
||||||
static const RegEx e = RegEx('#');
|
static const RegEx e = RegEx('#');
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Anchor() {
|
inline const RegEx& Anchor() {
|
||||||
static const RegEx e = !(RegEx("[]{},", REGEX_OR) || BlankOrBreak());
|
static const RegEx e = !(RegEx("[]{},", REGEX_OR) | BlankOrBreak());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& AnchorEnd() {
|
inline const RegEx& AnchorEnd() {
|
||||||
static const RegEx e = RegEx("?:,]}%@`", REGEX_OR) || BlankOrBreak();
|
static const RegEx e = RegEx("?:,]}%@`", REGEX_OR) | BlankOrBreak();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& URI() {
|
inline const RegEx& URI() {
|
||||||
static const RegEx e = Word() || RegEx("#;/?:@&=+$,_.!~*'()[]", REGEX_OR) ||
|
static const RegEx e = Word() | RegEx("#;/?:@&=+$,_.!~*'()[]", REGEX_OR) |
|
||||||
(RegEx('%') + Hex() + Hex());
|
(RegEx('%') + Hex() + Hex());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Tag() {
|
inline const RegEx& Tag() {
|
||||||
static const RegEx e = Word() || RegEx("#;/?:@&=+$_.~*'", REGEX_OR) ||
|
static const RegEx e = Word() | RegEx("#;/?:@&=+$_.~*'()", REGEX_OR) |
|
||||||
(RegEx('%') + Hex() + Hex());
|
(RegEx('%') + Hex() + Hex());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
@ -148,34 +152,34 @@ inline const RegEx& Tag() {
|
|||||||
// space.
|
// space.
|
||||||
inline const RegEx& PlainScalar() {
|
inline const RegEx& PlainScalar() {
|
||||||
static const RegEx e =
|
static const RegEx e =
|
||||||
!(BlankOrBreak() || RegEx(",[]{}#&*!|>\'\"%@`", REGEX_OR) ||
|
!(BlankOrBreak() | RegEx(",[]{}#&*!|>\'\"%@`", REGEX_OR) |
|
||||||
(RegEx("-?:", REGEX_OR) + (BlankOrBreak() || RegEx())));
|
(RegEx("-?:", REGEX_OR) + (BlankOrBreak() | RegEx())));
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& PlainScalarInFlow() {
|
inline const RegEx& PlainScalarInFlow() {
|
||||||
static const RegEx e =
|
static const RegEx e =
|
||||||
!(BlankOrBreak() || RegEx("?,[]{}#&*!|>\'\"%@`", REGEX_OR) ||
|
!(BlankOrBreak() | RegEx("?,[]{}#&*!|>\'\"%@`", REGEX_OR) |
|
||||||
(RegEx("-:", REGEX_OR) + Blank()));
|
(RegEx("-:", REGEX_OR) + (Blank() | RegEx())));
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& EndScalar() {
|
inline const RegEx& EndScalar() {
|
||||||
static const RegEx e = RegEx(':') + (BlankOrBreak() || RegEx());
|
static const RegEx e = RegEx(':') + (BlankOrBreak() | RegEx());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& EndScalarInFlow() {
|
inline const RegEx& EndScalarInFlow() {
|
||||||
static const RegEx e =
|
static const RegEx e =
|
||||||
(RegEx(':') + (BlankOrBreak() || RegEx() || RegEx(",]}", REGEX_OR))) ||
|
(RegEx(':') + (BlankOrBreak() | RegEx() | RegEx(",]}", REGEX_OR))) |
|
||||||
RegEx(",?[]{}", REGEX_OR);
|
RegEx(",?[]{}", REGEX_OR);
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const RegEx& ScanScalarEndInFlow() {
|
inline const RegEx& ScanScalarEndInFlow() {
|
||||||
static const RegEx e = (EndScalarInFlow() || (BlankOrBreak() + Comment()));
|
static const RegEx e = (EndScalarInFlow() | (BlankOrBreak() + Comment()));
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const RegEx& ScanScalarEnd() {
|
inline const RegEx& ScanScalarEnd() {
|
||||||
static const RegEx e = EndScalar() || (BlankOrBreak() + Comment());
|
static const RegEx e = EndScalar() | (BlankOrBreak() + Comment());
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& EscSingleQuote() {
|
inline const RegEx& EscSingleQuote() {
|
||||||
@ -192,15 +196,15 @@ inline const RegEx& ChompIndicator() {
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
inline const RegEx& Chomp() {
|
inline const RegEx& Chomp() {
|
||||||
static const RegEx e = (ChompIndicator() + Digit()) ||
|
static const RegEx e = (ChompIndicator() + Digit()) |
|
||||||
(Digit() + ChompIndicator()) || ChompIndicator() ||
|
(Digit() + ChompIndicator()) | ChompIndicator() |
|
||||||
Digit();
|
Digit();
|
||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
// and some functions
|
// and some functions
|
||||||
std::string Escape(Stream& in);
|
std::string Escape(Stream& in);
|
||||||
}
|
} // namespace Exp
|
||||||
|
|
||||||
namespace Keys {
|
namespace Keys {
|
||||||
const char Directive = '%';
|
const char Directive = '%';
|
||||||
@ -216,7 +220,7 @@ const char LiteralScalar = '|';
|
|||||||
const char FoldedScalar = '>';
|
const char FoldedScalar = '>';
|
||||||
const char VerbatimTagStart = '<';
|
const char VerbatimTagStart = '<';
|
||||||
const char VerbatimTagEnd = '>';
|
const char VerbatimTagEnd = '>';
|
||||||
}
|
} // namespace Keys
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // EXP_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // EXP_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
4
3rdparty/yaml-cpp/src/memory.cpp
vendored
4
3rdparty/yaml-cpp/src/memory.cpp
vendored
@ -22,5 +22,5 @@ node& memory::create_node() {
|
|||||||
void memory::merge(const memory& rhs) {
|
void memory::merge(const memory& rhs) {
|
||||||
m_nodes.insert(rhs.m_nodes.begin(), rhs.m_nodes.end());
|
m_nodes.insert(rhs.m_nodes.begin(), rhs.m_nodes.end());
|
||||||
}
|
}
|
||||||
}
|
} // namespace detail
|
||||||
}
|
} // namespace YAML
|
||||||
|
2
3rdparty/yaml-cpp/src/node.cpp
vendored
2
3rdparty/yaml-cpp/src/node.cpp
vendored
@ -9,4 +9,4 @@ Node Clone(const Node& node) {
|
|||||||
events.Emit(builder);
|
events.Emit(builder);
|
||||||
return builder.Root();
|
return builder.Root();
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
94
3rdparty/yaml-cpp/src/node_data.cpp
vendored
94
3rdparty/yaml-cpp/src/node_data.cpp
vendored
@ -1,4 +1,5 @@
|
|||||||
#include <assert.h>
|
#include <algorithm>
|
||||||
|
#include <cassert>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
@ -12,15 +13,24 @@
|
|||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
YAML_CPP_API std::atomic<size_t> node::m_amount{0};
|
||||||
|
|
||||||
std::string node_data::empty_scalar;
|
const std::string& node_data::empty_scalar() {
|
||||||
|
static const std::string svalue;
|
||||||
|
return svalue;
|
||||||
|
}
|
||||||
|
|
||||||
node_data::node_data()
|
node_data::node_data()
|
||||||
: m_isDefined(false),
|
: m_isDefined(false),
|
||||||
m_mark(Mark::null_mark()),
|
m_mark(Mark::null_mark()),
|
||||||
m_type(NodeType::Null),
|
m_type(NodeType::Null),
|
||||||
|
m_tag{},
|
||||||
m_style(EmitterStyle::Default),
|
m_style(EmitterStyle::Default),
|
||||||
m_seqSize(0) {}
|
m_scalar{},
|
||||||
|
m_sequence{},
|
||||||
|
m_seqSize(0),
|
||||||
|
m_map{},
|
||||||
|
m_undefinedPairs{} {}
|
||||||
|
|
||||||
void node_data::mark_defined() {
|
void node_data::mark_defined() {
|
||||||
if (m_type == NodeType::Undefined)
|
if (m_type == NodeType::Undefined)
|
||||||
@ -100,9 +110,9 @@ void node_data::compute_seq_size() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void node_data::compute_map_size() const {
|
void node_data::compute_map_size() const {
|
||||||
kv_pairs::iterator it = m_undefinedPairs.begin();
|
auto it = m_undefinedPairs.begin();
|
||||||
while (it != m_undefinedPairs.end()) {
|
while (it != m_undefinedPairs.end()) {
|
||||||
kv_pairs::iterator jt = std::next(it);
|
auto jt = std::next(it);
|
||||||
if (it->first->is_defined() && it->second->is_defined())
|
if (it->first->is_defined() && it->second->is_defined())
|
||||||
m_undefinedPairs.erase(it);
|
m_undefinedPairs.erase(it);
|
||||||
it = jt;
|
it = jt;
|
||||||
@ -111,7 +121,7 @@ void node_data::compute_map_size() const {
|
|||||||
|
|
||||||
const_node_iterator node_data::begin() const {
|
const_node_iterator node_data::begin() const {
|
||||||
if (!m_isDefined)
|
if (!m_isDefined)
|
||||||
return const_node_iterator();
|
return {};
|
||||||
|
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
@ -119,13 +129,13 @@ const_node_iterator node_data::begin() const {
|
|||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
return const_node_iterator(m_map.begin(), m_map.end());
|
return const_node_iterator(m_map.begin(), m_map.end());
|
||||||
default:
|
default:
|
||||||
return const_node_iterator();
|
return {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
node_iterator node_data::begin() {
|
node_iterator node_data::begin() {
|
||||||
if (!m_isDefined)
|
if (!m_isDefined)
|
||||||
return node_iterator();
|
return {};
|
||||||
|
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
@ -133,13 +143,13 @@ node_iterator node_data::begin() {
|
|||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
return node_iterator(m_map.begin(), m_map.end());
|
return node_iterator(m_map.begin(), m_map.end());
|
||||||
default:
|
default:
|
||||||
return node_iterator();
|
return {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const_node_iterator node_data::end() const {
|
const_node_iterator node_data::end() const {
|
||||||
if (!m_isDefined)
|
if (!m_isDefined)
|
||||||
return const_node_iterator();
|
return {};
|
||||||
|
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
@ -147,13 +157,13 @@ const_node_iterator node_data::end() const {
|
|||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
return const_node_iterator(m_map.end(), m_map.end());
|
return const_node_iterator(m_map.end(), m_map.end());
|
||||||
default:
|
default:
|
||||||
return const_node_iterator();
|
return {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
node_iterator node_data::end() {
|
node_iterator node_data::end() {
|
||||||
if (!m_isDefined)
|
if (!m_isDefined)
|
||||||
return node_iterator();
|
return {};
|
||||||
|
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
@ -161,12 +171,13 @@ node_iterator node_data::end() {
|
|||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
return node_iterator(m_map.end(), m_map.end());
|
return node_iterator(m_map.end(), m_map.end());
|
||||||
default:
|
default:
|
||||||
return node_iterator();
|
return {};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// sequence
|
// sequence
|
||||||
void node_data::push_back(node& node, shared_memory_holder /* pMemory */) {
|
void node_data::push_back(node& node,
|
||||||
|
const shared_memory_holder& /* pMemory */) {
|
||||||
if (m_type == NodeType::Undefined || m_type == NodeType::Null) {
|
if (m_type == NodeType::Undefined || m_type == NodeType::Null) {
|
||||||
m_type = NodeType::Sequence;
|
m_type = NodeType::Sequence;
|
||||||
reset_sequence();
|
reset_sequence();
|
||||||
@ -178,7 +189,8 @@ void node_data::push_back(node& node, shared_memory_holder /* pMemory */) {
|
|||||||
m_sequence.push_back(&node);
|
m_sequence.push_back(&node);
|
||||||
}
|
}
|
||||||
|
|
||||||
void node_data::insert(node& key, node& value, shared_memory_holder pMemory) {
|
void node_data::insert(node& key, node& value,
|
||||||
|
const shared_memory_holder& pMemory) {
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
break;
|
break;
|
||||||
@ -188,27 +200,28 @@ void node_data::insert(node& key, node& value, shared_memory_holder pMemory) {
|
|||||||
convert_to_map(pMemory);
|
convert_to_map(pMemory);
|
||||||
break;
|
break;
|
||||||
case NodeType::Scalar:
|
case NodeType::Scalar:
|
||||||
throw BadSubscript();
|
throw BadSubscript(m_mark, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
insert_map_pair(key, value);
|
insert_map_pair(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// indexing
|
// indexing
|
||||||
node* node_data::get(node& key, shared_memory_holder /* pMemory */) const {
|
node* node_data::get(node& key,
|
||||||
|
const shared_memory_holder& /* pMemory */) const {
|
||||||
if (m_type != NodeType::Map) {
|
if (m_type != NodeType::Map) {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (node_map::const_iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
for (const auto& it : m_map) {
|
||||||
if (it->first->is(key))
|
if (it.first->is(key))
|
||||||
return it->second;
|
return it.second;
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
node& node_data::get(node& key, shared_memory_holder pMemory) {
|
node& node_data::get(node& key, const shared_memory_holder& pMemory) {
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
break;
|
break;
|
||||||
@ -218,12 +231,12 @@ node& node_data::get(node& key, shared_memory_holder pMemory) {
|
|||||||
convert_to_map(pMemory);
|
convert_to_map(pMemory);
|
||||||
break;
|
break;
|
||||||
case NodeType::Scalar:
|
case NodeType::Scalar:
|
||||||
throw BadSubscript();
|
throw BadSubscript(m_mark, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (node_map::const_iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
for (const auto& it : m_map) {
|
||||||
if (it->first->is(key))
|
if (it.first->is(key))
|
||||||
return *it->second;
|
return *it.second;
|
||||||
}
|
}
|
||||||
|
|
||||||
node& value = pMemory->create_node();
|
node& value = pMemory->create_node();
|
||||||
@ -231,16 +244,27 @@ node& node_data::get(node& key, shared_memory_holder pMemory) {
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool node_data::remove(node& key, shared_memory_holder /* pMemory */) {
|
bool node_data::remove(node& key, const shared_memory_holder& /* pMemory */) {
|
||||||
if (m_type != NodeType::Map)
|
if (m_type != NodeType::Map)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (node_map::iterator it = m_map.begin(); it != m_map.end(); ++it) {
|
for (auto it = m_undefinedPairs.begin(); it != m_undefinedPairs.end();) {
|
||||||
if (it->first->is(key)) {
|
auto jt = std::next(it);
|
||||||
|
if (it->first->is(key))
|
||||||
|
m_undefinedPairs.erase(it);
|
||||||
|
it = jt;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto it =
|
||||||
|
std::find_if(m_map.begin(), m_map.end(),
|
||||||
|
[&](std::pair<YAML::detail::node*, YAML::detail::node*> j) {
|
||||||
|
return (j.first->is(key));
|
||||||
|
});
|
||||||
|
|
||||||
|
if (it != m_map.end()) {
|
||||||
m_map.erase(it);
|
m_map.erase(it);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -262,7 +286,7 @@ void node_data::insert_map_pair(node& key, node& value) {
|
|||||||
m_undefinedPairs.emplace_back(&key, &value);
|
m_undefinedPairs.emplace_back(&key, &value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void node_data::convert_to_map(shared_memory_holder pMemory) {
|
void node_data::convert_to_map(const shared_memory_holder& pMemory) {
|
||||||
switch (m_type) {
|
switch (m_type) {
|
||||||
case NodeType::Undefined:
|
case NodeType::Undefined:
|
||||||
case NodeType::Null:
|
case NodeType::Null:
|
||||||
@ -280,7 +304,7 @@ void node_data::convert_to_map(shared_memory_holder pMemory) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void node_data::convert_sequence_to_map(shared_memory_holder pMemory) {
|
void node_data::convert_sequence_to_map(const shared_memory_holder& pMemory) {
|
||||||
assert(m_type == NodeType::Sequence);
|
assert(m_type == NodeType::Sequence);
|
||||||
|
|
||||||
reset_map();
|
reset_map();
|
||||||
@ -296,5 +320,5 @@ void node_data::convert_sequence_to_map(shared_memory_holder pMemory) {
|
|||||||
reset_sequence();
|
reset_sequence();
|
||||||
m_type = NodeType::Map;
|
m_type = NodeType::Map;
|
||||||
}
|
}
|
||||||
}
|
} // namespace detail
|
||||||
}
|
} // namespace YAML
|
||||||
|
16
3rdparty/yaml-cpp/src/nodebuilder.cpp
vendored
16
3rdparty/yaml-cpp/src/nodebuilder.cpp
vendored
@ -1,4 +1,3 @@
|
|||||||
#include <assert.h>
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
|
||||||
#include "nodebuilder.h"
|
#include "nodebuilder.h"
|
||||||
@ -11,11 +10,16 @@ namespace YAML {
|
|||||||
struct Mark;
|
struct Mark;
|
||||||
|
|
||||||
NodeBuilder::NodeBuilder()
|
NodeBuilder::NodeBuilder()
|
||||||
: m_pMemory(new detail::memory_holder), m_pRoot(0), m_mapDepth(0) {
|
: m_pMemory(new detail::memory_holder),
|
||||||
m_anchors.push_back(0); // since the anchors start at 1
|
m_pRoot(nullptr),
|
||||||
|
m_stack{},
|
||||||
|
m_anchors{},
|
||||||
|
m_keys{},
|
||||||
|
m_mapDepth(0) {
|
||||||
|
m_anchors.push_back(nullptr); // since the anchors start at 1
|
||||||
}
|
}
|
||||||
|
|
||||||
NodeBuilder::~NodeBuilder() {}
|
NodeBuilder::~NodeBuilder() = default;
|
||||||
|
|
||||||
Node NodeBuilder::Root() {
|
Node NodeBuilder::Root() {
|
||||||
if (!m_pRoot)
|
if (!m_pRoot)
|
||||||
@ -88,7 +92,7 @@ void NodeBuilder::Push(detail::node& node) {
|
|||||||
|
|
||||||
m_stack.push_back(&node);
|
m_stack.push_back(&node);
|
||||||
if (needsKey)
|
if (needsKey)
|
||||||
m_keys.push_back(PushedKey(&node, false));
|
m_keys.emplace_back(&node, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NodeBuilder::Pop() {
|
void NodeBuilder::Pop() {
|
||||||
@ -127,4 +131,4 @@ void NodeBuilder::RegisterAnchor(anchor_t anchor, detail::node& node) {
|
|||||||
m_anchors.push_back(&node);
|
m_anchors.push_back(&node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
36
3rdparty/yaml-cpp/src/nodebuilder.h
vendored
36
3rdparty/yaml-cpp/src/nodebuilder.h
vendored
@ -27,25 +27,29 @@ class Node;
|
|||||||
class NodeBuilder : public EventHandler {
|
class NodeBuilder : public EventHandler {
|
||||||
public:
|
public:
|
||||||
NodeBuilder();
|
NodeBuilder();
|
||||||
virtual ~NodeBuilder();
|
NodeBuilder(const NodeBuilder&) = delete;
|
||||||
|
NodeBuilder(NodeBuilder&&) = delete;
|
||||||
|
NodeBuilder& operator=(const NodeBuilder&) = delete;
|
||||||
|
NodeBuilder& operator=(NodeBuilder&&) = delete;
|
||||||
|
~NodeBuilder() override;
|
||||||
|
|
||||||
Node Root();
|
Node Root();
|
||||||
|
|
||||||
virtual void OnDocumentStart(const Mark& mark);
|
void OnDocumentStart(const Mark& mark) override;
|
||||||
virtual void OnDocumentEnd();
|
void OnDocumentEnd() override;
|
||||||
|
|
||||||
virtual void OnNull(const Mark& mark, anchor_t anchor);
|
void OnNull(const Mark& mark, anchor_t anchor) override;
|
||||||
virtual void OnAlias(const Mark& mark, anchor_t anchor);
|
void OnAlias(const Mark& mark, anchor_t anchor) override;
|
||||||
virtual void OnScalar(const Mark& mark, const std::string& tag,
|
void OnScalar(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, const std::string& value);
|
anchor_t anchor, const std::string& value) override;
|
||||||
|
|
||||||
virtual void OnSequenceStart(const Mark& mark, const std::string& tag,
|
void OnSequenceStart(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, EmitterStyle::value style);
|
anchor_t anchor, EmitterStyle::value style) override;
|
||||||
virtual void OnSequenceEnd();
|
void OnSequenceEnd() override;
|
||||||
|
|
||||||
virtual void OnMapStart(const Mark& mark, const std::string& tag,
|
void OnMapStart(const Mark& mark, const std::string& tag,
|
||||||
anchor_t anchor, EmitterStyle::value style);
|
anchor_t anchor, EmitterStyle::value style) override;
|
||||||
virtual void OnMapEnd();
|
void OnMapEnd() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
detail::node& Push(const Mark& mark, anchor_t anchor);
|
detail::node& Push(const Mark& mark, anchor_t anchor);
|
||||||
@ -57,14 +61,14 @@ class NodeBuilder : public EventHandler {
|
|||||||
detail::shared_memory_holder m_pMemory;
|
detail::shared_memory_holder m_pMemory;
|
||||||
detail::node* m_pRoot;
|
detail::node* m_pRoot;
|
||||||
|
|
||||||
typedef std::vector<detail::node*> Nodes;
|
using Nodes = std::vector<detail::node *>;
|
||||||
Nodes m_stack;
|
Nodes m_stack;
|
||||||
Nodes m_anchors;
|
Nodes m_anchors;
|
||||||
|
|
||||||
typedef std::pair<detail::node*, bool> PushedKey;
|
using PushedKey = std::pair<detail::node*, bool>;
|
||||||
std::vector<PushedKey> m_keys;
|
std::vector<PushedKey> m_keys;
|
||||||
std::size_t m_mapDepth;
|
std::size_t m_mapDepth;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // NODE_NODEBUILDER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // NODE_NODEBUILDER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
31
3rdparty/yaml-cpp/src/nodeevents.cpp
vendored
31
3rdparty/yaml-cpp/src/nodeevents.cpp
vendored
@ -13,14 +13,14 @@ void NodeEvents::AliasManager::RegisterReference(const detail::node& node) {
|
|||||||
|
|
||||||
anchor_t NodeEvents::AliasManager::LookupAnchor(
|
anchor_t NodeEvents::AliasManager::LookupAnchor(
|
||||||
const detail::node& node) const {
|
const detail::node& node) const {
|
||||||
AnchorByIdentity::const_iterator it = m_anchorByIdentity.find(node.ref());
|
auto it = m_anchorByIdentity.find(node.ref());
|
||||||
if (it == m_anchorByIdentity.end())
|
if (it == m_anchorByIdentity.end())
|
||||||
return 0;
|
return 0;
|
||||||
return it->second;
|
return it->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
NodeEvents::NodeEvents(const Node& node)
|
NodeEvents::NodeEvents(const Node& node)
|
||||||
: m_pMemory(node.m_pMemory), m_root(node.m_pNode) {
|
: m_pMemory(node.m_pMemory), m_root(node.m_pNode), m_refCount{} {
|
||||||
if (m_root)
|
if (m_root)
|
||||||
Setup(*m_root);
|
Setup(*m_root);
|
||||||
}
|
}
|
||||||
@ -32,13 +32,12 @@ void NodeEvents::Setup(const detail::node& node) {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (node.type() == NodeType::Sequence) {
|
if (node.type() == NodeType::Sequence) {
|
||||||
for (detail::const_node_iterator it = node.begin(); it != node.end(); ++it)
|
for (auto element : node)
|
||||||
Setup(**it);
|
Setup(*element);
|
||||||
} else if (node.type() == NodeType::Map) {
|
} else if (node.type() == NodeType::Map) {
|
||||||
for (detail::const_node_iterator it = node.begin(); it != node.end();
|
for (auto element : node) {
|
||||||
++it) {
|
Setup(*element.first);
|
||||||
Setup(*it->first);
|
Setup(*element.second);
|
||||||
Setup(*it->second);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -77,17 +76,15 @@ void NodeEvents::Emit(const detail::node& node, EventHandler& handler,
|
|||||||
break;
|
break;
|
||||||
case NodeType::Sequence:
|
case NodeType::Sequence:
|
||||||
handler.OnSequenceStart(Mark(), node.tag(), anchor, node.style());
|
handler.OnSequenceStart(Mark(), node.tag(), anchor, node.style());
|
||||||
for (detail::const_node_iterator it = node.begin(); it != node.end();
|
for (auto element : node)
|
||||||
++it)
|
Emit(*element, handler, am);
|
||||||
Emit(**it, handler, am);
|
|
||||||
handler.OnSequenceEnd();
|
handler.OnSequenceEnd();
|
||||||
break;
|
break;
|
||||||
case NodeType::Map:
|
case NodeType::Map:
|
||||||
handler.OnMapStart(Mark(), node.tag(), anchor, node.style());
|
handler.OnMapStart(Mark(), node.tag(), anchor, node.style());
|
||||||
for (detail::const_node_iterator it = node.begin(); it != node.end();
|
for (auto element : node) {
|
||||||
++it) {
|
Emit(*element.first, handler, am);
|
||||||
Emit(*it->first, handler, am);
|
Emit(*element.second, handler, am);
|
||||||
Emit(*it->second, handler, am);
|
|
||||||
}
|
}
|
||||||
handler.OnMapEnd();
|
handler.OnMapEnd();
|
||||||
break;
|
break;
|
||||||
@ -95,7 +92,7 @@ void NodeEvents::Emit(const detail::node& node, EventHandler& handler,
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool NodeEvents::IsAliased(const detail::node& node) const {
|
bool NodeEvents::IsAliased(const detail::node& node) const {
|
||||||
RefCount::const_iterator it = m_refCount.find(node.ref());
|
auto it = m_refCount.find(node.ref());
|
||||||
return it != m_refCount.end() && it->second > 1;
|
return it != m_refCount.end() && it->second > 1;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
12
3rdparty/yaml-cpp/src/nodeevents.h
vendored
12
3rdparty/yaml-cpp/src/nodeevents.h
vendored
@ -26,13 +26,17 @@ class Node;
|
|||||||
class NodeEvents {
|
class NodeEvents {
|
||||||
public:
|
public:
|
||||||
explicit NodeEvents(const Node& node);
|
explicit NodeEvents(const Node& node);
|
||||||
|
NodeEvents(const NodeEvents&) = delete;
|
||||||
|
NodeEvents(NodeEvents&&) = delete;
|
||||||
|
NodeEvents& operator=(const NodeEvents&) = delete;
|
||||||
|
NodeEvents& operator=(NodeEvents&&) = delete;
|
||||||
|
|
||||||
void Emit(EventHandler& handler);
|
void Emit(EventHandler& handler);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
class AliasManager {
|
class AliasManager {
|
||||||
public:
|
public:
|
||||||
AliasManager() : m_curAnchor(0) {}
|
AliasManager() : m_anchorByIdentity{}, m_curAnchor(0) {}
|
||||||
|
|
||||||
void RegisterReference(const detail::node& node);
|
void RegisterReference(const detail::node& node);
|
||||||
anchor_t LookupAnchor(const detail::node& node) const;
|
anchor_t LookupAnchor(const detail::node& node) const;
|
||||||
@ -41,7 +45,7 @@ class NodeEvents {
|
|||||||
anchor_t _CreateNewAnchor() { return ++m_curAnchor; }
|
anchor_t _CreateNewAnchor() { return ++m_curAnchor; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef std::map<const detail::node_ref*, anchor_t> AnchorByIdentity;
|
using AnchorByIdentity = std::map<const detail::node_ref*, anchor_t>;
|
||||||
AnchorByIdentity m_anchorByIdentity;
|
AnchorByIdentity m_anchorByIdentity;
|
||||||
|
|
||||||
anchor_t m_curAnchor;
|
anchor_t m_curAnchor;
|
||||||
@ -56,9 +60,9 @@ class NodeEvents {
|
|||||||
detail::shared_memory_holder m_pMemory;
|
detail::shared_memory_holder m_pMemory;
|
||||||
detail::node* m_root;
|
detail::node* m_root;
|
||||||
|
|
||||||
typedef std::map<const detail::node_ref*, int> RefCount;
|
using RefCount = std::map<const detail::node_ref*, int>;
|
||||||
RefCount m_refCount;
|
RefCount m_refCount;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // NODE_NODEEVENTS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // NODE_NODEEVENTS_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
2
3rdparty/yaml-cpp/src/null.cpp
vendored
2
3rdparty/yaml-cpp/src/null.cpp
vendored
@ -7,4 +7,4 @@ bool IsNullString(const std::string& str) {
|
|||||||
return str.empty() || str == "~" || str == "null" || str == "Null" ||
|
return str.empty() || str == "~" || str == "null" || str == "Null" ||
|
||||||
str == "NULL";
|
str == "NULL";
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
17
3rdparty/yaml-cpp/src/ostream_wrapper.cpp
vendored
17
3rdparty/yaml-cpp/src/ostream_wrapper.cpp
vendored
@ -7,16 +7,21 @@
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
ostream_wrapper::ostream_wrapper()
|
ostream_wrapper::ostream_wrapper()
|
||||||
: m_buffer(1, '\0'),
|
: m_buffer(1, '\0'),
|
||||||
m_pStream(0),
|
m_pStream(nullptr),
|
||||||
m_pos(0),
|
m_pos(0),
|
||||||
m_row(0),
|
m_row(0),
|
||||||
m_col(0),
|
m_col(0),
|
||||||
m_comment(false) {}
|
m_comment(false) {}
|
||||||
|
|
||||||
ostream_wrapper::ostream_wrapper(std::ostream& stream)
|
ostream_wrapper::ostream_wrapper(std::ostream& stream)
|
||||||
: m_pStream(&stream), m_pos(0), m_row(0), m_col(0), m_comment(false) {}
|
: m_buffer{},
|
||||||
|
m_pStream(&stream),
|
||||||
|
m_pos(0),
|
||||||
|
m_row(0),
|
||||||
|
m_col(0),
|
||||||
|
m_comment(false) {}
|
||||||
|
|
||||||
ostream_wrapper::~ostream_wrapper() {}
|
ostream_wrapper::~ostream_wrapper() = default;
|
||||||
|
|
||||||
void ostream_wrapper::write(const std::string& str) {
|
void ostream_wrapper::write(const std::string& str) {
|
||||||
if (m_pStream) {
|
if (m_pStream) {
|
||||||
@ -26,8 +31,8 @@ void ostream_wrapper::write(const std::string& str) {
|
|||||||
std::copy(str.begin(), str.end(), m_buffer.begin() + m_pos);
|
std::copy(str.begin(), str.end(), m_buffer.begin() + m_pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (std::size_t i = 0; i < str.size(); i++) {
|
for (char ch : str) {
|
||||||
update_pos(str[i]);
|
update_pos(ch);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,4 +59,4 @@ void ostream_wrapper::update_pos(char ch) {
|
|||||||
m_comment = false;
|
m_comment = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
18
3rdparty/yaml-cpp/src/parse.cpp
vendored
18
3rdparty/yaml-cpp/src/parse.cpp
vendored
@ -3,10 +3,10 @@
|
|||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
#include "yaml-cpp/node/node.h"
|
|
||||||
#include "yaml-cpp/node/impl.h"
|
|
||||||
#include "yaml-cpp/parser.h"
|
|
||||||
#include "nodebuilder.h"
|
#include "nodebuilder.h"
|
||||||
|
#include "yaml-cpp/node/impl.h"
|
||||||
|
#include "yaml-cpp/node/node.h"
|
||||||
|
#include "yaml-cpp/parser.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
Node Load(const std::string& input) {
|
Node Load(const std::string& input) {
|
||||||
@ -30,9 +30,9 @@ Node Load(std::istream& input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Node LoadFile(const std::string& filename) {
|
Node LoadFile(const std::string& filename) {
|
||||||
std::ifstream fin(filename.c_str());
|
std::ifstream fin(filename);
|
||||||
if (!fin || fin.bad()) {
|
if (!fin) {
|
||||||
throw BadFile();
|
throw BadFile(filename);
|
||||||
}
|
}
|
||||||
return Load(fin);
|
return Load(fin);
|
||||||
}
|
}
|
||||||
@ -51,7 +51,7 @@ std::vector<Node> LoadAll(std::istream& input) {
|
|||||||
std::vector<Node> docs;
|
std::vector<Node> docs;
|
||||||
|
|
||||||
Parser parser(input);
|
Parser parser(input);
|
||||||
while (1) {
|
while (true) {
|
||||||
NodeBuilder builder;
|
NodeBuilder builder;
|
||||||
if (!parser.HandleNextDocument(builder)) {
|
if (!parser.HandleNextDocument(builder)) {
|
||||||
break;
|
break;
|
||||||
@ -63,9 +63,9 @@ std::vector<Node> LoadAll(std::istream& input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Node> LoadAllFromFile(const std::string& filename) {
|
std::vector<Node> LoadAllFromFile(const std::string& filename) {
|
||||||
std::ifstream fin(filename.c_str());
|
std::ifstream fin(filename);
|
||||||
if (!fin) {
|
if (!fin) {
|
||||||
throw BadFile();
|
throw BadFile(filename);
|
||||||
}
|
}
|
||||||
return LoadAll(fin);
|
return LoadAll(fin);
|
||||||
}
|
}
|
||||||
|
28
3rdparty/yaml-cpp/src/parser.cpp
vendored
28
3rdparty/yaml-cpp/src/parser.cpp
vendored
@ -11,15 +11,13 @@
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
class EventHandler;
|
class EventHandler;
|
||||||
|
|
||||||
Parser::Parser() {}
|
Parser::Parser() : m_pScanner{}, m_pDirectives{} {}
|
||||||
|
|
||||||
Parser::Parser(std::istream& in) { Load(in); }
|
Parser::Parser(std::istream& in) : Parser() { Load(in); }
|
||||||
|
|
||||||
Parser::~Parser() {}
|
Parser::~Parser() = default;
|
||||||
|
|
||||||
Parser::operator bool() const {
|
Parser::operator bool() const { return m_pScanner && !m_pScanner->empty(); }
|
||||||
return m_pScanner.get() && !m_pScanner->empty();
|
|
||||||
}
|
|
||||||
|
|
||||||
void Parser::Load(std::istream& in) {
|
void Parser::Load(std::istream& in) {
|
||||||
m_pScanner.reset(new Scanner(in));
|
m_pScanner.reset(new Scanner(in));
|
||||||
@ -27,7 +25,7 @@ void Parser::Load(std::istream& in) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool Parser::HandleNextDocument(EventHandler& eventHandler) {
|
bool Parser::HandleNextDocument(EventHandler& eventHandler) {
|
||||||
if (!m_pScanner.get())
|
if (!m_pScanner)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
ParseDirectives();
|
ParseDirectives();
|
||||||
@ -43,11 +41,7 @@ bool Parser::HandleNextDocument(EventHandler& eventHandler) {
|
|||||||
void Parser::ParseDirectives() {
|
void Parser::ParseDirectives() {
|
||||||
bool readDirective = false;
|
bool readDirective = false;
|
||||||
|
|
||||||
while (1) {
|
while (!m_pScanner->empty()) {
|
||||||
if (m_pScanner->empty()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
Token& token = m_pScanner->peek();
|
Token& token = m_pScanner->peek();
|
||||||
if (token.type != Token::DIRECTIVE) {
|
if (token.type != Token::DIRECTIVE) {
|
||||||
break;
|
break;
|
||||||
@ -113,17 +107,13 @@ void Parser::HandleTagDirective(const Token& token) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Parser::PrintTokens(std::ostream& out) {
|
void Parser::PrintTokens(std::ostream& out) {
|
||||||
if (!m_pScanner.get()) {
|
if (!m_pScanner) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (1) {
|
while (!m_pScanner->empty()) {
|
||||||
if (m_pScanner->empty()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
out << m_pScanner->peek() << "\n";
|
out << m_pScanner->peek() << "\n";
|
||||||
m_pScanner->pop();
|
m_pScanner->pop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
12
3rdparty/yaml-cpp/src/ptr_vector.h
vendored
12
3rdparty/yaml-cpp/src/ptr_vector.h
vendored
@ -12,15 +12,17 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
|
|
||||||
// TODO: This class is no longer needed
|
// TODO: This class is no longer needed
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class ptr_vector : private YAML::noncopyable {
|
class ptr_vector {
|
||||||
public:
|
public:
|
||||||
ptr_vector() {}
|
ptr_vector() : m_data{} {}
|
||||||
|
ptr_vector(const ptr_vector&) = delete;
|
||||||
|
ptr_vector(ptr_vector&&) = default;
|
||||||
|
ptr_vector& operator=(const ptr_vector&) = delete;
|
||||||
|
ptr_vector& operator=(ptr_vector&&) = default;
|
||||||
|
|
||||||
void clear() { m_data.clear(); }
|
void clear() { m_data.clear(); }
|
||||||
|
|
||||||
@ -38,6 +40,6 @@ class ptr_vector : private YAML::noncopyable {
|
|||||||
private:
|
private:
|
||||||
std::vector<std::unique_ptr<T>> m_data;
|
std::vector<std::unique_ptr<T>> m_data;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // PTR_VECTOR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // PTR_VECTOR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
20
3rdparty/yaml-cpp/src/regex_yaml.cpp
vendored
20
3rdparty/yaml-cpp/src/regex_yaml.cpp
vendored
@ -2,18 +2,16 @@
|
|||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
// constructors
|
// constructors
|
||||||
RegEx::RegEx() : m_op(REGEX_EMPTY) {}
|
|
||||||
|
|
||||||
RegEx::RegEx(REGEX_OP op) : m_op(op) {}
|
RegEx::RegEx(REGEX_OP op) : m_op(op), m_a(0), m_z(0), m_params{} {}
|
||||||
|
RegEx::RegEx() : RegEx(REGEX_EMPTY) {}
|
||||||
|
|
||||||
RegEx::RegEx(char ch) : m_op(REGEX_MATCH), m_a(ch) {}
|
RegEx::RegEx(char ch) : m_op(REGEX_MATCH), m_a(ch), m_z(0), m_params{} {}
|
||||||
|
|
||||||
RegEx::RegEx(char a, char z) : m_op(REGEX_RANGE), m_a(a), m_z(z) {}
|
RegEx::RegEx(char a, char z) : m_op(REGEX_RANGE), m_a(a), m_z(z), m_params{} {}
|
||||||
|
|
||||||
RegEx::RegEx(const std::string& str, REGEX_OP op) : m_op(op) {
|
RegEx::RegEx(const std::string& str, REGEX_OP op)
|
||||||
for (std::size_t i = 0; i < str.size(); i++)
|
: m_op(op), m_a(0), m_z(0), m_params(str.begin(), str.end()) {}
|
||||||
m_params.push_back(RegEx(str[i]));
|
|
||||||
}
|
|
||||||
|
|
||||||
// combination constructors
|
// combination constructors
|
||||||
RegEx operator!(const RegEx& ex) {
|
RegEx operator!(const RegEx& ex) {
|
||||||
@ -22,14 +20,14 @@ RegEx operator!(const RegEx& ex) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
RegEx operator||(const RegEx& ex1, const RegEx& ex2) {
|
RegEx operator|(const RegEx& ex1, const RegEx& ex2) {
|
||||||
RegEx ret(REGEX_OR);
|
RegEx ret(REGEX_OR);
|
||||||
ret.m_params.push_back(ex1);
|
ret.m_params.push_back(ex1);
|
||||||
ret.m_params.push_back(ex2);
|
ret.m_params.push_back(ex2);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
RegEx operator&&(const RegEx& ex1, const RegEx& ex2) {
|
RegEx operator&(const RegEx& ex1, const RegEx& ex2) {
|
||||||
RegEx ret(REGEX_AND);
|
RegEx ret(REGEX_AND);
|
||||||
ret.m_params.push_back(ex1);
|
ret.m_params.push_back(ex1);
|
||||||
ret.m_params.push_back(ex2);
|
ret.m_params.push_back(ex2);
|
||||||
@ -42,4 +40,4 @@ RegEx operator+(const RegEx& ex1, const RegEx& ex2) {
|
|||||||
ret.m_params.push_back(ex2);
|
ret.m_params.push_back(ex2);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
15
3rdparty/yaml-cpp/src/regex_yaml.h
vendored
15
3rdparty/yaml-cpp/src/regex_yaml.h
vendored
@ -31,14 +31,14 @@ enum REGEX_OP {
|
|||||||
class YAML_CPP_API RegEx {
|
class YAML_CPP_API RegEx {
|
||||||
public:
|
public:
|
||||||
RegEx();
|
RegEx();
|
||||||
RegEx(char ch);
|
explicit RegEx(char ch);
|
||||||
RegEx(char a, char z);
|
RegEx(char a, char z);
|
||||||
RegEx(const std::string& str, REGEX_OP op = REGEX_SEQ);
|
RegEx(const std::string& str, REGEX_OP op = REGEX_SEQ);
|
||||||
~RegEx() {}
|
~RegEx() = default;
|
||||||
|
|
||||||
friend YAML_CPP_API RegEx operator!(const RegEx& ex);
|
friend YAML_CPP_API RegEx operator!(const RegEx& ex);
|
||||||
friend YAML_CPP_API RegEx operator||(const RegEx& ex1, const RegEx& ex2);
|
friend YAML_CPP_API RegEx operator|(const RegEx& ex1, const RegEx& ex2);
|
||||||
friend YAML_CPP_API RegEx operator&&(const RegEx& ex1, const RegEx& ex2);
|
friend YAML_CPP_API RegEx operator&(const RegEx& ex1, const RegEx& ex2);
|
||||||
friend YAML_CPP_API RegEx operator+(const RegEx& ex1, const RegEx& ex2);
|
friend YAML_CPP_API RegEx operator+(const RegEx& ex1, const RegEx& ex2);
|
||||||
|
|
||||||
bool Matches(char ch) const;
|
bool Matches(char ch) const;
|
||||||
@ -53,7 +53,7 @@ class YAML_CPP_API RegEx {
|
|||||||
int Match(const Source& source) const;
|
int Match(const Source& source) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RegEx(REGEX_OP op);
|
explicit RegEx(REGEX_OP op);
|
||||||
|
|
||||||
template <typename Source>
|
template <typename Source>
|
||||||
bool IsValidSource(const Source& source) const;
|
bool IsValidSource(const Source& source) const;
|
||||||
@ -77,10 +77,11 @@ class YAML_CPP_API RegEx {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
REGEX_OP m_op;
|
REGEX_OP m_op;
|
||||||
char m_a, m_z;
|
char m_a{};
|
||||||
|
char m_z{};
|
||||||
std::vector<RegEx> m_params;
|
std::vector<RegEx> m_params;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#include "regeximpl.h"
|
#include "regeximpl.h"
|
||||||
|
|
||||||
|
17
3rdparty/yaml-cpp/src/regeximpl.h
vendored
17
3rdparty/yaml-cpp/src/regeximpl.h
vendored
@ -8,8 +8,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "stream.h"
|
#include "stream.h"
|
||||||
#include "stringsource.h"
|
|
||||||
#include "streamcharsource.h"
|
#include "streamcharsource.h"
|
||||||
|
#include "stringsource.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
// query matches
|
// query matches
|
||||||
@ -106,9 +106,8 @@ inline int RegEx::MatchOpEmpty(const Source& source) const {
|
|||||||
template <>
|
template <>
|
||||||
inline int RegEx::MatchOpEmpty<StringCharSource>(
|
inline int RegEx::MatchOpEmpty<StringCharSource>(
|
||||||
const StringCharSource& source) const {
|
const StringCharSource& source) const {
|
||||||
return !source
|
return !source ? 0 : -1; // the empty regex only is successful on the empty
|
||||||
? 0
|
// string
|
||||||
: -1; // the empty regex only is successful on the empty string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// MatchOperator
|
// MatchOperator
|
||||||
@ -130,8 +129,8 @@ inline int RegEx::MatchOpRange(const Source& source) const {
|
|||||||
// OrOperator
|
// OrOperator
|
||||||
template <typename Source>
|
template <typename Source>
|
||||||
inline int RegEx::MatchOpOr(const Source& source) const {
|
inline int RegEx::MatchOpOr(const Source& source) const {
|
||||||
for (std::size_t i = 0; i < m_params.size(); i++) {
|
for (const RegEx& param : m_params) {
|
||||||
int n = m_params[i].MatchUnchecked(source);
|
int n = param.MatchUnchecked(source);
|
||||||
if (n >= 0)
|
if (n >= 0)
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
@ -169,8 +168,8 @@ inline int RegEx::MatchOpNot(const Source& source) const {
|
|||||||
template <typename Source>
|
template <typename Source>
|
||||||
inline int RegEx::MatchOpSeq(const Source& source) const {
|
inline int RegEx::MatchOpSeq(const Source& source) const {
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
for (std::size_t i = 0; i < m_params.size(); i++) {
|
for (const RegEx& param : m_params) {
|
||||||
int n = m_params[i].Match(source + offset); // note Match, not
|
int n = param.Match(source + offset); // note Match, not
|
||||||
// MatchUnchecked because we
|
// MatchUnchecked because we
|
||||||
// need to check validity after
|
// need to check validity after
|
||||||
// the offset
|
// the offset
|
||||||
@ -181,6 +180,6 @@ inline int RegEx::MatchOpSeq(const Source& source) const {
|
|||||||
|
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // REGEXIMPL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // REGEXIMPL_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
21
3rdparty/yaml-cpp/src/scanner.cpp
vendored
21
3rdparty/yaml-cpp/src/scanner.cpp
vendored
@ -9,12 +9,17 @@
|
|||||||
namespace YAML {
|
namespace YAML {
|
||||||
Scanner::Scanner(std::istream& in)
|
Scanner::Scanner(std::istream& in)
|
||||||
: INPUT(in),
|
: INPUT(in),
|
||||||
|
m_tokens{},
|
||||||
m_startedStream(false),
|
m_startedStream(false),
|
||||||
m_endedStream(false),
|
m_endedStream(false),
|
||||||
m_simpleKeyAllowed(false),
|
m_simpleKeyAllowed(false),
|
||||||
m_canBeJSONFlow(false) {}
|
m_canBeJSONFlow(false),
|
||||||
|
m_simpleKeys{},
|
||||||
|
m_indents{},
|
||||||
|
m_indentRefs{},
|
||||||
|
m_flows{} {}
|
||||||
|
|
||||||
Scanner::~Scanner() {}
|
Scanner::~Scanner() = default;
|
||||||
|
|
||||||
bool Scanner::empty() {
|
bool Scanner::empty() {
|
||||||
EnsureTokensInQueue();
|
EnsureTokensInQueue();
|
||||||
@ -46,7 +51,7 @@ Token& Scanner::peek() {
|
|||||||
Mark Scanner::mark() const { return INPUT.mark(); }
|
Mark Scanner::mark() const { return INPUT.mark(); }
|
||||||
|
|
||||||
void Scanner::EnsureTokensInQueue() {
|
void Scanner::EnsureTokensInQueue() {
|
||||||
while (1) {
|
while (true) {
|
||||||
if (!m_tokens.empty()) {
|
if (!m_tokens.empty()) {
|
||||||
Token& token = m_tokens.front();
|
Token& token = m_tokens.front();
|
||||||
|
|
||||||
@ -83,7 +88,7 @@ void Scanner::ScanNextToken() {
|
|||||||
return StartStream();
|
return StartStream();
|
||||||
}
|
}
|
||||||
|
|
||||||
// get rid of whitespace, etc. (in between tokens it should be irrelevent)
|
// get rid of whitespace, etc. (in between tokens it should be irrelevant)
|
||||||
ScanToNextToken();
|
ScanToNextToken();
|
||||||
|
|
||||||
// maybe need to end some blocks
|
// maybe need to end some blocks
|
||||||
@ -169,7 +174,7 @@ void Scanner::ScanNextToken() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Scanner::ScanToNextToken() {
|
void Scanner::ScanToNextToken() {
|
||||||
while (1) {
|
while (true) {
|
||||||
// first eat whitespace
|
// first eat whitespace
|
||||||
while (INPUT && IsWhitespaceToBeEaten(INPUT.peek())) {
|
while (INPUT && IsWhitespaceToBeEaten(INPUT.peek())) {
|
||||||
if (InBlockContext() && Exp::Tab().Matches(INPUT)) {
|
if (InBlockContext() && Exp::Tab().Matches(INPUT)) {
|
||||||
@ -282,7 +287,7 @@ Scanner::IndentMarker* Scanner::PushIndentTo(int column,
|
|||||||
IndentMarker::INDENT_TYPE type) {
|
IndentMarker::INDENT_TYPE type) {
|
||||||
// are we in flow?
|
// are we in flow?
|
||||||
if (InFlowContext()) {
|
if (InFlowContext()) {
|
||||||
return 0;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<IndentMarker> pIndent(new IndentMarker(column, type));
|
std::unique_ptr<IndentMarker> pIndent(new IndentMarker(column, type));
|
||||||
@ -291,12 +296,12 @@ Scanner::IndentMarker* Scanner::PushIndentTo(int column,
|
|||||||
|
|
||||||
// is this actually an indentation?
|
// is this actually an indentation?
|
||||||
if (indent.column < lastIndent.column) {
|
if (indent.column < lastIndent.column) {
|
||||||
return 0;
|
return nullptr;
|
||||||
}
|
}
|
||||||
if (indent.column == lastIndent.column &&
|
if (indent.column == lastIndent.column &&
|
||||||
!(indent.type == IndentMarker::SEQ &&
|
!(indent.type == IndentMarker::SEQ &&
|
||||||
lastIndent.type == IndentMarker::MAP)) {
|
lastIndent.type == IndentMarker::MAP)) {
|
||||||
return 0;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// push a start token
|
// push a start token
|
||||||
|
4
3rdparty/yaml-cpp/src/scanner.h
vendored
4
3rdparty/yaml-cpp/src/scanner.h
vendored
@ -9,9 +9,7 @@
|
|||||||
|
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <ios>
|
#include <ios>
|
||||||
#include <map>
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <set>
|
|
||||||
#include <stack>
|
#include <stack>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
@ -49,7 +47,7 @@ class Scanner {
|
|||||||
enum INDENT_TYPE { MAP, SEQ, NONE };
|
enum INDENT_TYPE { MAP, SEQ, NONE };
|
||||||
enum STATUS { VALID, INVALID, UNKNOWN };
|
enum STATUS { VALID, INVALID, UNKNOWN };
|
||||||
IndentMarker(int column_, INDENT_TYPE type_)
|
IndentMarker(int column_, INDENT_TYPE type_)
|
||||||
: column(column_), type(type_), status(VALID), pStartToken(0) {}
|
: column(column_), type(type_), status(VALID), pStartToken(nullptr) {}
|
||||||
|
|
||||||
int column;
|
int column;
|
||||||
INDENT_TYPE type;
|
INDENT_TYPE type;
|
||||||
|
9
3rdparty/yaml-cpp/src/scanscalar.cpp
vendored
9
3rdparty/yaml-cpp/src/scanscalar.cpp
vendored
@ -47,7 +47,8 @@ std::string ScanScalar(Stream& INPUT, ScanScalarParams& params) {
|
|||||||
if (INPUT.column() == 0 && Exp::DocIndicator().Matches(INPUT)) {
|
if (INPUT.column() == 0 && Exp::DocIndicator().Matches(INPUT)) {
|
||||||
if (params.onDocIndicator == BREAK) {
|
if (params.onDocIndicator == BREAK) {
|
||||||
break;
|
break;
|
||||||
} else if (params.onDocIndicator == THROW) {
|
}
|
||||||
|
if (params.onDocIndicator == THROW) {
|
||||||
throw ParserException(INPUT.mark(), ErrorMsg::DOC_IN_SCALAR);
|
throw ParserException(INPUT.mark(), ErrorMsg::DOC_IN_SCALAR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -183,7 +184,7 @@ std::string ScanScalar(Stream& INPUT, ScanScalarParams& params) {
|
|||||||
case FOLD_FLOW:
|
case FOLD_FLOW:
|
||||||
if (nextEmptyLine) {
|
if (nextEmptyLine) {
|
||||||
scalar += "\n";
|
scalar += "\n";
|
||||||
} else if (!emptyLine && !nextEmptyLine && !escapedNewline) {
|
} else if (!emptyLine && !escapedNewline) {
|
||||||
scalar += " ";
|
scalar += " ";
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -203,7 +204,7 @@ std::string ScanScalar(Stream& INPUT, ScanScalarParams& params) {
|
|||||||
|
|
||||||
// post-processing
|
// post-processing
|
||||||
if (params.trimTrailingSpaces) {
|
if (params.trimTrailingSpaces) {
|
||||||
std::size_t pos = scalar.find_last_not_of(' ');
|
std::size_t pos = scalar.find_last_not_of(" \t");
|
||||||
if (lastEscapedChar != std::string::npos) {
|
if (lastEscapedChar != std::string::npos) {
|
||||||
if (pos < lastEscapedChar || pos == std::string::npos) {
|
if (pos < lastEscapedChar || pos == std::string::npos) {
|
||||||
pos = lastEscapedChar;
|
pos = lastEscapedChar;
|
||||||
@ -247,4 +248,4 @@ std::string ScanScalar(Stream& INPUT, ScanScalarParams& params) {
|
|||||||
|
|
||||||
return scalar;
|
return scalar;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
2
3rdparty/yaml-cpp/src/scanscalar.h
vendored
2
3rdparty/yaml-cpp/src/scanscalar.h
vendored
@ -57,7 +57,7 @@ struct ScanScalarParams {
|
|||||||
bool leadingSpaces;
|
bool leadingSpaces;
|
||||||
};
|
};
|
||||||
|
|
||||||
std::string ScanScalar(Stream& INPUT, ScanScalarParams& info);
|
std::string ScanScalar(Stream& INPUT, ScanScalarParams& params);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SCANSCALAR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // SCANSCALAR_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
2
3rdparty/yaml-cpp/src/scantag.cpp
vendored
2
3rdparty/yaml-cpp/src/scantag.cpp
vendored
@ -78,4 +78,4 @@ const std::string ScanTagSuffix(Stream& INPUT) {
|
|||||||
|
|
||||||
return tag;
|
return tag;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
10
3rdparty/yaml-cpp/src/scantoken.cpp
vendored
10
3rdparty/yaml-cpp/src/scantoken.cpp
vendored
@ -37,7 +37,7 @@ void Scanner::ScanDirective() {
|
|||||||
token.value += INPUT.get();
|
token.value += INPUT.get();
|
||||||
|
|
||||||
// read parameters
|
// read parameters
|
||||||
while (1) {
|
while (true) {
|
||||||
// first get rid of whitespace
|
// first get rid of whitespace
|
||||||
while (Exp::Blank().Matches(INPUT))
|
while (Exp::Blank().Matches(INPUT))
|
||||||
INPUT.eat(1);
|
INPUT.eat(1);
|
||||||
@ -171,7 +171,7 @@ void Scanner::ScanBlockEntry() {
|
|||||||
|
|
||||||
// Key
|
// Key
|
||||||
void Scanner::ScanKey() {
|
void Scanner::ScanKey() {
|
||||||
// handle keys diffently in the block context (and manage indents)
|
// handle keys differently in the block context (and manage indents)
|
||||||
if (InBlockContext()) {
|
if (InBlockContext()) {
|
||||||
if (!m_simpleKeyAllowed)
|
if (!m_simpleKeyAllowed)
|
||||||
throw ParserException(INPUT.mark(), ErrorMsg::MAP_KEY);
|
throw ParserException(INPUT.mark(), ErrorMsg::MAP_KEY);
|
||||||
@ -199,7 +199,7 @@ void Scanner::ScanValue() {
|
|||||||
// seems fine)
|
// seems fine)
|
||||||
m_simpleKeyAllowed = false;
|
m_simpleKeyAllowed = false;
|
||||||
} else {
|
} else {
|
||||||
// handle values diffently in the block context (and manage indents)
|
// handle values differently in the block context (and manage indents)
|
||||||
if (InBlockContext()) {
|
if (InBlockContext()) {
|
||||||
if (!m_simpleKeyAllowed)
|
if (!m_simpleKeyAllowed)
|
||||||
throw ParserException(INPUT.mark(), ErrorMsg::MAP_VALUE);
|
throw ParserException(INPUT.mark(), ErrorMsg::MAP_VALUE);
|
||||||
@ -338,7 +338,7 @@ void Scanner::ScanQuotedScalar() {
|
|||||||
|
|
||||||
// setup the scanning parameters
|
// setup the scanning parameters
|
||||||
ScanScalarParams params;
|
ScanScalarParams params;
|
||||||
RegEx end = (single ? RegEx(quote) && !Exp::EscSingleQuote() : RegEx(quote));
|
RegEx end = (single ? RegEx(quote) & !Exp::EscSingleQuote() : RegEx(quote));
|
||||||
params.end = &end;
|
params.end = &end;
|
||||||
params.eatEnd = true;
|
params.eatEnd = true;
|
||||||
params.escape = (single ? '\'' : '\\');
|
params.escape = (single ? '\'' : '\\');
|
||||||
@ -434,4 +434,4 @@ void Scanner::ScanBlockScalar() {
|
|||||||
token.value = scalar;
|
token.value = scalar;
|
||||||
m_tokens.push(token);
|
m_tokens.push(token);
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
81
3rdparty/yaml-cpp/src/setting.h
vendored
81
3rdparty/yaml-cpp/src/setting.h
vendored
@ -7,17 +7,24 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "yaml-cpp/noexcept.h"
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <utility>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
class SettingChangeBase;
|
|
||||||
|
class SettingChangeBase {
|
||||||
|
public:
|
||||||
|
virtual ~SettingChangeBase() = default;
|
||||||
|
virtual void pop() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class Setting {
|
class Setting {
|
||||||
public:
|
public:
|
||||||
Setting() : m_value() {}
|
Setting() : m_value() {}
|
||||||
|
Setting(const T& value) : m_value() { set(value); }
|
||||||
|
|
||||||
const T get() const { return m_value; }
|
const T get() const { return m_value; }
|
||||||
std::unique_ptr<SettingChangeBase> set(const T& value);
|
std::unique_ptr<SettingChangeBase> set(const T& value);
|
||||||
@ -27,21 +34,19 @@ class Setting {
|
|||||||
T m_value;
|
T m_value;
|
||||||
};
|
};
|
||||||
|
|
||||||
class SettingChangeBase {
|
|
||||||
public:
|
|
||||||
virtual ~SettingChangeBase() {}
|
|
||||||
virtual void pop() = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class SettingChange : public SettingChangeBase {
|
class SettingChange : public SettingChangeBase {
|
||||||
public:
|
public:
|
||||||
SettingChange(Setting<T>* pSetting) : m_pCurSetting(pSetting) {
|
SettingChange(Setting<T>* pSetting)
|
||||||
// copy old setting to save its state
|
: m_pCurSetting(pSetting),
|
||||||
m_oldSetting = *pSetting;
|
m_oldSetting(*pSetting) // copy old setting to save its state
|
||||||
}
|
{}
|
||||||
|
SettingChange(const SettingChange&) = delete;
|
||||||
|
SettingChange(SettingChange&&) = delete;
|
||||||
|
SettingChange& operator=(const SettingChange&) = delete;
|
||||||
|
SettingChange& operator=(SettingChange&&) = delete;
|
||||||
|
|
||||||
virtual void pop() { m_pCurSetting->restore(m_oldSetting); }
|
void pop() override { m_pCurSetting->restore(m_oldSetting); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Setting<T>* m_pCurSetting;
|
Setting<T>* m_pCurSetting;
|
||||||
@ -55,28 +60,13 @@ inline std::unique_ptr<SettingChangeBase> Setting<T>::set(const T& value) {
|
|||||||
return pChange;
|
return pChange;
|
||||||
}
|
}
|
||||||
|
|
||||||
class SettingChanges : private noncopyable {
|
class SettingChanges {
|
||||||
public:
|
public:
|
||||||
SettingChanges() {}
|
SettingChanges() : m_settingChanges{} {}
|
||||||
~SettingChanges() { clear(); }
|
SettingChanges(const SettingChanges&) = delete;
|
||||||
|
SettingChanges(SettingChanges&&) YAML_CPP_NOEXCEPT = default;
|
||||||
void clear() {
|
SettingChanges& operator=(const SettingChanges&) = delete;
|
||||||
restore();
|
SettingChanges& operator=(SettingChanges&& rhs) YAML_CPP_NOEXCEPT {
|
||||||
m_settingChanges.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
void restore() {
|
|
||||||
for (setting_changes::const_iterator it = m_settingChanges.begin();
|
|
||||||
it != m_settingChanges.end(); ++it)
|
|
||||||
(*it)->pop();
|
|
||||||
}
|
|
||||||
|
|
||||||
void push(std::unique_ptr<SettingChangeBase> pSettingChange) {
|
|
||||||
m_settingChanges.push_back(std::move(pSettingChange));
|
|
||||||
}
|
|
||||||
|
|
||||||
// like std::unique_ptr - assignment is transfer of ownership
|
|
||||||
SettingChanges& operator=(SettingChanges&& rhs) {
|
|
||||||
if (this == &rhs)
|
if (this == &rhs)
|
||||||
return *this;
|
return *this;
|
||||||
|
|
||||||
@ -85,11 +75,26 @@ class SettingChanges : private noncopyable {
|
|||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
~SettingChanges() { clear(); }
|
||||||
|
|
||||||
private:
|
void clear() YAML_CPP_NOEXCEPT {
|
||||||
typedef std::vector<std::unique_ptr<SettingChangeBase>> setting_changes;
|
restore();
|
||||||
setting_changes m_settingChanges;
|
m_settingChanges.clear();
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void restore() YAML_CPP_NOEXCEPT {
|
||||||
|
for (const auto& setting : m_settingChanges)
|
||||||
|
setting->pop();
|
||||||
|
}
|
||||||
|
|
||||||
|
void push(std::unique_ptr<SettingChangeBase> pSettingChange) {
|
||||||
|
m_settingChanges.push_back(std::move(pSettingChange));
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
using setting_changes = std::vector<std::unique_ptr<SettingChangeBase>>;
|
||||||
|
setting_changes m_settingChanges;
|
||||||
|
};
|
||||||
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // SETTING_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // SETTING_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
8
3rdparty/yaml-cpp/src/simplekey.cpp
vendored
8
3rdparty/yaml-cpp/src/simplekey.cpp
vendored
@ -5,7 +5,11 @@ namespace YAML {
|
|||||||
struct Mark;
|
struct Mark;
|
||||||
|
|
||||||
Scanner::SimpleKey::SimpleKey(const Mark& mark_, std::size_t flowLevel_)
|
Scanner::SimpleKey::SimpleKey(const Mark& mark_, std::size_t flowLevel_)
|
||||||
: mark(mark_), flowLevel(flowLevel_), pIndent(0), pMapStart(0), pKey(0) {}
|
: mark(mark_),
|
||||||
|
flowLevel(flowLevel_),
|
||||||
|
pIndent(nullptr),
|
||||||
|
pMapStart(nullptr),
|
||||||
|
pKey(nullptr) {}
|
||||||
|
|
||||||
void Scanner::SimpleKey::Validate() {
|
void Scanner::SimpleKey::Validate() {
|
||||||
// Note: pIndent will *not* be garbage here;
|
// Note: pIndent will *not* be garbage here;
|
||||||
@ -125,4 +129,4 @@ void Scanner::PopAllSimpleKeys() {
|
|||||||
while (!m_simpleKeys.empty())
|
while (!m_simpleKeys.empty())
|
||||||
m_simpleKeys.pop();
|
m_simpleKeys.pop();
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
63
3rdparty/yaml-cpp/src/singledocparser.cpp
vendored
63
3rdparty/yaml-cpp/src/singledocparser.cpp
vendored
@ -7,6 +7,7 @@
|
|||||||
#include "singledocparser.h"
|
#include "singledocparser.h"
|
||||||
#include "tag.h"
|
#include "tag.h"
|
||||||
#include "token.h"
|
#include "token.h"
|
||||||
|
#include "yaml-cpp/depthguard.h"
|
||||||
#include "yaml-cpp/emitterstyle.h"
|
#include "yaml-cpp/emitterstyle.h"
|
||||||
#include "yaml-cpp/eventhandler.h"
|
#include "yaml-cpp/eventhandler.h"
|
||||||
#include "yaml-cpp/exceptions.h" // IWYU pragma: keep
|
#include "yaml-cpp/exceptions.h" // IWYU pragma: keep
|
||||||
@ -18,9 +19,10 @@ SingleDocParser::SingleDocParser(Scanner& scanner, const Directives& directives)
|
|||||||
: m_scanner(scanner),
|
: m_scanner(scanner),
|
||||||
m_directives(directives),
|
m_directives(directives),
|
||||||
m_pCollectionStack(new CollectionStack),
|
m_pCollectionStack(new CollectionStack),
|
||||||
|
m_anchors{},
|
||||||
m_curAnchor(0) {}
|
m_curAnchor(0) {}
|
||||||
|
|
||||||
SingleDocParser::~SingleDocParser() {}
|
SingleDocParser::~SingleDocParser() = default;
|
||||||
|
|
||||||
// HandleDocument
|
// HandleDocument
|
||||||
// . Handles the next document
|
// . Handles the next document
|
||||||
@ -46,6 +48,8 @@ void SingleDocParser::HandleDocument(EventHandler& eventHandler) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void SingleDocParser::HandleNode(EventHandler& eventHandler) {
|
void SingleDocParser::HandleNode(EventHandler& eventHandler) {
|
||||||
|
DepthGuard<500> depthguard(depth, m_scanner.mark(), ErrorMsg::BAD_FILE);
|
||||||
|
|
||||||
// an empty node *is* a possibility
|
// an empty node *is* a possibility
|
||||||
if (m_scanner.empty()) {
|
if (m_scanner.empty()) {
|
||||||
eventHandler.OnNull(m_scanner.mark(), NullAnchor);
|
eventHandler.OnNull(m_scanner.mark(), NullAnchor);
|
||||||
@ -71,21 +75,32 @@ void SingleDocParser::HandleNode(EventHandler& eventHandler) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string tag;
|
std::string tag;
|
||||||
|
std::string anchor_name;
|
||||||
anchor_t anchor;
|
anchor_t anchor;
|
||||||
ParseProperties(tag, anchor);
|
ParseProperties(tag, anchor, anchor_name);
|
||||||
|
|
||||||
const Token& token = m_scanner.peek();
|
if (!anchor_name.empty())
|
||||||
|
eventHandler.OnAnchor(mark, anchor_name);
|
||||||
|
|
||||||
if (token.type == Token::PLAIN_SCALAR && IsNullString(token.value)) {
|
// after parsing properties, an empty node is again a possibility
|
||||||
|
if (m_scanner.empty()) {
|
||||||
eventHandler.OnNull(mark, anchor);
|
eventHandler.OnNull(mark, anchor);
|
||||||
m_scanner.pop();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const Token& token = m_scanner.peek();
|
||||||
|
|
||||||
// add non-specific tags
|
// add non-specific tags
|
||||||
if (tag.empty())
|
if (tag.empty())
|
||||||
tag = (token.type == Token::NON_PLAIN_SCALAR ? "!" : "?");
|
tag = (token.type == Token::NON_PLAIN_SCALAR ? "!" : "?");
|
||||||
|
|
||||||
|
if (token.type == Token::PLAIN_SCALAR
|
||||||
|
&& tag.compare("?") == 0 && IsNullString(token.value)) {
|
||||||
|
eventHandler.OnNull(mark, anchor);
|
||||||
|
m_scanner.pop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// now split based on what kind of node we should be
|
// now split based on what kind of node we should be
|
||||||
switch (token.type) {
|
switch (token.type) {
|
||||||
case Token::PLAIN_SCALAR:
|
case Token::PLAIN_SCALAR:
|
||||||
@ -152,7 +167,7 @@ void SingleDocParser::HandleBlockSequence(EventHandler& eventHandler) {
|
|||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
m_pCollectionStack->PushCollectionType(CollectionType::BlockSeq);
|
m_pCollectionStack->PushCollectionType(CollectionType::BlockSeq);
|
||||||
|
|
||||||
while (1) {
|
while (true) {
|
||||||
if (m_scanner.empty())
|
if (m_scanner.empty())
|
||||||
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_SEQ);
|
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_SEQ);
|
||||||
|
|
||||||
@ -166,10 +181,10 @@ void SingleDocParser::HandleBlockSequence(EventHandler& eventHandler) {
|
|||||||
|
|
||||||
// check for null
|
// check for null
|
||||||
if (!m_scanner.empty()) {
|
if (!m_scanner.empty()) {
|
||||||
const Token& token_ = m_scanner.peek();
|
const Token& nextToken = m_scanner.peek();
|
||||||
if (token_.type == Token::BLOCK_ENTRY ||
|
if (nextToken.type == Token::BLOCK_ENTRY ||
|
||||||
token_.type == Token::BLOCK_SEQ_END) {
|
nextToken.type == Token::BLOCK_SEQ_END) {
|
||||||
eventHandler.OnNull(token_.mark, NullAnchor);
|
eventHandler.OnNull(nextToken.mark, NullAnchor);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -185,7 +200,7 @@ void SingleDocParser::HandleFlowSequence(EventHandler& eventHandler) {
|
|||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
m_pCollectionStack->PushCollectionType(CollectionType::FlowSeq);
|
m_pCollectionStack->PushCollectionType(CollectionType::FlowSeq);
|
||||||
|
|
||||||
while (1) {
|
while (true) {
|
||||||
if (m_scanner.empty())
|
if (m_scanner.empty())
|
||||||
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_SEQ_FLOW);
|
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_SEQ_FLOW);
|
||||||
|
|
||||||
@ -238,7 +253,7 @@ void SingleDocParser::HandleBlockMap(EventHandler& eventHandler) {
|
|||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
m_pCollectionStack->PushCollectionType(CollectionType::BlockMap);
|
m_pCollectionStack->PushCollectionType(CollectionType::BlockMap);
|
||||||
|
|
||||||
while (1) {
|
while (true) {
|
||||||
if (m_scanner.empty())
|
if (m_scanner.empty())
|
||||||
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_MAP);
|
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_MAP);
|
||||||
|
|
||||||
@ -277,7 +292,7 @@ void SingleDocParser::HandleFlowMap(EventHandler& eventHandler) {
|
|||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
m_pCollectionStack->PushCollectionType(CollectionType::FlowMap);
|
m_pCollectionStack->PushCollectionType(CollectionType::FlowMap);
|
||||||
|
|
||||||
while (1) {
|
while (true) {
|
||||||
if (m_scanner.empty())
|
if (m_scanner.empty())
|
||||||
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_MAP_FLOW);
|
throw ParserException(m_scanner.mark(), ErrorMsg::END_OF_MAP_FLOW);
|
||||||
|
|
||||||
@ -356,11 +371,13 @@ void SingleDocParser::HandleCompactMapWithNoKey(EventHandler& eventHandler) {
|
|||||||
|
|
||||||
// ParseProperties
|
// ParseProperties
|
||||||
// . Grabs any tag or anchor tokens and deals with them.
|
// . Grabs any tag or anchor tokens and deals with them.
|
||||||
void SingleDocParser::ParseProperties(std::string& tag, anchor_t& anchor) {
|
void SingleDocParser::ParseProperties(std::string& tag, anchor_t& anchor,
|
||||||
|
std::string& anchor_name) {
|
||||||
tag.clear();
|
tag.clear();
|
||||||
|
anchor_name.clear();
|
||||||
anchor = NullAnchor;
|
anchor = NullAnchor;
|
||||||
|
|
||||||
while (1) {
|
while (true) {
|
||||||
if (m_scanner.empty())
|
if (m_scanner.empty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -369,7 +386,7 @@ void SingleDocParser::ParseProperties(std::string& tag, anchor_t& anchor) {
|
|||||||
ParseTag(tag);
|
ParseTag(tag);
|
||||||
break;
|
break;
|
||||||
case Token::ANCHOR:
|
case Token::ANCHOR:
|
||||||
ParseAnchor(anchor);
|
ParseAnchor(anchor, anchor_name);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
@ -387,11 +404,12 @@ void SingleDocParser::ParseTag(std::string& tag) {
|
|||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SingleDocParser::ParseAnchor(anchor_t& anchor) {
|
void SingleDocParser::ParseAnchor(anchor_t& anchor, std::string& anchor_name) {
|
||||||
Token& token = m_scanner.peek();
|
Token& token = m_scanner.peek();
|
||||||
if (anchor)
|
if (anchor)
|
||||||
throw ParserException(token.mark, ErrorMsg::MULTIPLE_ANCHORS);
|
throw ParserException(token.mark, ErrorMsg::MULTIPLE_ANCHORS);
|
||||||
|
|
||||||
|
anchor_name = token.value;
|
||||||
anchor = RegisterAnchor(token.value);
|
anchor = RegisterAnchor(token.value);
|
||||||
m_scanner.pop();
|
m_scanner.pop();
|
||||||
}
|
}
|
||||||
@ -405,10 +423,13 @@ anchor_t SingleDocParser::RegisterAnchor(const std::string& name) {
|
|||||||
|
|
||||||
anchor_t SingleDocParser::LookupAnchor(const Mark& mark,
|
anchor_t SingleDocParser::LookupAnchor(const Mark& mark,
|
||||||
const std::string& name) const {
|
const std::string& name) const {
|
||||||
Anchors::const_iterator it = m_anchors.find(name);
|
auto it = m_anchors.find(name);
|
||||||
if (it == m_anchors.end())
|
if (it == m_anchors.end()) {
|
||||||
throw ParserException(mark, ErrorMsg::UNKNOWN_ANCHOR);
|
std::stringstream ss;
|
||||||
|
ss << ErrorMsg::UNKNOWN_ANCHOR << name;
|
||||||
|
throw ParserException(mark, ss.str());
|
||||||
|
}
|
||||||
|
|
||||||
return it->second;
|
return it->second;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
18
3rdparty/yaml-cpp/src/singledocparser.h
vendored
18
3rdparty/yaml-cpp/src/singledocparser.h
vendored
@ -12,10 +12,10 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include "yaml-cpp/anchor.h"
|
#include "yaml-cpp/anchor.h"
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
class CollectionStack;
|
class CollectionStack;
|
||||||
|
template <int> class DepthGuard; // depthguard.h
|
||||||
class EventHandler;
|
class EventHandler;
|
||||||
class Node;
|
class Node;
|
||||||
class Scanner;
|
class Scanner;
|
||||||
@ -23,9 +23,13 @@ struct Directives;
|
|||||||
struct Mark;
|
struct Mark;
|
||||||
struct Token;
|
struct Token;
|
||||||
|
|
||||||
class SingleDocParser : private noncopyable {
|
class SingleDocParser {
|
||||||
public:
|
public:
|
||||||
SingleDocParser(Scanner& scanner, const Directives& directives);
|
SingleDocParser(Scanner& scanner, const Directives& directives);
|
||||||
|
SingleDocParser(const SingleDocParser&) = delete;
|
||||||
|
SingleDocParser(SingleDocParser&&) = delete;
|
||||||
|
SingleDocParser& operator=(const SingleDocParser&) = delete;
|
||||||
|
SingleDocParser& operator=(SingleDocParser&&) = delete;
|
||||||
~SingleDocParser();
|
~SingleDocParser();
|
||||||
|
|
||||||
void HandleDocument(EventHandler& eventHandler);
|
void HandleDocument(EventHandler& eventHandler);
|
||||||
@ -43,23 +47,25 @@ class SingleDocParser : private noncopyable {
|
|||||||
void HandleCompactMap(EventHandler& eventHandler);
|
void HandleCompactMap(EventHandler& eventHandler);
|
||||||
void HandleCompactMapWithNoKey(EventHandler& eventHandler);
|
void HandleCompactMapWithNoKey(EventHandler& eventHandler);
|
||||||
|
|
||||||
void ParseProperties(std::string& tag, anchor_t& anchor);
|
void ParseProperties(std::string& tag, anchor_t& anchor,
|
||||||
|
std::string& anchor_name);
|
||||||
void ParseTag(std::string& tag);
|
void ParseTag(std::string& tag);
|
||||||
void ParseAnchor(anchor_t& anchor);
|
void ParseAnchor(anchor_t& anchor, std::string& anchor_name);
|
||||||
|
|
||||||
anchor_t RegisterAnchor(const std::string& name);
|
anchor_t RegisterAnchor(const std::string& name);
|
||||||
anchor_t LookupAnchor(const Mark& mark, const std::string& name) const;
|
anchor_t LookupAnchor(const Mark& mark, const std::string& name) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
int depth = 0;
|
||||||
Scanner& m_scanner;
|
Scanner& m_scanner;
|
||||||
const Directives& m_directives;
|
const Directives& m_directives;
|
||||||
std::unique_ptr<CollectionStack> m_pCollectionStack;
|
std::unique_ptr<CollectionStack> m_pCollectionStack;
|
||||||
|
|
||||||
typedef std::map<std::string, anchor_t> Anchors;
|
using Anchors = std::map<std::string, anchor_t>;
|
||||||
Anchors m_anchors;
|
Anchors m_anchors;
|
||||||
|
|
||||||
anchor_t m_curAnchor;
|
anchor_t m_curAnchor;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // SINGLEDOCPARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // SINGLEDOCPARSER_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
52
3rdparty/yaml-cpp/src/stream.cpp
vendored
52
3rdparty/yaml-cpp/src/stream.cpp
vendored
@ -111,24 +111,15 @@ static UtfIntroState s_introTransitions[][uictMax] = {
|
|||||||
|
|
||||||
static char s_introUngetCount[][uictMax] = {
|
static char s_introUngetCount[][uictMax] = {
|
||||||
// uict00, uictBB, uictBF, uictEF, uictFE, uictFF, uictAscii, uictOther
|
// uict00, uictBB, uictBF, uictEF, uictFE, uictFF, uictAscii, uictOther
|
||||||
{0, 1, 1, 0, 0, 0, 0, 1},
|
{0, 1, 1, 0, 0, 0, 0, 1}, {0, 2, 2, 2, 2, 2, 2, 2},
|
||||||
{0, 2, 2, 2, 2, 2, 2, 2},
|
{3, 3, 3, 3, 0, 3, 3, 3}, {4, 4, 4, 4, 4, 0, 4, 4},
|
||||||
{3, 3, 3, 3, 0, 3, 3, 3},
|
{1, 1, 1, 1, 1, 1, 1, 1}, {1, 1, 1, 1, 1, 1, 1, 1},
|
||||||
{4, 4, 4, 4, 4, 0, 4, 4},
|
{2, 2, 2, 2, 2, 0, 2, 2}, {2, 2, 2, 2, 0, 2, 2, 2},
|
||||||
{1, 1, 1, 1, 1, 1, 1, 1},
|
{0, 1, 1, 1, 1, 1, 1, 1}, {0, 2, 2, 2, 2, 2, 2, 2},
|
||||||
{1, 1, 1, 1, 1, 1, 1, 1},
|
{1, 1, 1, 1, 1, 1, 1, 1}, {1, 1, 1, 1, 1, 1, 1, 1},
|
||||||
{2, 2, 2, 2, 2, 0, 2, 2},
|
{0, 2, 2, 2, 2, 2, 2, 2}, {0, 3, 3, 3, 3, 3, 3, 3},
|
||||||
{2, 2, 2, 2, 0, 2, 2, 2},
|
{4, 4, 4, 4, 4, 4, 4, 4}, {2, 0, 2, 2, 2, 2, 2, 2},
|
||||||
{0, 1, 1, 1, 1, 1, 1, 1},
|
{3, 3, 0, 3, 3, 3, 3, 3}, {1, 1, 1, 1, 1, 1, 1, 1},
|
||||||
{0, 2, 2, 2, 2, 2, 2, 2},
|
|
||||||
{1, 1, 1, 1, 1, 1, 1, 1},
|
|
||||||
{1, 1, 1, 1, 1, 1, 1, 1},
|
|
||||||
{0, 2, 2, 2, 2, 2, 2, 2},
|
|
||||||
{0, 3, 3, 3, 3, 3, 3, 3},
|
|
||||||
{4, 4, 4, 4, 4, 4, 4, 4},
|
|
||||||
{2, 0, 2, 2, 2, 2, 2, 2},
|
|
||||||
{3, 3, 0, 3, 3, 3, 3, 3},
|
|
||||||
{1, 1, 1, 1, 1, 1, 1, 1},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline UtfIntroCharType IntroCharTypeOf(std::istream::int_type ch) {
|
inline UtfIntroCharType IntroCharTypeOf(std::istream::int_type ch) {
|
||||||
@ -160,7 +151,8 @@ inline UtfIntroCharType IntroCharTypeOf(std::istream::int_type ch) {
|
|||||||
|
|
||||||
inline char Utf8Adjust(unsigned long ch, unsigned char lead_bits,
|
inline char Utf8Adjust(unsigned long ch, unsigned char lead_bits,
|
||||||
unsigned char rshift) {
|
unsigned char rshift) {
|
||||||
const unsigned char header = ((1 << lead_bits) - 1) << (8 - lead_bits);
|
const unsigned char header =
|
||||||
|
static_cast<unsigned char>(((1 << lead_bits) - 1) << (8 - lead_bits));
|
||||||
const unsigned char mask = (0xFF >> (lead_bits + 1));
|
const unsigned char mask = (0xFF >> (lead_bits + 1));
|
||||||
return static_cast<char>(
|
return static_cast<char>(
|
||||||
static_cast<unsigned char>(header | ((ch >> rshift) & mask)));
|
static_cast<unsigned char>(header | ((ch >> rshift) & mask)));
|
||||||
@ -192,17 +184,20 @@ inline void QueueUnicodeCodepoint(std::deque<char>& q, unsigned long ch) {
|
|||||||
|
|
||||||
Stream::Stream(std::istream& input)
|
Stream::Stream(std::istream& input)
|
||||||
: m_input(input),
|
: m_input(input),
|
||||||
|
m_mark{},
|
||||||
|
m_charSet{},
|
||||||
|
m_readahead{},
|
||||||
m_pPrefetched(new unsigned char[YAML_PREFETCH_SIZE]),
|
m_pPrefetched(new unsigned char[YAML_PREFETCH_SIZE]),
|
||||||
m_nPrefetchedAvailable(0),
|
m_nPrefetchedAvailable(0),
|
||||||
m_nPrefetchedUsed(0) {
|
m_nPrefetchedUsed(0) {
|
||||||
typedef std::istream::traits_type char_traits;
|
using char_traits = std::istream::traits_type;
|
||||||
|
|
||||||
if (!input)
|
if (!input)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Determine (or guess) the character-set by reading the BOM, if any. See
|
// Determine (or guess) the character-set by reading the BOM, if any. See
|
||||||
// the YAML specification for the determination algorithm.
|
// the YAML specification for the determination algorithm.
|
||||||
char_traits::int_type intro[4];
|
char_traits::int_type intro[4]{};
|
||||||
int nIntroUsed = 0;
|
int nIntroUsed = 0;
|
||||||
UtfIntroState state = uis_start;
|
UtfIntroState state = uis_start;
|
||||||
for (; !s_introFinalState[state];) {
|
for (; !s_introFinalState[state];) {
|
||||||
@ -279,9 +274,11 @@ char Stream::get() {
|
|||||||
// . Extracts 'n' characters from the stream and updates our position
|
// . Extracts 'n' characters from the stream and updates our position
|
||||||
std::string Stream::get(int n) {
|
std::string Stream::get(int n) {
|
||||||
std::string ret;
|
std::string ret;
|
||||||
ret.reserve(n);
|
if (n > 0) {
|
||||||
|
ret.reserve(static_cast<std::string::size_type>(n));
|
||||||
for (int i = 0; i < n; i++)
|
for (int i = 0; i < n; i++)
|
||||||
ret += get();
|
ret += get();
|
||||||
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -332,7 +329,7 @@ bool Stream::_ReadAheadTo(size_t i) const {
|
|||||||
void Stream::StreamInUtf8() const {
|
void Stream::StreamInUtf8() const {
|
||||||
unsigned char b = GetNextByte();
|
unsigned char b = GetNextByte();
|
||||||
if (m_input.good()) {
|
if (m_input.good()) {
|
||||||
m_readahead.push_back(b);
|
m_readahead.push_back(static_cast<char>(b));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -353,7 +350,9 @@ void Stream::StreamInUtf16() const {
|
|||||||
// Trailing (low) surrogate...ugh, wrong order
|
// Trailing (low) surrogate...ugh, wrong order
|
||||||
QueueUnicodeCodepoint(m_readahead, CP_REPLACEMENT_CHARACTER);
|
QueueUnicodeCodepoint(m_readahead, CP_REPLACEMENT_CHARACTER);
|
||||||
return;
|
return;
|
||||||
} else if (ch >= 0xD800 && ch < 0xDC00) {
|
}
|
||||||
|
|
||||||
|
if (ch >= 0xD800 && ch < 0xDC00) {
|
||||||
// ch is a leading (high) surrogate
|
// ch is a leading (high) surrogate
|
||||||
|
|
||||||
// Four byte UTF-8 code point
|
// Four byte UTF-8 code point
|
||||||
@ -378,12 +377,11 @@ void Stream::StreamInUtf16() const {
|
|||||||
// Easiest case: queue the codepoint and return
|
// Easiest case: queue the codepoint and return
|
||||||
QueueUnicodeCodepoint(m_readahead, ch);
|
QueueUnicodeCodepoint(m_readahead, ch);
|
||||||
return;
|
return;
|
||||||
} else {
|
}
|
||||||
// Start the loop over with the new high surrogate
|
// Start the loop over with the new high surrogate
|
||||||
ch = chLow;
|
ch = chLow;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Select the payload bits from the high surrogate
|
// Select the payload bits from the high surrogate
|
||||||
ch &= 0x3FF;
|
ch &= 0x3FF;
|
||||||
@ -445,4 +443,4 @@ void Stream::StreamInUtf32() const {
|
|||||||
|
|
||||||
QueueUnicodeCodepoint(m_readahead, ch);
|
QueueUnicodeCodepoint(m_readahead, ch);
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
12
3rdparty/yaml-cpp/src/stream.h
vendored
12
3rdparty/yaml-cpp/src/stream.h
vendored
@ -7,7 +7,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/noncopyable.h"
|
|
||||||
#include "yaml-cpp/mark.h"
|
#include "yaml-cpp/mark.h"
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <deque>
|
#include <deque>
|
||||||
@ -17,11 +16,18 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
class Stream : private noncopyable {
|
|
||||||
|
class StreamCharSource;
|
||||||
|
|
||||||
|
class Stream {
|
||||||
public:
|
public:
|
||||||
friend class StreamCharSource;
|
friend class StreamCharSource;
|
||||||
|
|
||||||
Stream(std::istream& input);
|
Stream(std::istream& input);
|
||||||
|
Stream(const Stream&) = delete;
|
||||||
|
Stream(Stream&&) = delete;
|
||||||
|
Stream& operator=(const Stream&) = delete;
|
||||||
|
Stream& operator=(Stream&&) = delete;
|
||||||
~Stream();
|
~Stream();
|
||||||
|
|
||||||
operator bool() const;
|
operator bool() const;
|
||||||
@ -71,6 +77,6 @@ inline bool Stream::ReadAheadTo(size_t i) const {
|
|||||||
return true;
|
return true;
|
||||||
return _ReadAheadTo(i);
|
return _ReadAheadTo(i);
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // STREAM_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // STREAM_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
18
3rdparty/yaml-cpp/src/streamcharsource.h
vendored
18
3rdparty/yaml-cpp/src/streamcharsource.h
vendored
@ -7,16 +7,20 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "yaml-cpp/noncopyable.h"
|
#include "yaml-cpp/noexcept.h"
|
||||||
|
#include "stream.h"
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
|
|
||||||
class StreamCharSource {
|
class StreamCharSource {
|
||||||
public:
|
public:
|
||||||
StreamCharSource(const Stream& stream) : m_offset(0), m_stream(stream) {}
|
StreamCharSource(const Stream& stream) : m_offset(0), m_stream(stream) {}
|
||||||
StreamCharSource(const StreamCharSource& source)
|
StreamCharSource(const StreamCharSource& source) = default;
|
||||||
: m_offset(source.m_offset), m_stream(source.m_stream) {}
|
StreamCharSource(StreamCharSource&&) YAML_CPP_NOEXCEPT = default;
|
||||||
~StreamCharSource() {}
|
StreamCharSource& operator=(const StreamCharSource&) = delete;
|
||||||
|
StreamCharSource& operator=(StreamCharSource&&) = delete;
|
||||||
|
~StreamCharSource() = default;
|
||||||
|
|
||||||
operator bool() const;
|
operator bool() const;
|
||||||
char operator[](std::size_t i) const { return m_stream.CharAt(m_offset + i); }
|
char operator[](std::size_t i) const { return m_stream.CharAt(m_offset + i); }
|
||||||
@ -27,8 +31,6 @@ class StreamCharSource {
|
|||||||
private:
|
private:
|
||||||
std::size_t m_offset;
|
std::size_t m_offset;
|
||||||
const Stream& m_stream;
|
const Stream& m_stream;
|
||||||
|
|
||||||
StreamCharSource& operator=(const StreamCharSource&); // non-assignable
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline StreamCharSource::operator bool() const {
|
inline StreamCharSource::operator bool() const {
|
||||||
@ -38,11 +40,11 @@ inline StreamCharSource::operator bool() const {
|
|||||||
inline const StreamCharSource StreamCharSource::operator+(int i) const {
|
inline const StreamCharSource StreamCharSource::operator+(int i) const {
|
||||||
StreamCharSource source(*this);
|
StreamCharSource source(*this);
|
||||||
if (static_cast<int>(source.m_offset) + i >= 0)
|
if (static_cast<int>(source.m_offset) + i >= 0)
|
||||||
source.m_offset += i;
|
source.m_offset += static_cast<std::size_t>(i);
|
||||||
else
|
else
|
||||||
source.m_offset = 0;
|
source.m_offset = 0;
|
||||||
return source;
|
return source;
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // STREAMCHARSOURCE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // STREAMCHARSOURCE_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
7
3rdparty/yaml-cpp/src/tag.cpp
vendored
7
3rdparty/yaml-cpp/src/tag.cpp
vendored
@ -6,7 +6,8 @@
|
|||||||
#include "token.h"
|
#include "token.h"
|
||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
Tag::Tag(const Token& token) : type(static_cast<TYPE>(token.data)) {
|
Tag::Tag(const Token& token)
|
||||||
|
: type(static_cast<TYPE>(token.data)), handle{}, value{} {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case VERBATIM:
|
case VERBATIM:
|
||||||
value = token.value;
|
value = token.value;
|
||||||
@ -28,7 +29,7 @@ Tag::Tag(const Token& token) : type(static_cast<TYPE>(token.data)) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::string Tag::Translate(const Directives& directives) {
|
std::string Tag::Translate(const Directives& directives) {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case VERBATIM:
|
case VERBATIM:
|
||||||
return value;
|
return value;
|
||||||
@ -46,4 +47,4 @@ const std::string Tag::Translate(const Directives& directives) {
|
|||||||
}
|
}
|
||||||
throw std::runtime_error("yaml-cpp: internal error, bad tag type");
|
throw std::runtime_error("yaml-cpp: internal error, bad tag type");
|
||||||
}
|
}
|
||||||
}
|
} // namespace YAML
|
||||||
|
2
3rdparty/yaml-cpp/src/tag.h
vendored
2
3rdparty/yaml-cpp/src/tag.h
vendored
@ -23,7 +23,7 @@ struct Tag {
|
|||||||
};
|
};
|
||||||
|
|
||||||
Tag(const Token& token);
|
Tag(const Token& token);
|
||||||
const std::string Translate(const Directives& directives);
|
std::string Translate(const Directives& directives);
|
||||||
|
|
||||||
TYPE type;
|
TYPE type;
|
||||||
std::string handle, value;
|
std::string handle, value;
|
||||||
|
17
3rdparty/yaml-cpp/src/token.h
vendored
17
3rdparty/yaml-cpp/src/token.h
vendored
@ -14,10 +14,11 @@
|
|||||||
|
|
||||||
namespace YAML {
|
namespace YAML {
|
||||||
const std::string TokenNames[] = {
|
const std::string TokenNames[] = {
|
||||||
"DIRECTIVE", "DOC_START", "DOC_END", "BLOCK_SEQ_START", "BLOCK_MAP_START",
|
"DIRECTIVE", "DOC_START", "DOC_END", "BLOCK_SEQ_START",
|
||||||
"BLOCK_SEQ_END", "BLOCK_MAP_END", "BLOCK_ENTRY", "FLOW_SEQ_START",
|
"BLOCK_MAP_START", "BLOCK_SEQ_END", "BLOCK_MAP_END", "BLOCK_ENTRY",
|
||||||
"FLOW_MAP_START", "FLOW_SEQ_END", "FLOW_MAP_END", "FLOW_MAP_COMPACT",
|
"FLOW_SEQ_START", "FLOW_MAP_START", "FLOW_SEQ_END", "FLOW_MAP_END",
|
||||||
"FLOW_ENTRY", "KEY", "VALUE", "ANCHOR", "ALIAS", "TAG", "SCALAR"};
|
"FLOW_MAP_COMPACT", "FLOW_ENTRY", "KEY", "VALUE",
|
||||||
|
"ANCHOR", "ALIAS", "TAG", "SCALAR"};
|
||||||
|
|
||||||
struct Token {
|
struct Token {
|
||||||
// enums
|
// enums
|
||||||
@ -48,12 +49,12 @@ struct Token {
|
|||||||
|
|
||||||
// data
|
// data
|
||||||
Token(TYPE type_, const Mark& mark_)
|
Token(TYPE type_, const Mark& mark_)
|
||||||
: status(VALID), type(type_), mark(mark_), data(0) {}
|
: status(VALID), type(type_), mark(mark_), value{}, params{}, data(0) {}
|
||||||
|
|
||||||
friend std::ostream& operator<<(std::ostream& out, const Token& token) {
|
friend std::ostream& operator<<(std::ostream& out, const Token& token) {
|
||||||
out << TokenNames[token.type] << std::string(": ") << token.value;
|
out << TokenNames[token.type] << std::string(": ") << token.value;
|
||||||
for (std::size_t i = 0; i < token.params.size(); i++)
|
for (const std::string& param : token.params)
|
||||||
out << std::string(" ") << token.params[i];
|
out << std::string(" ") << param;
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,6 +65,6 @@ struct Token {
|
|||||||
std::vector<std::string> params;
|
std::vector<std::string> params;
|
||||||
int data;
|
int data;
|
||||||
};
|
};
|
||||||
}
|
} // namespace YAML
|
||||||
|
|
||||||
#endif // TOKEN_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
#endif // TOKEN_H_62B23520_7C8E_11DE_8A39_0800200C9A66
|
||||||
|
13
3rdparty/yaml-cpp/yaml-cpp.vcxproj
vendored
13
3rdparty/yaml-cpp/yaml-cpp.vcxproj
vendored
@ -95,8 +95,9 @@
|
|||||||
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
|
||||||
<InlineFunctionExpansion>Disabled</InlineFunctionExpansion>
|
<InlineFunctionExpansion>Disabled</InlineFunctionExpansion>
|
||||||
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YAML_CPP_STATIC_DEFINE;WIN32;_WINDOWS;_DEBUG;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||||
@ -107,8 +108,9 @@
|
|||||||
</SDLCheck>
|
</SDLCheck>
|
||||||
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
||||||
<InlineFunctionExpansion>Disabled</InlineFunctionExpansion>
|
<InlineFunctionExpansion>Disabled</InlineFunctionExpansion>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YAML_CPP_STATIC_DEFINE;WIN32;_WINDOWS;_DEBUG;_ITERATOR_DEBUG_LEVEL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
@ -120,8 +122,9 @@
|
|||||||
<SDLCheck>
|
<SDLCheck>
|
||||||
</SDLCheck>
|
</SDLCheck>
|
||||||
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YAML_CPP_STATIC_DEFINE;WIN32;_WINDOWS;NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
@ -137,8 +140,9 @@
|
|||||||
<SDLCheck>
|
<SDLCheck>
|
||||||
</SDLCheck>
|
</SDLCheck>
|
||||||
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>$(SolutionDir)3rdparty\yaml-cpp\include\;$(SolutionDir)3rdparty\yaml-cpp\src\;</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>YAML_CPP_STATIC_DEFINE;WIN32;_WINDOWS;NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
|
<MultiProcessorCompilation>true</MultiProcessorCompilation>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link>
|
<Link>
|
||||||
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
@ -174,6 +178,7 @@
|
|||||||
<ClCompile Include="src\contrib\graphbuilder.cpp" />
|
<ClCompile Include="src\contrib\graphbuilder.cpp" />
|
||||||
<ClCompile Include="src\contrib\graphbuilderadapter.cpp" />
|
<ClCompile Include="src\contrib\graphbuilderadapter.cpp" />
|
||||||
<ClCompile Include="src\convert.cpp" />
|
<ClCompile Include="src\convert.cpp" />
|
||||||
|
<ClCompile Include="src\depthguard.cpp" />
|
||||||
<ClCompile Include="src\directives.cpp" />
|
<ClCompile Include="src\directives.cpp" />
|
||||||
<ClCompile Include="src\emit.cpp" />
|
<ClCompile Include="src\emit.cpp" />
|
||||||
<ClCompile Include="src\emitfromevents.cpp" />
|
<ClCompile Include="src\emitfromevents.cpp" />
|
||||||
|
3
3rdparty/yaml-cpp/yaml-cpp.vcxproj.filters
vendored
3
3rdparty/yaml-cpp/yaml-cpp.vcxproj.filters
vendored
@ -89,6 +89,9 @@
|
|||||||
<ClCompile Include="src\convert.cpp">
|
<ClCompile Include="src\convert.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="src\depthguard.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="src\directives.cpp">
|
<ClCompile Include="src\directives.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@ -35,7 +35,7 @@ project( rAthena )
|
|||||||
if( CYGWIN )
|
if( CYGWIN )
|
||||||
unset( WIN32 )
|
unset( WIN32 )
|
||||||
endif()
|
endif()
|
||||||
set(CMAKE_CXX_STANDARD 11) # C++11...
|
set(CMAKE_CXX_STANDARD 17) # C++17...
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON) #...is required...
|
set(CMAKE_CXX_STANDARD_REQUIRED ON) #...is required...
|
||||||
#set(CMAKE_CXX_EXTENSIONS OFF) #...without compiler extensions like gnu++11
|
#set(CMAKE_CXX_EXTENSIONS OFF) #...without compiler extensions like gnu++11
|
||||||
|
|
||||||
@ -236,7 +236,7 @@ option( ENABLE_WEB_SERVER "Build web-server (default=ON)" ON )
|
|||||||
#
|
#
|
||||||
TEST_BIG_ENDIAN( BIG_ENDIAN )
|
TEST_BIG_ENDIAN( BIG_ENDIAN )
|
||||||
if( NOT DEFINED BIG_ENDIAN )
|
if( NOT DEFINED BIG_ENDIAN )
|
||||||
message( WARNING "unable to determine endianess, only LITTLE ENDIAN is supported" )
|
message( WARNING "unable to determine endianness, only LITTLE ENDIAN is supported" )
|
||||||
elseif( BIG_ENDIAN )
|
elseif( BIG_ENDIAN )
|
||||||
message( FATAL_ERROR "bigendian is not supported" )
|
message( FATAL_ERROR "bigendian is not supported" )
|
||||||
endif()
|
endif()
|
||||||
@ -309,6 +309,17 @@ if( ENABLE_EXTRA_DEBUG_CODE )
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable EPOLL (default=OFF)
|
||||||
|
# Only for Linux
|
||||||
|
#
|
||||||
|
option( ENABLE_EXTRA_SOCKET_POLL "enable SOCKET_EPOLL (default=OFF)" OFF )
|
||||||
|
if( ENABLE_EXTRA_SOCKET_POLL )
|
||||||
|
set_property( CACHE GLOBAL_DEFINITIONS PROPERTY VALUE "${GLOBAL_DEFINITIONS} -DSOCKET_EPOLL" )
|
||||||
|
message( STATUS "Enabled SOCKET_EPOLL" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Enable builtin memory manager (default=default)
|
# Enable builtin memory manager (default=default)
|
||||||
#
|
#
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user