Commit d4ea0ca
Optimize adjacent-token joining in both inline cleanup stages by
replacing repeated pairwise string concatenation with a single
`"".join(...)` over each contiguous run.
## Details
- `fragments_join` merges adjacent `text` tokens left behind after
emphasis/strikethrough post-processing and recalculates token levels
- `text_join` converts `text_special` tokens to `text` and performs the
final adjacent-text merge in the inline token stream
Both rules previously rebuilt growing strings incrementally, which can
become quadratic for long runs.
## Why
Tested on an adversarial ~190 KB document with ~30k intraword
underscores on a single line. With `tracemalloc` running:
| | render time | peak Python alloc |
|-----------|-------------|-------------------|
| before | 2.2s | 4476 MB |
| after | 0.6s | 23 MB |
It's not just a contrived attack input - this kind of thing also shows
up naturally in Markdown produced by OCR pipelines, where tables of
identifiers / references can easily contain very long runs of
underscores or other delimiter characters.
## Tests
Added focused tests for both rules:
- `fragments_join`: verifies raw adjacent text fragments remain when
both join stages are disabled, and that `fragments_join` alone collapses
them when `text_join` is disabled
- `text_join`: verifies escaped characters remain as multiple
`text_special` tokens when `text_join` is disabled, and are converted
and merged into a single `text` token when enabled
## Result
No behavioral change in parser output, with less unnecessary work when
joining long runs of adjacent tokens.
---------
Co-authored-by: Chris Sewell <chrisj_sewell@hotmail.com>
1 parent 8933147 commit d4ea0ca
3 files changed
Lines changed: 101 additions & 9 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
24 | | - | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
25 | 28 | | |
26 | 29 | | |
27 | 30 | | |
28 | 31 | | |
29 | 32 | | |
30 | 33 | | |
31 | 34 | | |
32 | | - | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
33 | 50 | | |
34 | 51 | | |
| 52 | + | |
35 | 53 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
32 | | - | |
33 | | - | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
38 | | - | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
39 | 45 | | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
40 | 51 | | |
41 | 52 | | |
42 | 53 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
279 | 279 | | |
280 | 280 | | |
281 | 281 | | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
0 commit comments