This repository was archived by the owner on May 28, 2025. It is now read-only.
Commit 0a89233
committed
Auto merge of rust-lang#119688 - Nadrieril:dont-alloc-custom-wildcards, r=compiler-errors
Exhaustiveness: use an `Option` instead of allocating fictitious patterns
In the process of exhaustiveness checking, `Matrix` stores a 2D array of patterns. Those are subpatterns of the patterns we were provided as input, _except_ sometimes we allocate some extra wildcard patterns to fill a hole during specialization.
Morally though, we could store `Option<&'p DeconstructedPat>` in the matrix, where `None` signifies a wildcard. That way we'd only have "real" patterns in the matrix and we wouldn't need the arena to allocate these wildcards. This is what this PR does.
This is part of me splitting up rust-lang#119581 for ease of review.
r? `@compiler-errors`File tree
3 files changed
+119
-70
lines changed- compiler/rustc_pattern_analysis/src
3 files changed
+119
-70
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
| |||
23 | 24 | | |
24 | 25 | | |
25 | 26 | | |
26 | | - | |
| 27 | + | |
27 | 28 | | |
28 | | - | |
| 29 | + | |
29 | 30 | | |
30 | 31 | | |
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
34 | 35 | | |
35 | 36 | | |
36 | | - | |
| 37 | + | |
| 38 | + | |
37 | 39 | | |
38 | | - | |
39 | | - | |
40 | | - | |
41 | | - | |
42 | | - | |
| 40 | + | |
43 | 41 | | |
44 | | - | |
| 42 | + | |
45 | 43 | | |
46 | | - | |
47 | | - | |
48 | | - | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
49 | 55 | | |
| 56 | + | |
50 | 57 | | |
51 | 58 | | |
52 | 59 | | |
| |||
83 | 90 | | |
84 | 91 | | |
85 | 92 | | |
86 | | - | |
87 | 93 | | |
88 | | - | |
89 | | - | |
90 | | - | |
91 | | - | |
92 | | - | |
93 | | - | |
94 | | - | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
95 | 97 | | |
96 | 98 | | |
97 | | - | |
98 | | - | |
99 | | - | |
100 | | - | |
101 | | - | |
102 | | - | |
103 | 99 | | |
104 | 100 | | |
105 | 101 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
50 | 50 | | |
51 | 51 | | |
52 | 52 | | |
53 | | - | |
54 | | - | |
55 | | - | |
56 | | - | |
57 | | - | |
58 | | - | |
59 | | - | |
60 | | - | |
61 | 53 | | |
62 | 54 | | |
63 | 55 | | |
| |||
79 | 71 | | |
80 | 72 | | |
81 | 73 | | |
82 | | - | |
83 | 74 | | |
84 | | - | |
85 | | - | |
86 | | - | |
87 | | - | |
88 | | - | |
89 | | - | |
90 | | - | |
91 | | - | |
92 | | - | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
93 | 78 | | |
94 | 79 | | |
95 | 80 | | |
| |||
105 | 90 | | |
106 | 91 | | |
107 | 92 | | |
108 | | - | |
| 93 | + | |
109 | 94 | | |
110 | 95 | | |
111 | | - | |
| 96 | + | |
| 97 | + | |
112 | 98 | | |
113 | 99 | | |
114 | 100 | | |
115 | | - | |
| 101 | + | |
116 | 102 | | |
117 | 103 | | |
118 | 104 | | |
| |||
153 | 139 | | |
154 | 140 | | |
155 | 141 | | |
156 | | - | |
157 | | - | |
| 142 | + | |
158 | 143 | | |
159 | 144 | | |
160 | 145 | | |
161 | 146 | | |
162 | 147 | | |
163 | 148 | | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
164 | 222 | | |
165 | 223 | | |
166 | 224 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
716 | 716 | | |
717 | 717 | | |
718 | 718 | | |
719 | | - | |
| 719 | + | |
720 | 720 | | |
721 | 721 | | |
722 | 722 | | |
| |||
827 | 827 | | |
828 | 828 | | |
829 | 829 | | |
830 | | - | |
| 830 | + | |
831 | 831 | | |
832 | 832 | | |
833 | 833 | | |
| |||
836 | 836 | | |
837 | 837 | | |
838 | 838 | | |
839 | | - | |
| 839 | + | |
840 | 840 | | |
841 | 841 | | |
842 | 842 | | |
| |||
847 | 847 | | |
848 | 848 | | |
849 | 849 | | |
850 | | - | |
851 | | - | |
852 | | - | |
853 | | - | |
854 | | - | |
| 850 | + | |
| 851 | + | |
855 | 852 | | |
856 | 853 | | |
857 | | - | |
| 854 | + | |
858 | 855 | | |
859 | 856 | | |
860 | 857 | | |
| |||
872 | 869 | | |
873 | 870 | | |
874 | 871 | | |
875 | | - | |
876 | 872 | | |
877 | | - | |
| 873 | + | |
878 | 874 | | |
879 | 875 | | |
880 | 876 | | |
881 | 877 | | |
882 | | - | |
| 878 | + | |
883 | 879 | | |
884 | 880 | | |
885 | 881 | | |
| |||
926 | 922 | | |
927 | 923 | | |
928 | 924 | | |
929 | | - | |
| 925 | + | |
930 | 926 | | |
931 | 927 | | |
932 | 928 | | |
933 | | - | |
| 929 | + | |
934 | 930 | | |
935 | 931 | | |
936 | 932 | | |
| |||
949 | 945 | | |
950 | 946 | | |
951 | 947 | | |
952 | | - | |
953 | 948 | | |
954 | | - | |
| 949 | + | |
955 | 950 | | |
956 | 951 | | |
957 | 952 | | |
958 | 953 | | |
959 | | - | |
| 954 | + | |
960 | 955 | | |
961 | 956 | | |
962 | 957 | | |
| |||
1054 | 1049 | | |
1055 | 1050 | | |
1056 | 1051 | | |
1057 | | - | |
| 1052 | + | |
1058 | 1053 | | |
1059 | 1054 | | |
1060 | 1055 | | |
| |||
1066 | 1061 | | |
1067 | 1062 | | |
1068 | 1063 | | |
| 1064 | + | |
1069 | 1065 | | |
1070 | 1066 | | |
1071 | 1067 | | |
1072 | 1068 | | |
1073 | | - | |
| 1069 | + | |
1074 | 1070 | | |
1075 | 1071 | | |
1076 | 1072 | | |
| |||
1081 | 1077 | | |
1082 | 1078 | | |
1083 | 1079 | | |
1084 | | - | |
1085 | | - | |
| 1080 | + | |
1086 | 1081 | | |
1087 | 1082 | | |
1088 | 1083 | | |
| |||
0 commit comments