Commit 75e4f24
committed
Fix past end array access on unsigned char builds
- 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 bc9131e commit 75e4f24
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 | | |
| |||
211 | 205 | | |
212 | 206 | | |
213 | 207 | | |
214 | | - | |
| 208 | + | |
215 | 209 | | |
216 | 210 | | |
217 | 211 | | |
| |||
275 | 269 | | |
276 | 270 | | |
277 | 271 | | |
278 | | - | |
| 272 | + | |
279 | 273 | | |
280 | 274 | | |
281 | 275 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
205 | 205 | | |
206 | 206 | | |
207 | 207 | | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
208 | 211 | | |
| 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 | | |
| |||
6050 | 6047 | | |
6051 | 6048 | | |
6052 | 6049 | | |
6053 | | - | |
| 6050 | + | |
6054 | 6051 | | |
6055 | 6052 | | |
6056 | 6053 | | |
| |||
6114 | 6111 | | |
6115 | 6112 | | |
6116 | 6113 | | |
6117 | | - | |
| 6114 | + | |
6118 | 6115 | | |
6119 | 6116 | | |
6120 | 6117 | | |
| |||
| 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 | | |
| |||
6050 | 6047 | | |
6051 | 6048 | | |
6052 | 6049 | | |
6053 | | - | |
| 6050 | + | |
6054 | 6051 | | |
6055 | 6052 | | |
6056 | 6053 | | |
| |||
6114 | 6111 | | |
6115 | 6112 | | |
6116 | 6113 | | |
6117 | | - | |
| 6114 | + | |
6118 | 6115 | | |
6119 | 6116 | | |
6120 | 6117 | | |
| |||
0 commit comments