data:image/s3,"s3://crabby-images/c4fc3/c4fc3d5b00bc36e95ac50db29df85ba59ac0bf7c" alt="Notepad++ linux fedora"
data:image/s3,"s3://crabby-images/c6397/c6397348ef26c8d58de44af71583953e0e2a0751" alt="notepad++ linux fedora notepad++ linux fedora"
Which basically loads a the whole file into an immutable buffer and then uses the PieceTree to manage the edits. Monaco - The editor in VS Code recently went from a linked-list of strings to a PieceTree buffer.
data:image/s3,"s3://crabby-images/79054/79054fcd099d48bf863d2c233e102bbab4a0ca8f" alt="notepad++ linux fedora notepad++ linux fedora"
It doesn't suffer though as much from heap fragmentation though as the linked-list of strings type approach. it will be sluggish, but if you do, like %!jq '.' and format it, you can them move around the file a little easier.Įmacs - Historically used a Gap-Buffer which optimized more for locality of edits than loading large files. Vim's implementation also feels somewhat line-oriented in that if you load a large JSON file that has everything on 1 line and you try to edit that line, uh. It's vaguely reminiscent of Vim's implementation, in the sense that I think, for large files, in it's default config, Vim keeps most of the text in it's swap file and pages it in as needed.
data:image/s3,"s3://crabby-images/c4fc3/c4fc3d5b00bc36e95ac50db29df85ba59ac0bf7c" alt="Notepad++ linux fedora"