1
0
mirror of https://github.com/m00natic/vlfi.git synced 2025-01-18 20:10:47 +00:00
vlfi/README.org

103 lines
3.2 KiB
Org Mode
Raw Normal View History

* View Large Files
2013-12-03 02:54:33 +02:00
Emacs minor mode that allows viewing, editing and searching large
files in batches. Batch size can be adjusted on the fly and bounds
the memory that is to be used for operations on the file.
2013-02-02 16:12:30 +02:00
This is development version of the GNU ELPA [[http://elpa.gnu.org/packages/vlf][vlf.el]] package. Here's
what it does in a nutshell:
2013-04-14 19:55:39 +03:00
2013-04-13 23:10:47 +03:00
- regular expression search on whole file (in constant memory
determined by current batch size)
- chunk editing (if size has changed, saving is done in constant
memory determined by current batch size)
2013-04-16 15:56:10 +03:00
- occur like indexing
2013-04-13 23:10:47 +03:00
- options to jump to beginning, end or arbitrary file chunk
2013-02-02 16:12:30 +02:00
- ability to jump/insert given number of batches at once
2013-04-13 23:10:47 +03:00
- newly added content is acknowledged if file has changed size
meanwhile
2013-04-14 19:55:39 +03:00
- automatic scrolling of batches
2013-08-25 17:57:43 +03:00
- VLF is added as an option when opening large files
2013-04-17 12:33:04 +03:00
GNU Emacs 23 and 24 are supported.
* Overview and tips
2013-08-25 17:57:43 +03:00
M-x vlf PATH-TO-FILE
2013-04-17 12:33:04 +03:00
** Unicode
2013-04-17 12:33:04 +03:00
Emacs' Unicode support is leveraged so you'll not see bare bytes but
characters decoded as if file is normally opened. This holds for
2013-04-17 12:33:04 +03:00
editing, search and indexing.
2013-05-02 14:25:39 +03:00
** 32-bit GNU Emacs
2013-05-01 02:02:28 +03:00
Regular Emacs integers are used, so if you use 32-bit Emacs without
bignum support and have really huge file (with size beyond the maximum
2013-08-25 17:57:43 +03:00
integer value), VLF will probably not quite work.
** Memory control
2013-04-17 12:33:04 +03:00
2013-08-25 17:57:43 +03:00
*vlf-batch-size* bounds the memory used for all operations.
2013-04-17 12:33:04 +03:00
* Detail usage
** Control batch size
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
*C-c C-v +* and *C-c C-v -* control current batch size by factors
of 2.
2013-04-17 12:33:04 +03:00
2013-08-25 17:57:43 +03:00
You can also set by hand local variable *vlf-batch-size* and then
2013-12-03 02:54:33 +02:00
refresh with *C-c C-v g*.
2013-04-17 12:33:04 +03:00
2013-04-17 13:19:37 +03:00
** Move around
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
*C-c C-v PgUp* and *C-c C-v PgDn* move batch by batch. With positive
prefix argument they move prefix number of batches. With negative -
append prefix number of batches.
2013-04-17 12:33:04 +03:00
*C-c C-v n* displays batch starting from current point.
2013-12-03 02:54:33 +02:00
*C-c C-v [* and *C-c C-v ]* take you to the beginning and end of file
respectively.
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
*C-c C-v j* jumps to given chunk. To see where you are in file and
how many chunks there are (using the current batch size), look at the
parenthesized part of the buffer name, batch size is also indicated at
the end.
2013-04-17 12:33:04 +03:00
2013-04-17 13:19:37 +03:00
** Search whole file
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
*C-c C-v s* and *C-c C-v r* search forward and backward respectively
over the whole file. This is done batch by batch so if you have
really huge file - you'd better set somewhat bigger batch size
beforehand.
2013-04-17 12:33:04 +03:00
2013-05-01 02:02:28 +03:00
** Occur over whole file
*C-c C-v o* builds index for given regular expression just like
*M-x occur*. It does this batch by batch over the whole file. Note
that even if you prematurely stop it with *C-g*, it will still show
index of what's found so far.
2013-05-01 02:02:28 +03:00
2013-05-02 14:25:39 +03:00
** Jump to line
2013-12-03 02:54:33 +02:00
*C-c C-v l* jumps to given line in file. This is done by searching
from the beginning, so again the bigger current batch size, the
quicker. With negative argument, lines are counted from the end of
file.
2013-05-02 14:25:39 +03:00
** Reload
*C-c C-v g* discards modifications (if such) and reloads chunk.
2013-12-03 02:54:33 +02:00
** Edit and save
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
If editing doesn't change size of the chunk, only this chunk is saved.
Otherwise the remaining part of the file is adjusted batch by batch,
so again you'd better have bigger current batch size.
2013-04-17 12:33:04 +03:00
2013-12-03 02:54:33 +02:00
*Warning* Saving changes to non-ASCII chunks is a bit risky right
now.