summaryrefslogtreecommitdiff
path: root/Cargo.lock
diff options
context:
space:
mode:
authorChristian Duerr <chrisduerr@users.noreply.github.com>2018-09-24 18:40:09 +0000
committerGitHub <noreply@github.com>2018-09-24 18:40:09 +0000
commit3d7e88e8a975f40996aaa71d951842db6f2fccbb (patch)
treec49ee457634a613bf84917fb0a8b89db18a9aa33 /Cargo.lock
parenta752066bfa281f236b8d171cbc8f6e5a5a940297 (diff)
downloadalacritty-3d7e88e8a975f40996aaa71d951842db6f2fccbb.tar.gz
alacritty-3d7e88e8a975f40996aaa71d951842db6f2fccbb.zip
Dynamically initialize grid storage
Previously Alacritty has initialized all lines in the buffer as soon as it is started. This had the effect that terminals which aren't making use of the scrollback buffer yet, would still consume large amounts of memory, potentially even freezing the system at startup. To resolve this problem, the grid is now dynamically resized in chunks of `1000` rows. The initial size is just the visible area itself, then every time lines are written to the terminal emulator, the grid storage is grown when required. With the worst-case scenario of having 100_000 lines scrollback configured, this change improves startup performance at the cost of scrolling performance. On my machine the startup changes from ~0.3 to ~0.2 seconds. The scrolling performance with large throughput is not affected, however it is slowed down when the number of lines scrolled are close to the 100_000 configured as scrollback. The most taxing benchmark I've found for this was running `yes | dd count=500 > 500.txt` (note the relatively small file size). This will cause a slowdown on the first run from 0.05s to 0.15s. While this is significant, it lines up with the time saved at startup. This fixes #1236.
Diffstat (limited to 'Cargo.lock')
0 files changed, 0 insertions, 0 deletions