]> granicus.if.org Git - vim/commitdiff
patch 7.4.1642 v7.4.1642
authorBram Moolenaar <Bram@vim.org>
Thu, 24 Mar 2016 17:24:58 +0000 (18:24 +0100)
committerBram Moolenaar <Bram@vim.org>
Thu, 24 Mar 2016 17:24:58 +0000 (18:24 +0100)
Problem:    Handling emoji characters as full width has problems with
            backwards compatibility.
Solution:   Only put characters in the 1f000 range in the emoji table.

runtime/tools/unicode.vim
src/mbyte.c
src/version.c

index e0627b644d1a81bf18ed90bde70d4fdc9fea784d..88c4c796098dd24356acd034665bebe947f2a1a0 100644 (file)
@@ -283,6 +283,12 @@ func! BuildEmojiTable(pattern, tableName)
       call add(alltokens, token)
     endif
 
+    " Characters below 1F000 may be considered single width traditionally,
+    " making them double width causes problems.
+    if first < 0x1f000
+      continue
+    endif
+
     " exclude characters that are in the "ambiguous" or "doublewidth" table
     for ambi in s:ambitable
       if first >= ambi[0] && first <= ambi[1]
index 811f80d9e2df06358edd3828946dc6d3b1974c34..f38e63e770f2cdceb0921e1ecddd18f5845a9b4e 100644 (file)
@@ -1445,64 +1445,6 @@ utf_char2cells(int c)
      * based on http://unicode.org/emoji/charts/emoji-list.html */
     static struct interval emoji_width[] =
     {
-       {0x203c, 0x203c},
-       {0x2049, 0x2049},
-       {0x2139, 0x2139},
-       {0x21a9, 0x21aa},
-       {0x231a, 0x231b},
-       {0x2328, 0x2328},
-       {0x23cf, 0x23cf},
-       {0x23e9, 0x23f3},
-       {0x25aa, 0x25ab},
-       {0x25fb, 0x25fe},
-       {0x2600, 0x2604},
-       {0x2611, 0x2611},
-       {0x2618, 0x2618},
-       {0x261d, 0x261d},
-       {0x2620, 0x2620},
-       {0x2622, 0x2623},
-       {0x2626, 0x2626},
-       {0x262a, 0x262a},
-       {0x262e, 0x262f},
-       {0x2638, 0x263a},
-       {0x2648, 0x2653},
-       {0x2666, 0x2666},
-       {0x267b, 0x267b},
-       {0x267f, 0x267f},
-       {0x2692, 0x2694},
-       {0x2696, 0x2697},
-       {0x2699, 0x2699},
-       {0x269b, 0x269c},
-       {0x26a0, 0x26a1},
-       {0x26aa, 0x26ab},
-       {0x26b0, 0x26b1},
-       {0x26bd, 0x26bd},
-       {0x26ce, 0x26ce},
-       {0x2702, 0x2702},
-       {0x2705, 0x2705},
-       {0x2708, 0x270d},
-       {0x270f, 0x270f},
-       {0x2712, 0x2712},
-       {0x2714, 0x2714},
-       {0x2716, 0x2716},
-       {0x271d, 0x271d},
-       {0x2721, 0x2721},
-       {0x2728, 0x2728},
-       {0x2733, 0x2734},
-       {0x2744, 0x2744},
-       {0x2747, 0x2747},
-       {0x274c, 0x274c},
-       {0x274e, 0x274e},
-       {0x2753, 0x2755},
-       {0x2763, 0x2764},
-       {0x2795, 0x2797},
-       {0x27a1, 0x27a1},
-       {0x27b0, 0x27b0},
-       {0x27bf, 0x27bf},
-       {0x2934, 0x2935},
-       {0x2b05, 0x2b07},
-       {0x2b1b, 0x2b1c},
-       {0x2b50, 0x2b50},
        {0x1f004, 0x1f004},
        {0x1f0cf, 0x1f0cf},
        {0x1f1e6, 0x1f1ff},
index 465794a0aa69535a0865475fe8588595977a0b85..15b6d0dea75042209856c6b9539a94a1f3ea6005 100644 (file)
@@ -748,6 +748,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1642,
 /**/
     1641,
 /**/