1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
|
To: vim_dev@googlegroups.com
Subject: Patch 7.3.489
Fcc: outbox
From: Bram Moolenaar <Bram@moolenaar.net>
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
------------
Patch 7.3.489
Problem: CTRL-] in Insert mode does not expand abbreviation when used in a
mapping. (Yichao Zhou)
Solution: Special case using CTRL-]. (Christian Brabandt)
Files: src/getchar.c, src/edit.c
*** ../vim-7.3.488/src/getchar.c 2012-02-05 22:05:44.000000000 +0100
--- src/getchar.c 2012-04-05 15:54:00.000000000 +0200
***************
*** 4352,4359 ****
if (typebuf.tb_no_abbr_cnt) /* abbrev. are not recursive */
return FALSE;
! if ((KeyNoremap & (RM_NONE|RM_SCRIPT)) != 0)
! /* no remapping implies no abbreviation */
return FALSE;
/*
--- 4352,4360 ----
if (typebuf.tb_no_abbr_cnt) /* abbrev. are not recursive */
return FALSE;
!
! /* no remapping implies no abbreviation, except for CTRL-] */
! if ((KeyNoremap & (RM_NONE|RM_SCRIPT)) != 0 && c != Ctrl_RSB)
return FALSE;
/*
*** ../vim-7.3.488/src/edit.c 2012-02-29 18:22:03.000000000 +0100
--- src/edit.c 2012-04-05 15:57:46.000000000 +0200
***************
*** 1455,1467 ****
Insstart_blank_vcol = get_nolist_virtcol();
}
! if (vim_iswordc(c) || !echeck_abbr(
#ifdef FEAT_MBYTE
/* Add ABBR_OFF for characters above 0x100, this is
* what check_abbr() expects. */
(has_mbyte && c >= 0x100) ? (c + ABBR_OFF) :
#endif
! c))
{
insert_special(c, FALSE, FALSE);
#ifdef FEAT_RIGHTLEFT
--- 1455,1470 ----
Insstart_blank_vcol = get_nolist_virtcol();
}
! /* Insert a normal character and check for abbreviations on a
! * special character. Let CTRL-] expand abbreviations without
! * inserting it. */
! if (vim_iswordc(c) || (!echeck_abbr(
#ifdef FEAT_MBYTE
/* Add ABBR_OFF for characters above 0x100, this is
* what check_abbr() expects. */
(has_mbyte && c >= 0x100) ? (c + ABBR_OFF) :
#endif
! c) && c != Ctrl_RSB))
{
insert_special(c, FALSE, FALSE);
#ifdef FEAT_RIGHTLEFT
*** ../vim-7.3.488/src/version.c 2012-04-05 16:04:58.000000000 +0200
--- src/version.c 2012-04-05 16:06:12.000000000 +0200
***************
*** 716,717 ****
--- 716,719 ----
{ /* Add new patch number below this line */
+ /**/
+ 489,
/**/
--
Just think of all the things we haven't thought of yet.
/// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\ an exciting new programming language -- http://www.Zimbu.org ///
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
|