Commit d18c788
authored
Fix past end array access on unsigned char builds (#260)
- There are some platforms where `char` is implemented as `unsigned
char` such as arm architectures. In this systems, the existing code
to access the `ParseFlagMap` and `WhitespaceMap` arrays will access
elements past the end of the arrays.
- This PR fixes the bug by making the offset to convert the `char` into
an array index dependent on how `char` is implemented.
- Modifications on single headers were manually introduced as the
command:
`cmake --build build/ --target=generate_single_header`
Introduces way more changes than the introduced ones.1 parent 2303be9 commit d18c788
File tree
5 files changed
+76
-85
lines changed- include/internal
- single_include_test
- single_include
5 files changed
+76
-85
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
26 | 38 | | |
27 | 39 | | |
28 | 40 | | |
29 | 41 | | |
30 | 42 | | |
31 | | - | |
32 | | - | |
33 | | - | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
38 | | - | |
39 | | - | |
40 | | - | |
41 | | - | |
42 | | - | |
43 | | - | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
44 | 47 | | |
45 | 48 | | |
46 | 49 | | |
| |||
50 | 53 | | |
51 | 54 | | |
52 | 55 | | |
53 | | - | |
| 56 | + | |
54 | 57 | | |
55 | 58 | | |
56 | 59 | | |
| |||
59 | 62 | | |
60 | 63 | | |
61 | 64 | | |
62 | | - | |
63 | | - | |
64 | | - | |
65 | | - | |
66 | | - | |
67 | | - | |
68 | | - | |
69 | | - | |
70 | | - | |
71 | | - | |
72 | | - | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
73 | 68 | | |
74 | | - | |
75 | 69 | | |
76 | 70 | | |
77 | 71 | | |
| |||
221 | 215 | | |
222 | 216 | | |
223 | 217 | | |
224 | | - | |
| 218 | + | |
225 | 219 | | |
226 | 220 | | |
227 | 221 | | |
| |||
285 | 279 | | |
286 | 280 | | |
287 | 281 | | |
288 | | - | |
| 282 | + | |
289 | 283 | | |
290 | 284 | | |
291 | 285 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
212 | 215 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
78 | 78 | | |
79 | 79 | | |
80 | 80 | | |
81 | | - | |
| 81 | + | |
82 | 82 | | |
83 | 83 | | |
84 | 84 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4846 | 4846 | | |
4847 | 4847 | | |
4848 | 4848 | | |
| 4849 | + | |
| 4850 | + | |
| 4851 | + | |
4849 | 4852 | | |
4850 | 4853 | | |
4851 | 4854 | | |
| |||
5862 | 5865 | | |
5863 | 5866 | | |
5864 | 5867 | | |
| 5868 | + | |
| 5869 | + | |
| 5870 | + | |
| 5871 | + | |
| 5872 | + | |
| 5873 | + | |
| 5874 | + | |
| 5875 | + | |
| 5876 | + | |
| 5877 | + | |
| 5878 | + | |
| 5879 | + | |
5865 | 5880 | | |
5866 | 5881 | | |
5867 | 5882 | | |
5868 | 5883 | | |
5869 | 5884 | | |
5870 | | - | |
5871 | | - | |
5872 | | - | |
5873 | | - | |
5874 | | - | |
5875 | | - | |
5876 | | - | |
5877 | | - | |
5878 | | - | |
5879 | | - | |
5880 | | - | |
5881 | | - | |
5882 | | - | |
| 5885 | + | |
| 5886 | + | |
| 5887 | + | |
| 5888 | + | |
5883 | 5889 | | |
5884 | 5890 | | |
5885 | 5891 | | |
| |||
5889 | 5895 | | |
5890 | 5896 | | |
5891 | 5897 | | |
5892 | | - | |
| 5898 | + | |
5893 | 5899 | | |
5894 | 5900 | | |
5895 | 5901 | | |
| |||
5898 | 5904 | | |
5899 | 5905 | | |
5900 | 5906 | | |
5901 | | - | |
5902 | | - | |
5903 | | - | |
5904 | | - | |
5905 | | - | |
5906 | | - | |
5907 | | - | |
5908 | | - | |
5909 | | - | |
5910 | | - | |
5911 | | - | |
| 5907 | + | |
| 5908 | + | |
| 5909 | + | |
5912 | 5910 | | |
5913 | | - | |
5914 | 5911 | | |
5915 | 5912 | | |
5916 | 5913 | | |
| |||
6060 | 6057 | | |
6061 | 6058 | | |
6062 | 6059 | | |
6063 | | - | |
| 6060 | + | |
6064 | 6061 | | |
6065 | 6062 | | |
6066 | 6063 | | |
| |||
6124 | 6121 | | |
6125 | 6122 | | |
6126 | 6123 | | |
6127 | | - | |
| 6124 | + | |
6128 | 6125 | | |
6129 | 6126 | | |
6130 | 6127 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4846 | 4846 | | |
4847 | 4847 | | |
4848 | 4848 | | |
| 4849 | + | |
| 4850 | + | |
| 4851 | + | |
4849 | 4852 | | |
4850 | 4853 | | |
4851 | 4854 | | |
| |||
5862 | 5865 | | |
5863 | 5866 | | |
5864 | 5867 | | |
| 5868 | + | |
| 5869 | + | |
| 5870 | + | |
| 5871 | + | |
| 5872 | + | |
| 5873 | + | |
| 5874 | + | |
| 5875 | + | |
| 5876 | + | |
| 5877 | + | |
| 5878 | + | |
| 5879 | + | |
5865 | 5880 | | |
5866 | 5881 | | |
5867 | 5882 | | |
5868 | 5883 | | |
5869 | 5884 | | |
5870 | | - | |
5871 | | - | |
5872 | | - | |
5873 | | - | |
5874 | | - | |
5875 | | - | |
5876 | | - | |
5877 | | - | |
5878 | | - | |
5879 | | - | |
5880 | | - | |
5881 | | - | |
5882 | | - | |
| 5885 | + | |
| 5886 | + | |
| 5887 | + | |
| 5888 | + | |
5883 | 5889 | | |
5884 | 5890 | | |
5885 | 5891 | | |
| |||
5889 | 5895 | | |
5890 | 5896 | | |
5891 | 5897 | | |
5892 | | - | |
| 5898 | + | |
5893 | 5899 | | |
5894 | 5900 | | |
5895 | 5901 | | |
| |||
5898 | 5904 | | |
5899 | 5905 | | |
5900 | 5906 | | |
5901 | | - | |
5902 | | - | |
5903 | | - | |
5904 | | - | |
5905 | | - | |
5906 | | - | |
5907 | | - | |
5908 | | - | |
5909 | | - | |
5910 | | - | |
5911 | | - | |
| 5907 | + | |
| 5908 | + | |
| 5909 | + | |
5912 | 5910 | | |
5913 | | - | |
5914 | 5911 | | |
5915 | 5912 | | |
5916 | 5913 | | |
| |||
6060 | 6057 | | |
6061 | 6058 | | |
6062 | 6059 | | |
6063 | | - | |
| 6060 | + | |
6064 | 6061 | | |
6065 | 6062 | | |
6066 | 6063 | | |
| |||
6124 | 6121 | | |
6125 | 6122 | | |
6126 | 6123 | | |
6127 | | - | |
| 6124 | + | |
6128 | 6125 | | |
6129 | 6126 | | |
6130 | 6127 | | |
| |||
0 commit comments