Commit 143e3ea
Use arena offsets instead of holding an arena pointer in
This does not reduce the size of `RepeatedField`, but does greatly simplify the SOO logic, and makes `size()` branchless. Additionally, `RepeatedField`s now need `memcpy` in `MessageCreator::PlacementNew`, but don't require arena seeding.
All behavior changes introduced by this cl are flag-gated with `PROTOBUF_INTERNAL_REMOVE_ARENA_PTRS_REPEATED_FIELD`, which is currently off.
PiperOrigin-RevId: 819581961RepeatedField.1 parent 5f724e0 commit 143e3ea
File tree
10 files changed
+627
-136
lines changed- src/google/protobuf
- compiler/cpp
- field_generators
10 files changed
+627
-136
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
40 | 40 | | |
41 | 41 | | |
42 | 42 | | |
43 | | - | |
44 | 43 | | |
45 | 44 | | |
46 | 45 | | |
47 | | - | |
48 | | - | |
49 | | - | |
50 | | - | |
51 | | - | |
52 | | - | |
53 | | - | |
54 | | - | |
55 | | - | |
56 | 46 | | |
57 | 47 | | |
58 | 48 | | |
| |||
177 | 167 | | |
178 | 168 | | |
179 | 169 | | |
180 | | - | |
181 | | - | |
182 | | - | |
183 | | - | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
184 | 173 | | |
185 | | - | |
| 174 | + | |
186 | 175 | | |
187 | | - | |
| 176 | + | |
188 | 177 | | |
189 | | - | |
190 | | - | |
191 | | - | |
192 | | - | |
| 178 | + | |
193 | 179 | | |
194 | 180 | | |
195 | 181 | | |
| |||
211 | 197 | | |
212 | 198 | | |
213 | 199 | | |
214 | | - | |
| 200 | + | |
215 | 201 | | |
216 | 202 | | |
217 | 203 | | |
| |||
221 | 207 | | |
222 | 208 | | |
223 | 209 | | |
224 | | - | |
225 | | - | |
226 | 210 | | |
227 | 211 | | |
228 | 212 | | |
| |||
243 | 227 | | |
244 | 228 | | |
245 | 229 | | |
246 | | - | |
247 | | - | |
248 | | - | |
249 | | - | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
250 | 233 | | |
251 | | - | |
| 234 | + | |
252 | 235 | | |
253 | | - | |
| 236 | + | |
254 | 237 | | |
255 | | - | |
256 | | - | |
257 | | - | |
258 | | - | |
| 238 | + | |
259 | 239 | | |
260 | 240 | | |
261 | 241 | | |
| |||
309 | 289 | | |
310 | 290 | | |
311 | 291 | | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
312 | 299 | | |
313 | 300 | | |
314 | 301 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
203 | 203 | | |
204 | 204 | | |
205 | 205 | | |
| 206 | + | |
| 207 | + | |
206 | 208 | | |
207 | 209 | | |
208 | 210 | | |
| |||
Lines changed: 35 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
301 | 301 | | |
302 | 302 | | |
303 | 303 | | |
304 | | - | |
305 | | - | |
306 | | - | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
307 | 313 | | |
308 | 314 | | |
309 | 315 | | |
| |||
326 | 332 | | |
327 | 333 | | |
328 | 334 | | |
329 | | - | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
330 | 344 | | |
331 | 345 | | |
332 | 346 | | |
333 | 347 | | |
334 | 348 | | |
335 | 349 | | |
336 | | - | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
337 | 359 | | |
338 | 360 | | |
339 | 361 | | |
340 | 362 | | |
341 | 363 | | |
342 | 364 | | |
343 | | - | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
344 | 373 | | |
345 | 374 | | |
346 | 375 | | |
| |||
Lines changed: 35 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
351 | 351 | | |
352 | 352 | | |
353 | 353 | | |
354 | | - | |
355 | | - | |
356 | | - | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
357 | 363 | | |
358 | 364 | | |
359 | 365 | | |
| |||
366 | 372 | | |
367 | 373 | | |
368 | 374 | | |
369 | | - | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
370 | 384 | | |
371 | 385 | | |
372 | 386 | | |
373 | 387 | | |
374 | 388 | | |
375 | 389 | | |
376 | | - | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
377 | 399 | | |
378 | 400 | | |
379 | 401 | | |
380 | 402 | | |
381 | 403 | | |
382 | 404 | | |
383 | | - | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
384 | 413 | | |
385 | 414 | | |
386 | 415 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
128 | 128 | | |
129 | 129 | | |
130 | 130 | | |
131 | | - | |
| 131 | + | |
132 | 132 | | |
133 | 133 | | |
134 | 134 | | |
| |||
4065 | 4065 | | |
4066 | 4066 | | |
4067 | 4067 | | |
4068 | | - | |
| 4068 | + | |
4069 | 4069 | | |
4070 | 4070 | | |
4071 | 4071 | | |
| |||
0 commit comments