diff options
author | Felipe Oliveira Carvalho <felipekde@gmail.com> | 2016-03-09 19:34:28 -0300 |
---|---|---|
committer | Felipe Oliveira Carvalho <felipekde@gmail.com> | 2017-04-11 00:33:09 +0200 |
commit | 9ea111d1af6abcac361eece478fb7709e5264b82 (patch) | |
tree | 503cd8775e8f53a5ee5827258a1ad5e88c0c01d3 /runtime | |
parent | b99cac277812d337e8a5f1bc6a182e62f1e8c448 (diff) | |
download | rneovim-9ea111d1af6abcac361eece478fb7709e5264b82.tar.gz rneovim-9ea111d1af6abcac361eece478fb7709e5264b82.tar.bz2 rneovim-9ea111d1af6abcac361eece478fb7709e5264b82.zip |
Remove maxmem and maxmemtot options
> The option 'maxmem' ('mm') is used to set the maximum memory used for one
> buffer (in kilobytes). 'maxmemtot' is used to set the maximum memory used for
> all buffers (in kilobytes). The defaults depend on the system used. These
> are not hard limits, but tell Vim when to move text into a swap file. If you
> don't like Vim to swap to a file, set 'maxmem' and 'maxmemtot' to a very large
> value. The swap file will then only be used for recovery. If you don't want
> a swap file at all, set 'updatecount' to 0, or use the "-n" argument when
> starting Vim.
On today's systems these values are huge (4GB in my machine with 8GB of RAM
since it's set as half the available memory by default) so the limits are
never reached in practice, but Vim wastes a lot of time checking if the limit
was reached.
If the limit is reached Vim starts saving pieces of the swap file that were in
memory to the disk. Said in a different way: Vim implements its own memory
swapping mechanism. This is unnecessary and inefficient since the operating
system already virtualized the memory and will swap to the disk if programs
start using too much memory.
This change does...
1. Reduce the number of config options and need for documentation.
2. Make the code more efficient as we don't have to keep track of memory usage
nor check if the memory limits were reached to start swapping to disk every
time we need memory for buffers.
3. Simplify the code. Once `memfile.c` is simple enough it could be replaced by
actual operating system memory mapping (`mmap`, `MemoryViewOfFile`...).
This change does not prevent Vim to recover changes from swap files since the
swapping code is never triggered with the huge limits set by default.
Diffstat (limited to 'runtime')
-rw-r--r-- | runtime/doc/options.txt | 24 | ||||
-rw-r--r-- | runtime/doc/quickref.txt | 2 | ||||
-rw-r--r-- | runtime/doc/recover.txt | 6 | ||||
-rw-r--r-- | runtime/doc/usr_11.txt | 2 | ||||
-rw-r--r-- | runtime/doc/vi_diff.txt | 12 | ||||
-rw-r--r-- | runtime/optwin.vim | 4 |
6 files changed, 2 insertions, 48 deletions
diff --git a/runtime/doc/options.txt b/runtime/doc/options.txt index c30a88f48d..de0ae52ae0 100644 --- a/runtime/doc/options.txt +++ b/runtime/doc/options.txt @@ -4015,16 +4015,6 @@ A jump table for the options with a short description can be found at |Q_op|. because the 'w' is used before the next mapping is done. See also |key-mapping|. - *'maxmem'* *'mm'* -'maxmem' 'mm' number (default between 256 to 5120 (system - dependent) or half the amount of memory - available) - global - Maximum amount of memory (in Kbyte) to use for one buffer. When this - limit is reached allocating extra memory for a buffer will cause - other memory to be freed. The maximum usable value is about 2000000. - Use this to work without a limit. Also see 'maxmemtot'. - *'maxmempattern'* *'mmp'* 'maxmempattern' 'mmp' number (default 1000) global @@ -4038,20 +4028,6 @@ A jump table for the options with a short description can be found at |Q_op|. "\(.\)*" on a very long line. ".*" works much better. Vim may run out of memory before hitting the 'maxmempattern' limit. - *'maxmemtot'* *'mmt'* -'maxmemtot' 'mmt' number (default between 2048 and 10240 (system - dependent) or half the amount of memory - available) - global - Maximum amount of memory in Kbyte to use for all buffers together. - The maximum usable value is about 2000000 (2 Gbyte). Use this to work - without a limit. - On 64 bit machines higher values might work. But hey, do you really - need more than 2 Gbyte for text editing? Keep in mind that text is - stored in the swap file, one can edit files > 2 Gbyte anyway. We do - need the memory to store undo info. - Also see 'maxmem'. - *'menuitems'* *'mis'* 'menuitems' 'mis' number (default 25) global diff --git a/runtime/doc/quickref.txt b/runtime/doc/quickref.txt index a918a4d34a..aaf4d89c3d 100644 --- a/runtime/doc/quickref.txt +++ b/runtime/doc/quickref.txt @@ -770,9 +770,7 @@ Short explanation of each option: *option-list* 'maxcombine' 'mco' maximum nr of combining characters displayed 'maxfuncdepth' 'mfd' maximum recursive depth for user functions 'maxmapdepth' 'mmd' maximum recursive depth for mapping -'maxmem' 'mm' maximum memory (in Kbyte) used for one buffer 'maxmempattern' 'mmp' maximum memory (in Kbyte) used for pattern search -'maxmemtot' 'mmt' maximum memory (in Kbyte) used for all buffers 'menuitems' 'mis' maximum number of items in a menu 'mkspellmem' 'msm' memory used before |:mkspell| compresses the tree 'modeline' 'ml' recognize modelines at start or end of file diff --git a/runtime/doc/recover.txt b/runtime/doc/recover.txt index 8eded487c0..eba5f162de 100644 --- a/runtime/doc/recover.txt +++ b/runtime/doc/recover.txt @@ -64,10 +64,8 @@ following ones in your vimrc: This is also very handy when editing files on floppy. Of course you will have to create that "tmp" directory for this to work! -For read-only files, a swap file is not used. Unless the file is big, causing -the amount of memory used to be higher than given with 'maxmem' or -'maxmemtot'. And when making a change to a read-only file, the swap file is -created anyway. +For read-only files, a swap file is not used right away. The swap file is +created only when making changes. The 'swapfile' option can be reset to avoid creating a swapfile. And the |:noswapfile| modifier can be used to not create a swapfile for a new buffer. diff --git a/runtime/doc/usr_11.txt b/runtime/doc/usr_11.txt index 42009519df..42aa1d9100 100644 --- a/runtime/doc/usr_11.txt +++ b/runtime/doc/usr_11.txt @@ -294,8 +294,6 @@ If you really don't want to see this message, you can add the 'A' flag to the disk. 'updatetime' Timeout after which the swap file is flushed to disk. 'directory' List of directory names where to store the swap file. -'maxmem' Limit for memory usage before writing text to the swap file. -'maxmemtot' Same, but for all files in total. ============================================================================== diff --git a/runtime/doc/vi_diff.txt b/runtime/doc/vi_diff.txt index 1a108caeaf..9b8d64e8ca 100644 --- a/runtime/doc/vi_diff.txt +++ b/runtime/doc/vi_diff.txt @@ -39,18 +39,6 @@ Information for undo and text in registers is kept in memory, thus when making undo levels and the text that can be kept in registers. Other things are also kept in memory: Command-line history, error messages for Quickfix mode, etc. -Memory usage limits -------------------- - -The option 'maxmem' ('mm') is used to set the maximum memory used for one -buffer (in kilobytes). 'maxmemtot' is used to set the maximum memory used for -all buffers (in kilobytes). The defaults depend on the system used. -These are not hard limits, but tell Vim when to move text into a swap file. -If you don't like Vim to swap to a file, set 'maxmem' and 'maxmemtot' to a -very large value. The swap file will then only be used for recovery. If you -don't want a swap file at all, set 'updatecount' to 0, or use the "-n" -argument when starting Vim. - ============================================================================== 2. The most interesting additions *vim-additions* diff --git a/runtime/optwin.vim b/runtime/optwin.vim index 2053b2d860..2f9f9b7d21 100644 --- a/runtime/optwin.vim +++ b/runtime/optwin.vim @@ -988,10 +988,6 @@ call append("$", "updatecount\tnumber of characters typed to cause a swap file u call append("$", " \tset uc=" . &uc) call append("$", "updatetime\ttime in msec after which the swap file will be updated") call append("$", " \tset ut=" . &ut) -call append("$", "maxmem\tmaximum amount of memory in Kbyte used for one buffer") -call append("$", " \tset mm=" . &mm) -call append("$", "maxmemtot\tmaximum amount of memory in Kbyte used for all buffers") -call append("$", " \tset mmt=" . &mmt) call <SID>Header("command line editing") |