Commit a724a09
authored
* perf(native): scope incremental rebuild to truly-changed files (#1012)
Native 1-file incremental was 4.3x slower than WASM (876ms vs 203ms) because
`run_pipeline` re-parsed the full reverse-dep cone (47 files for a 1-file
change), which cascaded into insert/structure/roles/analysis phases.
Adopt the WASM save+reconnect strategy: save reverse-dep → changed-file
edges before purge, reconnect to new node IDs after Stage 5. Reverse-dep
files are no longer re-parsed — only their affected edges are reconstructed.
Result: 876ms → 43ms (95% faster, 0.78x WASM).
- insertMs: 185ms → 0.2ms
- structureMs: 73ms → 3.1ms
- rolesMs: 311ms → 18.3ms
Edge counts identical between full and 1-file rebuild (37134), confirming
no edge loss or duplication. The existing `1-file incremental ratio` gate
in `benchmark-parity-gate.mjs` (limit 1.5) enforces the ceiling.
* fix(native): only count actual inserts in reconnect counter (#1027)
INSERT OR IGNORE returns Ok(0) for duplicate-row no-ops, so the previous
`is_ok()` check inflated `reconnected` whenever two saved entries
resolved to the same (source_id, new_target_id, kind). Match on the
rows-affected count and only increment when n > 0; leave the dropped
counter for genuine errors. Diagnostic-only — no functional change to
edge data.
Impact: 1 functions changed, 0 affected
* fix(native): log dropped reverse-dep edges during reconnect (#1027)
`reconnect_reverse_dep_edges` returns `(reconnected, dropped)` but the
caller previously discarded the result. Dropped edges occur when a saved
target node can't be re-located after re-insert (e.g. the symbol was
renamed or deleted), and silently swallowing them makes partial edge
loss during incremental rebuild hard to diagnose. Surface the count via
eprintln when dropped > 0 — same observability pattern other native
diagnostics use.
Impact: 1 functions changed, 0 affected
* fix(native): reclassify reverse-deps of removed files (#1027)
When a file is removed during incremental build, its nodes are purged
along with edges pointing at them. Files that imported the removed file
were never re-parsed (correct, by design) but their role records became
stale: fan-out dropped silently because do_classify_incremental was only
seeded with parsed files. For removal-only builds, classification was
skipped entirely.
Compute reverse-deps of removed entries before purge (find_reverse_deps
with change_result.removed as seed, mirroring WASM/JS) and union them
into the seed passed to do_classify_incremental. No re-parse needed —
the classifier reads fan-in/fan-out from the post-purge edges table.
Impact: 1 functions changed, 0 affected
1 parent 57a6df4 commit a724a09
3 files changed
Lines changed: 224 additions & 56 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
180 | 180 | | |
181 | 181 | | |
182 | 182 | | |
183 | | - | |
184 | | - | |
185 | | - | |
186 | | - | |
187 | | - | |
188 | | - | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
189 | 193 | | |
190 | 194 | | |
191 | 195 | | |
192 | 196 | | |
193 | 197 | | |
194 | 198 | | |
195 | | - | |
196 | | - | |
197 | | - | |
198 | | - | |
199 | | - | |
200 | | - | |
201 | | - | |
202 | | - | |
203 | | - | |
204 | | - | |
205 | | - | |
206 | | - | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
207 | 217 | | |
208 | 218 | | |
209 | 219 | | |
210 | 220 | | |
211 | 221 | | |
212 | 222 | | |
213 | 223 | | |
214 | | - | |
215 | | - | |
216 | | - | |
217 | | - | |
218 | | - | |
219 | | - | |
220 | | - | |
221 | | - | |
222 | | - | |
223 | | - | |
224 | | - | |
225 | | - | |
226 | | - | |
227 | | - | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
228 | 230 | | |
229 | 231 | | |
230 | 232 | | |
| 233 | + | |
| 234 | + | |
231 | 235 | | |
232 | | - | |
| 236 | + | |
233 | 237 | | |
234 | | - | |
235 | | - | |
236 | 238 | | |
237 | 239 | | |
238 | 240 | | |
| |||
330 | 332 | | |
331 | 333 | | |
332 | 334 | | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
333 | 349 | | |
334 | 350 | | |
335 | 351 | | |
336 | 352 | | |
337 | 353 | | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
338 | 357 | | |
339 | | - | |
340 | | - | |
341 | | - | |
342 | | - | |
343 | 358 | | |
344 | 359 | | |
345 | 360 | | |
346 | | - | |
347 | | - | |
348 | | - | |
349 | | - | |
350 | | - | |
351 | | - | |
352 | | - | |
| 361 | + | |
353 | 362 | | |
354 | 363 | | |
355 | 364 | | |
356 | | - | |
357 | | - | |
358 | | - | |
359 | 365 | | |
360 | 366 | | |
361 | 367 | | |
| |||
385 | 391 | | |
386 | 392 | | |
387 | 393 | | |
388 | | - | |
389 | | - | |
390 | | - | |
391 | | - | |
392 | | - | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
393 | 401 | | |
394 | 402 | | |
395 | 403 | | |
396 | | - | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
397 | 414 | | |
398 | 415 | | |
399 | 416 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
345 | 345 | | |
346 | 346 | | |
347 | 347 | | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
| 451 | + | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
| 484 | + | |
| 485 | + | |
| 486 | + | |
| 487 | + | |
| 488 | + | |
| 489 | + | |
| 490 | + | |
| 491 | + | |
| 492 | + | |
| 493 | + | |
| 494 | + | |
| 495 | + | |
| 496 | + | |
| 497 | + | |
| 498 | + | |
348 | 499 | | |
349 | 500 | | |
350 | 501 | | |
| |||
0 commit comments