Commit c46defe
authored
perf(render): fix lazy-render and fold performance for large sessions (#393)
* perf(render): fix lazy-render and fold performance for large sessions
- Replace cursor+zc fold creation with :{from},{to}fold Ex commands
— avoids cursor-triggered screen redraws (~90ms/fold in large buffers)
- Switch to foldmethod=manual and stay there — prevents foldexpr
recalculation on every buffer line (~4.6s on 87K lines)
- Lazy-render only viewport-sized message count on initial load
- Load more messages on scroll-to-top via WinScrolled autocmd
- Fix lazy_render_count being cleared by M.reset() — read before reset,
persist back to ctx after determining limit
- Debounce WinScrolled load_more callback (150ms) to prevent rapid
re-renders during fast scrolling
- Remove debug vim.notify logging from render paths
Performance: ~36s → ~10ms render time on a 2786-msg/87K-line session.
Closes #392
* refactor(render): remove redundant foldexpr path
* fix(output): set fold fillchars for cleaner fold column rendering
* refactor(render): make lazy-render always active, fix cursor and gg
- Remove opts.lazy: lazy-render is always active as a perf optimization
- Decouple hidden_count from lazy-render truncation (only max_messages counts)
- Fix cursor jump after load_more: preserve position via anchor message
- Add gg keymap: load all messages before jumping to top, so full history
is searchable
* fix(render): fix gg E565 and gate load_more on has_unrendered
- Remove expr=true from gg keymap (causes E565 during buffer write)
- Gate scroll-to-top load_more on has_unrendered, not bare line number
- Fix load_more_messages treating nil as 'needs loading'1 parent adc77d1 commit c46defe
6 files changed
Lines changed: 509 additions & 101 deletions
File tree
- lua/opencode/ui
- renderer
- tests
- unit
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
17 | | - | |
18 | 17 | | |
19 | 18 | | |
20 | 19 | | |
| |||
23 | 22 | | |
24 | 23 | | |
25 | 24 | | |
26 | | - | |
27 | 25 | | |
28 | 26 | | |
29 | 27 | | |
30 | 28 | | |
31 | 29 | | |
32 | 30 | | |
33 | | - | |
34 | 31 | | |
35 | 32 | | |
36 | 33 | | |
37 | 34 | | |
38 | 35 | | |
39 | | - | |
| 36 | + | |
40 | 37 | | |
41 | 38 | | |
42 | 39 | | |
43 | | - | |
| 40 | + | |
44 | 41 | | |
45 | | - | |
| 42 | + | |
46 | 43 | | |
47 | 44 | | |
48 | 45 | | |
49 | 46 | | |
50 | 47 | | |
51 | | - | |
52 | | - | |
53 | | - | |
54 | | - | |
55 | | - | |
56 | | - | |
57 | | - | |
58 | | - | |
59 | | - | |
60 | | - | |
61 | | - | |
62 | | - | |
63 | | - | |
64 | | - | |
65 | | - | |
66 | | - | |
67 | | - | |
68 | | - | |
69 | | - | |
70 | | - | |
71 | | - | |
72 | | - | |
73 | 48 | | |
74 | 49 | | |
75 | 50 | | |
| |||
243 | 218 | | |
244 | 219 | | |
245 | 220 | | |
246 | | - | |
247 | | - | |
| 221 | + | |
248 | 222 | | |
249 | 223 | | |
250 | 224 | | |
| 225 | + | |
251 | 226 | | |
252 | 227 | | |
253 | 228 | | |
| |||
307 | 282 | | |
308 | 283 | | |
309 | 284 | | |
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 | 285 | | |
337 | 286 | | |
338 | 287 | | |
| |||
363 | 312 | | |
364 | 313 | | |
365 | 314 | | |
366 | | - | |
367 | 315 | | |
368 | 316 | | |
369 | 317 | | |
| |||
404 | 352 | | |
405 | 353 | | |
406 | 354 | | |
407 | | - | |
408 | 355 | | |
409 | 356 | | |
410 | 357 | | |
411 | 358 | | |
412 | | - | |
413 | | - | |
414 | | - | |
415 | | - | |
416 | | - | |
417 | 359 | | |
| 360 | + | |
418 | 361 | | |
419 | | - | |
420 | | - | |
421 | | - | |
| 362 | + | |
| 363 | + | |
422 | 364 | | |
423 | 365 | | |
424 | 366 | | |
425 | 367 | | |
426 | 368 | | |
427 | | - | |
428 | | - | |
| 369 | + | |
429 | 370 | | |
430 | 371 | | |
431 | 372 | | |
| |||
652 | 593 | | |
653 | 594 | | |
654 | 595 | | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
655 | 604 | | |
656 | 605 | | |
657 | 606 | | |
| |||
692 | 641 | | |
693 | 642 | | |
694 | 643 | | |
695 | | - | |
696 | | - | |
697 | | - | |
698 | | - | |
699 | | - | |
700 | | - | |
701 | | - | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
702 | 696 | | |
703 | 697 | | |
704 | 698 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
15 | 32 | | |
16 | 33 | | |
17 | 34 | | |
| |||
319 | 336 | | |
320 | 337 | | |
321 | 338 | | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
322 | 342 | | |
323 | 343 | | |
324 | 344 | | |
| |||
329 | 349 | | |
330 | 350 | | |
331 | 351 | | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
332 | 364 | | |
333 | 365 | | |
334 | 366 | | |
| |||
376 | 408 | | |
377 | 409 | | |
378 | 410 | | |
| 411 | + | |
379 | 412 | | |
380 | 413 | | |
| 414 | + | |
381 | 415 | | |
382 | 416 | | |
383 | 417 | | |
| |||
397 | 431 | | |
398 | 432 | | |
399 | 433 | | |
400 | | - | |
401 | | - | |
402 | | - | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
403 | 437 | | |
404 | 438 | | |
405 | 439 | | |
406 | 440 | | |
407 | 441 | | |
408 | 442 | | |
409 | 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 | + | |
410 | 491 | | |
411 | 492 | | |
412 | 493 | | |
413 | 494 | | |
414 | 495 | | |
415 | 496 | | |
416 | 497 | | |
417 | | - | |
418 | | - | |
419 | | - | |
| 498 | + | |
| 499 | + | |
| 500 | + | |
420 | 501 | | |
421 | 502 | | |
422 | 503 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
| 36 | + | |
| 37 | + | |
36 | 38 | | |
37 | 39 | | |
38 | 40 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
| 28 | + | |
| 29 | + | |
28 | 30 | | |
29 | 31 | | |
30 | 32 | | |
| |||
0 commit comments