From 5b962cf71c87f5d23408bac83c8a526b901daa3f Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Mon, 12 Dec 2005 21:58:40 +0000 Subject: [PATCH] updated for version 7.0168 --- runtime/doc/index.txt | 3 +- runtime/doc/insert.txt | 10 +- runtime/doc/map.txt | 221 +++++++++++++++++++++++++++------------ runtime/doc/quickref.txt | 3 +- src/feature.h | 2 +- src/fileio.c | 6 +- src/normal.c | 43 ++++++++ src/os_unix.c | 17 ++- src/spell.c | 5 +- src/vim.h | 1 + src/window.c | 4 +- 11 files changed, 229 insertions(+), 86 deletions(-) diff --git a/runtime/doc/index.txt b/runtime/doc/index.txt index 38f2612357..bbd178d242 100644 --- a/runtime/doc/index.txt +++ b/runtime/doc/index.txt @@ -1,4 +1,4 @@ -*index.txt* For Vim version 7.0aa. Last change: 2005 Dec 11 +*index.txt* For Vim version 7.0aa. Last change: 2005 Dec 12 VIM REFERENCE MANUAL by Bram Moolenaar @@ -736,6 +736,7 @@ tag char note action in Normal mode ~ |gu| gu{motion} 2 make Nmove text lowercase |gv| gv reselect the previous Visual area |gw| gw{motion} 2 format Nmove text and keep cursor +|g@| g@{motion} call 'operatorfunc' |g~| g~{motion} 2 swap case for Nmove text |g| g 1 same as "gj" |g| g 1 same as "g$" diff --git a/runtime/doc/insert.txt b/runtime/doc/insert.txt index 9d8e4e609a..a62771d4cf 100644 --- a/runtime/doc/insert.txt +++ b/runtime/doc/insert.txt @@ -1,4 +1,4 @@ -*insert.txt* For Vim version 7.0aa. Last change: 2005 Nov 22 +*insert.txt* For Vim version 7.0aa. Last change: 2005 Dec 12 VIM REFERENCE MANUAL by Bram Moolenaar @@ -1040,9 +1040,9 @@ Note: When used first time completion menu will be shown with little delay XML *ft-xml-omni* -Vim 7 provides mechanism to context aware completion of XML files. It depends -on special |xml-data-file| and two commands: |:XMLns| and |:XMLent|. Features -are: +Vim 7 provides mechanism to context aware completion of XML files. It depends +on special |xml-omni-datafile| and two commands: |:XMLns| and |:XMLent|. +Features are: - after "<" complete tag name depending on context (no div suggest inside of an a tag) @@ -1050,7 +1050,7 @@ are: a tag) - when attribute has limited number of possible values help to complete them -- complete names of entities (defined in |xml-data-file| and in current file +- complete names of entities (defined in |xml-omni-datafile| and in current file with " This appends the current date and time after the cursor (in <> notation |<>|). + +1.1 MAP COMMANDS *:map-commands* + There are commands to enter new mappings, remove mappings and list mappings. See |map-overview| for the various forms of "map" and their relationships with modes. @@ -116,6 +130,21 @@ characters. You can use this to put command sequences under function keys, translate one key into another, etc. See |:mkexrc| for how to save and restore the current mappings. + *map-ambiguous* +When two mappings start with the same sequence of characters, they are +ambiguous. Example: > + :imap aa foo + :imap aaa bar +When Vim has read "aa", it will need to get another character to be able to +decide if "aa" or "aaa" should be mapped. This means that after typing "aa" +that mapping won't get expanded yet, Vim is waiting for another character. +If you type a space, then "foo" will get inserted, plus the space. If you +type "a", then "bar" will get inserted. +{Vi does not allow ambiguous mappings} + + +1.2 SPECIAL ARGUMENTS *:map-arguments* + *:map-local* *:map-* *E224* *E225* If the first argument to one of these commands is "" it will apply to mappings locally to the current buffer only. Example: > @@ -167,7 +196,7 @@ Example of what will fail: > They must appear right after the command, before any other arguments. -MAPPING AND MODES +1.3 MAPPING AND MODES *:map-modes* There are five sets of mappings - For Normal mode: When typing commands. @@ -236,19 +265,9 @@ character as an argument to command like "f" or "t". are only used for typed characters. This assumes that the language mapping was already done when typing the mapping. - *map-multibyte* -It is possible to map multibyte characters, but only the whole character. You -cannot map the first byte only. This was done to prevent problems in this -scenario: > - :set encoding=latin1 - :imap foo - :set encoding=utf-8 -The mapping for is defined with the latin1 encoding, resulting in a 0xc3 -byte. If you type the character á (0xea ) in UTF-8 encoding this is the -two bytes 0xc3 0xa1. You don't want the 0xc3 byte to be mapped then, -otherwise it would be impossible to type the á character. - *map-listing* +1.4 LISTING MAPPINGS *map-listing* + When listing mappings the characters in the first two columns are: CHAR MODE ~ @@ -283,6 +302,48 @@ last defined. Example: > See |:verbose-cmd| for more information. + +1.5 MAPPING SPECIAL KEYS *:map-special-keys* + +There are three ways to map a special key: +1. The Vi-compatible method: Map the key code. Often this is a sequence that + starts with . To enter a mapping like this you type ":map " and then + you have to type CTRL-V before hitting the function key. Note that when + the key code for the key is in the termcap (the t_ options), it will + automatically be translated into the internal code and become the second + way of mapping (unless the 'k' flag is included in 'cpoptions'). +2. The second method is to use the internal code for the function key. To + enter such a mapping type CTRL-K and then hit the function key, or use + the form "#1", "#2", .. "#9", "#0", "", "", "", etc. + (see table of keys |key-notation|, all keys from can be used). The + first ten function keys can be defined in two ways: Just the number, like + "#2", and with "", like "". Both stand for function key 2. "#0" + refers to function key 10, defined with option 't_f10', which may be + function key zero on some keyboards. The <> form cannot be used when + 'cpoptions' includes the '<' flag. +3. Use the termcap entry, with the form , where "xx" is the name of the + termcap entry. Any string entry can be used. For example: > + :map G +< Maps function key 13 to "G". This does not work if 'cpoptions' includes + the '<' flag. + +The advantage of the second and third method is that the mapping will work on +different terminals without modification (the function key will be +translated into the same internal code or the actual key code, no matter what +terminal you are using. The termcap must be correct for this to work, and you +must use the same mappings). + +DETAIL: Vim first checks if a sequence from the keyboard is mapped. If it +isn't the terminal key codes are tried (see |terminal-options|). If a +terminal code is found it is replaced with the internal code. Then the check +for a mapping is done again (so you can map an internal code to something +else). What is written into the script file depends on what is recognized. +If the terminal key code was recognized as a mapping the key code itself is +written to the script file. If it was recognized as a terminal code the +internal code is written to the script file. + + +1.6 SPECIAL CHARACTERS *:map-special-chars* *map_backslash* Note that only CTRL-V is mentioned here as a special character for mappings and abbreviations. When 'cpoptions' does not contain 'B', a backslash can @@ -294,18 +355,6 @@ To map a backslash, or use a backslash literally in the {rhs}, the special sequence "" can be used. This avoids the need to double backslashes when using nested mappings. - *map-ambiguous* -When two mappings start with the same sequence of characters, they are -ambiguous. Example: > - :imap aa foo - :imap aaa bar -When Vim has read "aa", it will need to get another character to be able to -decide if "aa" or "aaa" should be mapped. This means that after typing "aa" -that mapping won't get expanded yet, Vim is waiting for another character. -If you type a space, then "foo" will get inserted, plus the space. If you -type "a", then "bar" will get inserted. -{Vi does not allow ambiguous mappings} - *map_CTRL-C* Using CTRL-C in the {lhs} is possible, but it will only work when Vim is waiting for a key, not when Vim is busy with something. When Vim is busy @@ -331,6 +380,18 @@ example, to make sure that function key 8 does nothing at all: > :map :map! < + *map-multibyte* +It is possible to map multibyte characters, but only the whole character. You +cannot map the first byte only. This was done to prevent problems in this +scenario: > + :set encoding=latin1 + :imap foo + :set encoding=utf-8 +The mapping for is defined with the latin1 encoding, resulting in a 0xc3 +byte. If you type the character á (0xea ) in UTF-8 encoding this is the +two bytes 0xc3 0xa1. You don't want the 0xc3 byte to be mapped then, +otherwise it would be impossible to type the á character. + ** *mapleader* To define a mapping which uses the "mapleader" variable, the special string "" can be used. It is replaced with the string value of "mapleader". @@ -418,7 +479,9 @@ and CTRL-X is not mapped. This was done to be able to use all the named registers and marks, even when the command with the same name has been mapped. - *map-which-keys* + +1.7 WHAT KEYS TO MAP *map-which-keys* + If you are going to map something, you will need to choose which key(s) to use for the {lhs}. You will have to avoid keys that are used for Vim commands, otherwise you would not be able to use those commands anymore. Here are a few @@ -436,7 +499,9 @@ losing any builtin function. You can also use ":help {key}^D" to find out if a key is used for some command. ({key} is the specific key you want to find out about, ^D is CTRL-D). - *map-examples* + +1.8 EXAMPLES *map-examples* + A few examples (given as you type them, for "" you type four characters; the '<' flag must not be present in 'cpoptions' for this to work). > @@ -445,7 +510,9 @@ the '<' flag must not be present in 'cpoptions' for this to work). > :map _x d/END/e :map! qq quadrillion questions < - *map-typing* + +1.9 USING MAPPINGS *map-typing* + Vim will compare what you type with the start of a mapped sequence. If there is an incomplete match, it will get more characters until there either is a complete match or until there is no match at all. Example: If you map! "qq", @@ -521,46 +588,8 @@ the original Vi, as long as there is only one undo command in the mapped sequence (having two undo commands in a mapped sequence did not make sense in the original Vi, you would get back the text before the first undo). - *:map-special-keys* -There are three ways to map a special key: -1. The Vi-compatible method: Map the key code. Often this is a sequence that - starts with . To enter a mapping like this you type ":map " and then - you have to type CTRL-V before hitting the function key. Note that when - the key code for the key is in the termcap (the t_ options), it will - automatically be translated into the internal code and become the second - way of mapping (unless the 'k' flag is included in 'cpoptions'). -2. The second method is to use the internal code for the function key. To - enter such a mapping type CTRL-K and then hit the function key, or use - the form "#1", "#2", .. "#9", "#0", "", "", "", etc. - (see table of keys |key-notation|, all keys from can be used). The - first ten function keys can be defined in two ways: Just the number, like - "#2", and with "", like "". Both stand for function key 2. "#0" - refers to function key 10, defined with option 't_f10', which may be - function key zero on some keyboards. The <> form cannot be used when - 'cpoptions' includes the '<' flag. -3. Use the termcap entry, with the form , where "xx" is the name of the - termcap entry. Any string entry can be used. For example: > - :map G -< Maps function key 13 to "G". This does not work if 'cpoptions' includes - the '<' flag. -The advantage of the second and third method is that the mapping will work on -different terminals without modification (the function key will be -translated into the same internal code or the actual key code, no matter what -terminal you are using. The termcap must be correct for this to work, and you -must use the same mappings). - -DETAIL: Vim first checks if a sequence from the keyboard is mapped. If it -isn't the terminal key codes are tried (see |terminal-options|). If a -terminal code is found it is replaced with the internal code. Then the check -for a mapping is done again (so you can map an internal code to something -else). What is written into the script file depends on what is recognized. -If the terminal key code was recognized as a mapping the key code itself is -written to the script file. If it was recognized as a terminal code the -internal code is written to the script file. - - -Mapping ALT-keys *:map-alt-keys* +1.10 MAPPING ALT-KEYS *:map-alt-keys* In the GUI Vim handles the Alt key itself, thus mapping keys with ALT should always work. But in a terminal Vim gets a sequence of bytes and has to figure @@ -601,6 +630,62 @@ toggled on the fly through the "Main Options" menu, by pressing Ctrl-LeftClick on the terminal; that's a good last resource in case you want to send ESC when using other applications but not when inside VIM. + +1.11 MAPPING AN OPERATOR *:map-operator* + +An operator is used before a {motion} command. To define your own operator +you must create mapping that first sets the 'operatorfunc' option and then +invoke the |g@| operator. After the user types the {motion} command the +specified function will be called. + + *g@* +g@{motion} Call the function set by the 'operatorfunc' option. + The '[ mark is positioned at the start of the text + moved over by {motion}, the '] mark on the last + character of the text. + The function is called with one String argument: + "line" {motion} was |linewise| + "char" {motion} was |characterwise| + "block" {motion} was |blockwise-visual|| + Although "block" would rarely appear, since it can + only result from Visual mode where "g@" is not useful. + {not available when compiled without the +eval + feature} + +Here is an example that counts the number of spaces with : > + + nmap :set opfunc=CountSpacesg@ + vmap :call CountSpaces(visualmode(), 1) + + function! CountSpaces(type, ...) + let sel_save = &selection + let &selection = "inclusive" + let reg_save = @@ + + if a:0 " Invoked from Visual mode, use '< and '> marks. + silent exe "normal! `<" . a:type . "`>y" + elseif a:type == 'line' + silent exe "normal! '[V']y" + elseif a:type == 'block' + silent exe "normal! `[\`]y" + else + silent exe "normal! `[v`]y" + endif + + echomsg strlen(substitute(@@, '[^ ]', '', 'g')) + + let &selection = sel_save + let @@ = reg_save + endfunction + +Note that the 'selection' option is temporarily set to "inclusive" to be able +to yank exactly the right text by using Visual mode from the '[ to the '] +mark. + +Also note that there is a separate mapping for Visual mode. It removes the +"'<,'>" range that ":" inserts in Visual mode and invokes the function with +visualmode() and an extra argument. + ============================================================================== 2. Abbreviations *abbreviations* *Abbreviations* diff --git a/runtime/doc/quickref.txt b/runtime/doc/quickref.txt index 9f4f7e65b5..687e5cff5c 100644 --- a/runtime/doc/quickref.txt +++ b/runtime/doc/quickref.txt @@ -1,4 +1,4 @@ -*quickref.txt* For Vim version 7.0aa. Last change: 2005 Nov 25 +*quickref.txt* For Vim version 7.0aa. Last change: 2005 Dec 12 VIM REFERENCE MANUAL by Bram Moolenaar @@ -774,6 +774,7 @@ Short explanation of each option: *option-list* |'number'| |'nu'| print the line number in front of each line |'numberwidth'| |'nuw'| number of columns used for the line number |'omnifunc'| |'ofu'| function for filetype-specific completion +|'operatorfunc'| |'opfunc'| funtion to be called for |g@| operator |'osfiletype'| |'oft'| operating system-specific filetype information |'paragraphs'| |'para'| nroff macros that separate paragraphs |'paste'| allow pasting text diff --git a/src/feature.h b/src/feature.h index 6abc0ed357..69a784e442 100644 --- a/src/feature.h +++ b/src/feature.h @@ -972,7 +972,7 @@ * +mouse Any mouse support (any of the above enabled). */ /* OS/2 and Amiga console have no mouse support */ -#if (!defined(AMIGA) && !defined(OS2) && !defined(MACOS)) +#if !defined(AMIGA) && !defined(OS2) # ifdef FEAT_NORMAL # define FEAT_MOUSE_XTERM # endif diff --git a/src/fileio.c b/src/fileio.c index a573a5b6fc..4c415ab442 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -556,7 +556,11 @@ readfile(fname, sfname, from, lines_to_skip, lines_to_read, eap, flags) if (!bt_dontwrite(curbuf)) #endif check_need_swap(newfile); - filemess(curbuf, sfname, (char_u *)_("[New File]"), 0); + if (dir_of_file_exists(fname)) + filemess(curbuf, sfname, (char_u *)_("[New File]"), 0); + else + filemess(curbuf, sfname, + (char_u *)_("[New DIRECTORY]"), 0); #ifdef FEAT_VIMINFO /* Even though this is a new file, it might have been * edited before and deleted. Get the old marks. */ diff --git a/src/normal.c b/src/normal.c index 71eefc4942..346cc8b5e0 100644 --- a/src/normal.c +++ b/src/normal.c @@ -32,6 +32,7 @@ _RTLENTRYF nv_compare __ARGS((const void *s1, const void *s2)); static int find_command __ARGS((int cmdchar)); static void op_colon __ARGS((oparg_T *oap)); +static void op_function __ARGS((oparg_T *oap)); #if defined(FEAT_MOUSE) && defined(FEAT_VISUAL) static void find_start_of_word __ARGS((pos_T *)); static void find_end_of_word __ARGS((pos_T *)); @@ -1696,6 +1697,7 @@ do_pending_operator(cap, old_col, gui_yank) } redo_VIsual_busy = FALSE; + /* * Switch Visual off now, so screen updating does * not show inverted text when the screen is redrawn. @@ -1718,6 +1720,7 @@ do_pending_operator(cap, old_col, gui_yank) #endif if ((oap->op_type == OP_YANK || oap->op_type == OP_COLON + || oap->op_type == OP_FUNCTION || oap->op_type == OP_FILTER) && oap->motion_force == NUL) redraw_curbuf_later(INVERTED); @@ -1940,6 +1943,10 @@ do_pending_operator(cap, old_col, gui_yank) op_format(oap, TRUE); /* use internal function */ break; + case OP_FUNCTION: + op_function(oap); /* call 'operatorfunc' */ + break; + case OP_INSERT: case OP_APPEND: #ifdef FEAT_VISUAL @@ -2100,6 +2107,40 @@ op_colon(oap) */ } +/* + * Handle the "gy" operator: call 'operatorfunc'. + */ + void +op_function(oap) + oparg_T *oap; +{ +#ifdef FEAT_EVAL + char_u *(argv[1]); + + if (*p_opfunc == NUL) + EMSG(_("E774: 'operatorfunc' is empty")); + else + { + /* Set '[ and '] marks to text to be operated on. */ + curbuf->b_op_start = oap->start; + curbuf->b_op_end = oap->end; + if (oap->motion_type != MLINE && !oap->inclusive) + /* Exclude the end position. */ + decl(&curbuf->b_op_end); + + if (oap->block_mode) + argv[0] = (char_u *)"block"; + else if (oap->motion_type == MLINE) + argv[0] = (char_u *)"line"; + else + argv[0] = (char_u *)"char"; + (void)call_func_retnr(p_opfunc, 1, argv, FALSE); + } +#else + EMSG(_("E775: Eval feature not available")); +#endif +} + #if defined(FEAT_MOUSE) || defined(PROTO) /* * Do the appropriate action for the current mouse click in the current mode. @@ -7660,6 +7701,7 @@ nv_g_cmd(cap) * "gu" Change text to lower case. * "gU" Change text to upper case. * "g?" rot13 encoding + * "gy" call 'operatorfunc' */ case 'q': case 'w': @@ -7669,6 +7711,7 @@ nv_g_cmd(cap) case 'u': case 'U': case '?': + case 'y': nv_operator(cap); break; diff --git a/src/os_unix.c b/src/os_unix.c index 4535aef477..89c420d994 100644 --- a/src/os_unix.c +++ b/src/os_unix.c @@ -3970,14 +3970,25 @@ mch_call_shell(cmd, options) { /* * Check if keys have been typed, write them to the child - * if there are any. Don't do this if we are expanding - * wild cards (would eat typeahead). Don't get extra - * characters when we already have one. + * if there are any. + * Don't do this if we are expanding wild cards (would eat + * typeahead). + * Don't do this when filtering and terminal is in cooked + * mode, the shell command will handle the I/O. Avoids + * that a typed password is echoed for ssh or gpg command. + * Don't get extra characters when we already have one. * Don't read characters unless we didn't get output for a * while, avoids that ":r !ls" eats typeahead. */ len = 0; if (!(options & SHELL_EXPAND) + && ((options & + (SHELL_READ|SHELL_WRITE|SHELL_COOKED)) + != (SHELL_READ|SHELL_WRITE|SHELL_COOKED) +#ifdef FEAT_GUI + || gui.in_use +#endif + ) && (ta_len > 0 || (noread_cnt > 4 && (len = ui_inchar(ta_buf, diff --git a/src/spell.c b/src/spell.c index c3f46986bc..303ed587e0 100644 --- a/src/spell.c +++ b/src/spell.c @@ -7703,7 +7703,6 @@ spell_add_word(word, len, bad, index) FILE *fd; buf_T *buf = NULL; int new_spf = FALSE; - struct stat st; char_u *fname; char_u fnamebuf[MAXPATHL]; char_u line[MAXWLEN * 2]; @@ -7797,9 +7796,7 @@ spell_add_word(word, len, bad, index) /* We just initialized the 'spellfile' option and can't open the file. * We may need to create the "spell" directory first. We already * checked the runtime directory is writable in init_spellfile(). */ - STRCPY(NameBuff, fname); - *gettail_sep(NameBuff) = NUL; - if (mch_stat((char *)NameBuff, &st) < 0) + if (!dir_of_file_exists(fname)) { /* The directory doesn't exist. Try creating it and opening the * file again. */ diff --git a/src/vim.h b/src/vim.h index ec69431e00..273d10f08e 100644 --- a/src/vim.h +++ b/src/vim.h @@ -1201,6 +1201,7 @@ typedef enum #define OP_FOLDDEL 24 /* "zd" delete folds */ #define OP_FOLDDELREC 25 /* "zD" delete folds recursively */ #define OP_FORMAT2 26 /* "gw" format operator, keeps cursor pos */ +#define OP_FUNCTION 27 /* "gy" call 'operatorfunc' */ /* * Motion types, used for operators and for yank/delete registers. diff --git a/src/window.c b/src/window.c index 85bc22adfc..7d50180478 100644 --- a/src/window.c +++ b/src/window.c @@ -4765,7 +4765,7 @@ vim_isAbsName(name) } /* - * Get absolute file name into buffer 'buf' of length 'len' bytes. + * Get absolute file name into buffer "buf[len]". * * return FAIL for failure, OK otherwise */ @@ -4773,7 +4773,7 @@ vim_isAbsName(name) vim_FullName(fname, buf, len, force) char_u *fname, *buf; int len; - int force; + int force; /* force expansion even when already absolute */ { int retval = OK; int url;