]> granicus.if.org Git - vim/commitdiff
updated for version 7.2.389 v7.2.389
authorBram Moolenaar <Bram@vim.org>
Wed, 10 Mar 2010 12:43:49 +0000 (13:43 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 10 Mar 2010 12:43:49 +0000 (13:43 +0100)
Problem:    synIDattr() cannot return the font.
Solution:   Support the "font" argument. (Christian Brabandt)

runtime/doc/eval.txt
src/eval.c
src/syntax.c
src/version.c

index 6f5a8f725386e2a9a4fe0644a72b096871139543..e742bb14c16e649e064c0df26b2e8befd868e55c 100644 (file)
@@ -5388,6 +5388,8 @@ synIDattr({synID}, {what} [, {mode}])                     *synIDattr()*
                                the color, cterm: color number as a string,
                                term: empty string)
                "bg"            background color (as with "fg")
+               "font"          font name (only available in the GUI)
+                               |highlight-font|
                "sp"            special color (as with "fg") |highlight-guisp|
                "fg#"           like "fg", but for the GUI and the GUI is
                                running the name in "#RRGGBB" form
@@ -5397,6 +5399,7 @@ synIDattr({synID}, {what} [, {mode}])                     *synIDattr()*
                "italic"        "1" if italic
                "reverse"       "1" if reverse
                "inverse"       "1" if inverse (= reverse)
+               "standout"      "1" if standout
                "underline"     "1" if underlined
                "undercurl"     "1" if undercurled
 
index 87333c2bae2a04a58fe82bc07a77d502a26ed9e0..f9babb3fc5ec311d6de3ce6505af4ab50166a39f 100644 (file)
@@ -16627,7 +16627,7 @@ f_synIDattr(argvars, rettv)
                    p = highlight_has_attr(id, HL_BOLD, modec);
                break;
 
-       case 'f':                                       /* fg[#] */
+       case 'f':                                       /* fg[#] or font */
                p = highlight_color(id, what, modec);
                break;
 
index 8d976ea4056872080d2c260d88cc5bd59d5cc9cb..3f502b70df870e197be92eb66f9be0fd6fa1a684 100644 (file)
@@ -8326,7 +8326,7 @@ highlight_has_attr(id, flag, modec)
     char_u *
 highlight_color(id, what, modec)
     int                id;
-    char_u     *what;  /* "fg", "bg", "sp", "fg#", "bg#" or "sp#" */
+    char_u     *what;  /* "font", "fg", "bg", "sp", "fg#", "bg#" or "sp#" */
     int                modec;  /* 'g' for GUI, 'c' for cterm, 't' for term */
 {
     static char_u      name[20];
@@ -8334,20 +8334,30 @@ highlight_color(id, what, modec)
     int                        fg = FALSE;
 # ifdef FEAT_GUI
     int                        sp = FALSE;
+    int                        font = FALSE;
 # endif
 
     if (id <= 0 || id > highlight_ga.ga_len)
        return NULL;
 
-    if (TOLOWER_ASC(what[0]) == 'f')
+    if (TOLOWER_ASC(what[0]) == 'f' && TOLOWER_ASC(what[1]) == 'g')
        fg = TRUE;
 # ifdef FEAT_GUI
-    else if (TOLOWER_ASC(what[0]) == 's')
+    else if (TOLOWER_ASC(what[0]) == 'f' && TOLOWER_ASC(what[1]) == 'o'
+             && TOLOWER_ASC(what[2]) == 'n' && TOLOWER_ASC(what[3]) == 't')
+       font = TRUE;
+    else if (TOLOWER_ASC(what[0]) == 's' && TOLOWER_ASC(what[1]) == 'p')
        sp = TRUE;
+    else if (!(TOLOWER_ASC(what[0]) == 'b' && TOLOWER_ASC(what[1]) == 'g'))
+       return NULL;
     if (modec == 'g')
     {
+       /* return font name */
+       if (font)
+           return HL_TABLE()[id - 1].sg_font_name;
+
        /* return #RRGGBB form (only possible when GUI is running) */
-       if (gui.in_use && what[1] && what[2] == '#')
+       if (gui.in_use && what[2] == '#')
        {
            guicolor_T          color;
            long_u              rgb;
@@ -8374,6 +8384,8 @@ highlight_color(id, what, modec)
            return (HL_TABLE()[id - 1].sg_gui_sp_name);
        return (HL_TABLE()[id - 1].sg_gui_bg_name);
     }
+    if (font || sp)
+       return NULL;
 # endif
     if (modec == 'c')
     {
index c9adec1f2ac67ad3615043c849257b915ba01e10..109532e7c9c8630dc469792932eec86182bb0622 100644 (file)
@@ -681,6 +681,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    389,
 /**/
     388,
 /**/