From 3a362b6da3bbfe8d84af588748c5ee664d70f41d Mon Sep 17 00:00:00 2001 From: Jan Steinke Date: Sat, 1 Jan 2022 21:28:50 +0100 Subject: [PATCH 01/12] Add support for neovim 0.6.0 diagnostic API highlight groups (#282) In Neovim `0.6.0` [1] the naming scheme for the highlight groups of the diagnostic API changed [2]. The new groups have been added as default while the previous groups are conditionally guarded when using Neovim `0.5.0`. [1]: https://github.com/neovim/neovim/releases/tag/v0.6.0 [2]: https://github.com/neovim/neovim/pull/15585/commits/a5bbb932f9094098bd656d3f6be3c58344576709#diff-51fab2b766d0a3b606462e95de492190df173b7296147912307cdad636cd492aR77 Co-authored-by: Arctic Ice Studio Co-authored-by: Sven Greb GH-282 --- colors/nord.vim | 28 ++++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index bfcfb064..b6d2c25f 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -216,6 +216,16 @@ if has('nvim') let g:terminal_color_15 = s:nord6_gui endif +"+- Neovim Diagnostics API -+ +call s:hi("DiagnosticWarn", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("DiagnosticError" , s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("DiagnosticInfo" , s:nord8_gui, "", s:nord8_term, "", "", "") +call s:hi("DiagnosticHint" , s:nord10_gui, "", s:nord10_term, "", "", "") +call s:hi("DiagnosticUnderlineWarn" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") +call s:hi("DiagnosticUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") +call s:hi("DiagnosticUnderlineInfo" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") +call s:hi("DiagnosticUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") + "+--- Gutter ---+ call s:hi("CursorColumn", "", s:nord1_gui, "NONE", s:nord1_term, "", "") if g:nord_cursor_line_number_background == 0 @@ -575,14 +585,16 @@ call s:hi("CocHintSign" , s:nord10_gui, "", s:nord10_term, "", "", "") " Neovim LSP " > neovim/nvim-lspconfig call s:hi("LspCodeLens", s:nord3_gui_bright, "", s:nord3_term, "", "", "") -call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") -call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") -call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") -call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") -call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") -call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") +if has("nvim-0.5") + call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") + call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") +endif " GitGutter " > airblade/vim-gitgutter From 2df7a984d6cae8c580ed52f2d9a7de8e34a580ea Mon Sep 17 00:00:00 2001 From: Charles Moscofian Date: Wed, 12 Jan 2022 19:00:15 -0300 Subject: [PATCH 02/12] Add support for LSP textDocument/documentHighlight (#284) Support for Neovim LSP `documentHighlight` groups The Neovim LSP `textDocument` / `documentHightlight` groups [1] are responsible to highlight tokens in a document that are related to each other, e.g. decalred variables, using the `vim.buf.lsp.document_highlight()` function. Also see the LSP specification about "Document Highlights Request" [2] for more details. [1]: https://github.com/neovim/neovim/blob/f92a2457c2e7ad14d9a5a907ef4213fa770b6d95/runtime/doc/lsp.txt#L423 [2]: https://microsoft.github.io/language-server-protocol/specification#textDocument_documentHighlight Co-authored-by: Arctic Ice Studio Co-authored-by: Sven Greb --- colors/nord.vim | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/colors/nord.vim b/colors/nord.vim index b6d2c25f..068dcb45 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -226,6 +226,11 @@ call s:hi("DiagnosticUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "und call s:hi("DiagnosticUnderlineInfo" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") call s:hi("DiagnosticUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") +"+- Neovim DocumentHighlight -+ +call s:hi("LspReferenceText", "", s:nord3_gui, "", s:nord3_term, "", "") +call s:hi("LspReferenceRead", "", s:nord3_gui, "", s:nord3_term, "", "") +call s:hi("LspReferenceWrite", "", s:nord3_gui, "", s:nord3_term, "", "") + "+--- Gutter ---+ call s:hi("CursorColumn", "", s:nord1_gui, "NONE", s:nord1_term, "", "") if g:nord_cursor_line_number_background == 0 From 5970582dc45475d7de343d69bfaf6124cc093051 Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Tue, 25 Jan 2022 22:50:44 +0100 Subject: [PATCH 03/12] Improve readability of C language constants (#283) Improve readability of C language constants To improve the readability of C language constants, defined by the `cConstant` syntax highlighting group [1], these are now colored with `nord9` for the foreground to make them stand out. This is important in C, since interesting things are usually happening in their proximity, like checking/returning an error, passing particular values/flags to functions and so on. [1]: https://github.com/vim/vim/blob/0e6adf8a29d5c2c96c42cc7157f71bf22c2ad471/runtime/syntax/c.vim#L313-L375 Co-authored-by: Arctic Ice Studio Co-authored-by: Sven Greb GH-283 --- colors/nord.vim | 1 + 1 file changed, 1 insertion(+) diff --git a/colors/nord.vim b/colors/nord.vim index 068dcb45..c28c4326 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -366,6 +366,7 @@ hi! link awkVariables Identifier call s:hi("cIncluded", s:nord7_gui, "", s:nord7_term, "", "", "") hi! link cOperator Operator hi! link cPreCondit PreCondit +hi! link cConstant Type call s:hi("cmakeGeneratorExpression", s:nord10_gui, "", s:nord10_term, "", "", "") From 3c2e4113d9e923101a913f1d456f54fc248a4ece Mon Sep 17 00:00:00 2001 From: Charles Moscofian Date: Sat, 19 Feb 2022 10:22:01 -0300 Subject: [PATCH 04/12] Add support for LSPSignatureHelpActiveParameter (#286) The `vim.lsp.buf.signature_help` function is used to highlight the active parameter in the signature help [1]. Before this commit the active parameter was not styled differently to any other parameter which made it hard to distinguish it. This has been improved by adding support for the `LspSignatureActiveParameter` syntax highlighting group where the active parameter now uses `nord8` are foreground color and additionally a font underline with the same color. [1]: https://github.com/neovim/neovim/blob/70db972e5fbcab39946ad8ac05472a693cf65b68/runtime/doc/lsp.txt#L456-L459 Co-authored-by: Sven Greb Co-authored-by: Arctic Ice Studio GH-286 --- colors/nord.vim | 3 +++ 1 file changed, 3 insertions(+) diff --git a/colors/nord.vim b/colors/nord.vim index c28c4326..fe0a4ffc 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -231,6 +231,9 @@ call s:hi("LspReferenceText", "", s:nord3_gui, "", s:nord3_term, "", "") call s:hi("LspReferenceRead", "", s:nord3_gui, "", s:nord3_term, "", "") call s:hi("LspReferenceWrite", "", s:nord3_gui, "", s:nord3_term, "", "") +"+- Neovim LspSignatureHelp -+ +call s:hi("LspSignatureActiveParameter", s:nord8_gui, "", s:nord8_term, "", s:underline, "") + "+--- Gutter ---+ call s:hi("CursorColumn", "", s:nord1_gui, "NONE", s:nord1_term, "", "") if g:nord_cursor_line_number_background == 0 From da94312d823d8b4633ede21e17734396c3ba4759 Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Sun, 10 Apr 2022 10:21:23 +0200 Subject: [PATCH 05/12] Don't load plugin-related things when the relevant plugin isn't installed (#294) Guard plugin and Neovim specific features in conditional blocks Function calls are expensive in Vim script so to reduce the overhead of processing the theme most plugin and Neovim specific features are now wrapped in conditional blocks, e.g. Neovim highlighting groups are only loaded when the global `nvim` variable is set while other plugins are checked for their own `loaded_*` variable (common plugin pattern). Some plugins provide no easy/straightforward way to be detected, so not all blocks are behind conditions, but it's still a significant improvement, and can always be improved in the future. Co-authored-by: Julien Voisin Co-authored-by: Sven Greb GH-294 --- colors/nord.vim | 351 ++++++++++++++++++++++++++---------------------- 1 file changed, 193 insertions(+), 158 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index fe0a4ffc..d8fd6df0 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -185,19 +185,14 @@ call s:hi("SpellLocal", s:nord5_gui, s:nord0_gui, s:nord5_term, "NONE", "undercu call s:hi("SpellRare", s:nord6_gui, s:nord0_gui, s:nord6_term, "NONE", "undercurl", s:nord6_gui) call s:hi("Visual", "", s:nord2_gui, "", s:nord1_term, "", "") call s:hi("VisualNOS", "", s:nord2_gui, "", s:nord1_term, "", "") -"+- Neovim Support -+ -call s:hi("healthError", s:nord11_gui, s:nord1_gui, s:nord11_term, s:nord1_term, "", "") -call s:hi("healthSuccess", s:nord14_gui, s:nord1_gui, s:nord14_term, s:nord1_term, "", "") -call s:hi("healthWarning", s:nord13_gui, s:nord1_gui, s:nord13_term, s:nord1_term, "", "") -call s:hi("TermCursorNC", "", s:nord1_gui, "", s:nord1_term, "", "") "+- Vim 8 Terminal Colors -+ if has('terminal') let g:terminal_ansi_colors = [s:nord1_gui, s:nord11_gui, s:nord14_gui, s:nord13_gui, s:nord9_gui, s:nord15_gui, s:nord8_gui, s:nord5_gui, s:nord3_gui, s:nord11_gui, s:nord14_gui, s:nord13_gui, s:nord9_gui, s:nord15_gui, s:nord7_gui, s:nord6_gui] endif -"+- Neovim Terminal Colors -+ if has('nvim') + "+- Neovim Terminal Colors -+ let g:terminal_color_0 = s:nord1_gui let g:terminal_color_1 = s:nord11_gui let g:terminal_color_2 = s:nord14_gui @@ -214,25 +209,31 @@ if has('nvim') let g:terminal_color_13 = s:nord15_gui let g:terminal_color_14 = s:nord7_gui let g:terminal_color_15 = s:nord6_gui -endif - -"+- Neovim Diagnostics API -+ -call s:hi("DiagnosticWarn", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("DiagnosticError" , s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("DiagnosticInfo" , s:nord8_gui, "", s:nord8_term, "", "", "") -call s:hi("DiagnosticHint" , s:nord10_gui, "", s:nord10_term, "", "", "") -call s:hi("DiagnosticUnderlineWarn" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") -call s:hi("DiagnosticUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") -call s:hi("DiagnosticUnderlineInfo" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") -call s:hi("DiagnosticUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") -"+- Neovim DocumentHighlight -+ -call s:hi("LspReferenceText", "", s:nord3_gui, "", s:nord3_term, "", "") -call s:hi("LspReferenceRead", "", s:nord3_gui, "", s:nord3_term, "", "") -call s:hi("LspReferenceWrite", "", s:nord3_gui, "", s:nord3_term, "", "") - -"+- Neovim LspSignatureHelp -+ -call s:hi("LspSignatureActiveParameter", s:nord8_gui, "", s:nord8_term, "", s:underline, "") + "+- Neovim Support -+ + call s:hi("healthError", s:nord11_gui, s:nord1_gui, s:nord11_term, s:nord1_term, "", "") + call s:hi("healthSuccess", s:nord14_gui, s:nord1_gui, s:nord14_term, s:nord1_term, "", "") + call s:hi("healthWarning", s:nord13_gui, s:nord1_gui, s:nord13_term, s:nord1_term, "", "") + call s:hi("TermCursorNC", "", s:nord1_gui, "", s:nord1_term, "", "") + + "+- Neovim Diagnostics API -+ + call s:hi("DiagnosticWarn", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("DiagnosticError" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("DiagnosticInfo" , s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("DiagnosticHint" , s:nord10_gui, "", s:nord10_term, "", "", "") + call s:hi("DiagnosticUnderlineWarn" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("DiagnosticUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") + call s:hi("DiagnosticUnderlineInfo" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") + call s:hi("DiagnosticUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") + + "+- Neovim DocumentHighlight -+ + call s:hi("LspReferenceText", "", s:nord3_gui, "", s:nord3_term, "", "") + call s:hi("LspReferenceRead", "", s:nord3_gui, "", s:nord3_term, "", "") + call s:hi("LspReferenceWrite", "", s:nord3_gui, "", s:nord3_term, "", "") + + "+- Neovim LspSignatureHelp -+ + call s:hi("LspSignatureActiveParameter", s:nord8_gui, "", s:nord8_term, "", s:underline, "") +endif "+--- Gutter ---+ call s:hi("CursorColumn", "", s:nord1_gui, "NONE", s:nord1_term, "", "") @@ -577,53 +578,67 @@ hi! link yamlDocumentStart Keyword "+--- UI ---+ " ALE " > w0rp/ale -call s:hi("ALEWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("ALEErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("ALEWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") -call s:hi("ALEError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") +if exists('g:loaded_ale') + call s:hi("ALEWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("ALEErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("ALEWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("ALEError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") +endif " Coc -" > neoclide/coc -call s:hi("CocWarningHighlight" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") -call s:hi("CocErrorHighlight" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") -call s:hi("CocWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("CocErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("CocInfoSign" , s:nord8_gui, "", s:nord8_term, "", "", "") -call s:hi("CocHintSign" , s:nord10_gui, "", s:nord10_term, "", "", "") - -" Neovim LSP -" > neovim/nvim-lspconfig -call s:hi("LspCodeLens", s:nord3_gui_bright, "", s:nord3_term, "", "", "") -if has("nvim-0.5") - call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") - call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") - call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") +" > neoclide/coc.vim +if exists('g:did_coc_loaded') + call s:hi("CocWarningHighlight" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("CocErrorHighlight" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") + call s:hi("CocWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("CocErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("CocInfoSign" , s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("CocHintSign" , s:nord10_gui, "", s:nord10_term, "", "", "") +endif + +if has('nvim') + " Neovim LSP + " > neovim/nvim-lspconfig + if exists('g:lspconfig') + call s:hi("LspCodeLens", s:nord3_gui_bright, "", s:nord3_term, "", "", "") + if has("nvim-0.5") + call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") + call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") + endif + endif endif " GitGutter " > airblade/vim-gitgutter -call s:hi("GitGutterAdd", s:nord14_gui, "", s:nord14_term, "", "", "") -call s:hi("GitGutterChange", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("GitGutterChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("GitGutterDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +if exists('g:loaded_gitgutter') + call s:hi("GitGutterAdd", s:nord14_gui, "", s:nord14_term, "", "", "") + call s:hi("GitGutterChange", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("GitGutterChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("GitGutterDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +endif " Signify " > mhinz/vim-signify -call s:hi("SignifySignAdd", s:nord14_gui, "", s:nord14_term, "", "", "") -call s:hi("SignifySignChange", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("SignifySignChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("SignifySignDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +if exists('g:loaded_signify') + call s:hi("SignifySignAdd", s:nord14_gui, "", s:nord14_term, "", "", "") + call s:hi("SignifySignChange", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("SignifySignChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("SignifySignDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +endif " fugitive.vim " > tpope/vim-fugitive -call s:hi("gitcommitDiscardedFile", s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("gitcommitUntrackedFile", s:nord11_gui, "", s:nord11_term, "", "", "") -call s:hi("gitcommitSelectedFile", s:nord14_gui, "", s:nord14_term, "", "", "") +if exists('g:loaded_fugitive') + call s:hi("gitcommitDiscardedFile", s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("gitcommitUntrackedFile", s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("gitcommitSelectedFile", s:nord14_gui, "", s:nord14_term, "", "", "") +endif " davidhalter/jedi-vim call s:hi("jediFunction", s:nord4_gui, s:nord3_gui, "", s:nord3_term, "", "") @@ -631,68 +646,82 @@ call s:hi("jediFat", s:nord8_gui, s:nord3_gui, s:nord8_term, s:nord3_term, s:und " NERDTree " > scrooloose/nerdtree -call s:hi("NERDTreeExecFile", s:nord7_gui, "", s:nord7_term, "", "", "") -hi! link NERDTreeDirSlash Keyword -hi! link NERDTreeHelp Comment +if exists('loaded_nerd_tree') + call s:hi("NERDTreeExecFile", s:nord7_gui, "", s:nord7_term, "", "", "") + hi! link NERDTreeDirSlash Keyword + hi! link NERDTreeHelp Comment +endif " CtrlP " > ctrlpvim/ctrlp.vim -hi! link CtrlPMatch Keyword -hi! link CtrlPBufferHid Normal +if exists('g:loaded_ctrlp') + hi! link CtrlPMatch Keyword + hi! link CtrlPBufferHid Normal +endif " vim-clap " > liuchengxu/vim-clap -call s:hi("ClapDir", s:nord4_gui, "", "", "", "", "") -call s:hi("ClapDisplay", s:nord4_gui, s:nord1_gui, "", s:nord1_term, "", "") -call s:hi("ClapFile", s:nord4_gui, "", "", "NONE", "", "") -call s:hi("ClapMatches", s:nord8_gui, "", s:nord8_term, "", "", "") -call s:hi("ClapNoMatchesFound", s:nord13_gui, "", s:nord13_term, "", "", "") -call s:hi("ClapSelected", s:nord7_gui, "", s:nord7_term, "", s:bold, "") -call s:hi("ClapSelectedSign", s:nord9_gui, "", s:nord9_term, "", "", "") - -let s:clap_matches = [ - \ [s:nord8_gui, s:nord8_term] , - \ [s:nord9_gui, s:nord9_term] , - \ [s:nord10_gui, s:nord10_term] , - \ ] -for s:nord_clap_match_i in range(1,12) - let clap_match_color = s:clap_matches[s:nord_clap_match_i % len(s:clap_matches) - 1] - call s:hi("ClapMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") - call s:hi("ClapFuzzyMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") -endfor -unlet s:nord_clap_match_i - -hi! link ClapCurrentSelection PmenuSel -hi! link ClapCurrentSelectionSign ClapSelectedSign -hi! link ClapInput Pmenu -hi! link ClapPreview Pmenu -hi! link ClapProviderAbout ClapDisplay -hi! link ClapProviderColon Type -hi! link ClapProviderId Type +if exists('g:loaded_clap') + call s:hi("ClapDir", s:nord4_gui, "", "", "", "", "") + call s:hi("ClapDisplay", s:nord4_gui, s:nord1_gui, "", s:nord1_term, "", "") + call s:hi("ClapFile", s:nord4_gui, "", "", "NONE", "", "") + call s:hi("ClapMatches", s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("ClapNoMatchesFound", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("ClapSelected", s:nord7_gui, "", s:nord7_term, "", s:bold, "") + call s:hi("ClapSelectedSign", s:nord9_gui, "", s:nord9_term, "", "", "") + + let s:clap_matches = [ + \ [s:nord8_gui, s:nord8_term] , + \ [s:nord9_gui, s:nord9_term] , + \ [s:nord10_gui, s:nord10_term] , + \ ] + for s:nord_clap_match_i in range(1,12) + let clap_match_color = s:clap_matches[s:nord_clap_match_i % len(s:clap_matches) - 1] + call s:hi("ClapMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") + call s:hi("ClapFuzzyMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") + endfor + unlet s:nord_clap_match_i + + hi! link ClapCurrentSelection PmenuSel + hi! link ClapCurrentSelectionSign ClapSelectedSign + hi! link ClapInput Pmenu + hi! link ClapPreview Pmenu + hi! link ClapProviderAbout ClapDisplay + hi! link ClapProviderColon Type + hi! link ClapProviderId Type +endif " vim-indent-guides " > nathanaelkane/vim-indent-guides -call s:hi("IndentGuidesEven", "", s:nord1_gui, "", s:nord1_term, "", "") -call s:hi("IndentGuidesOdd", "", s:nord2_gui, "", s:nord3_term, "", "") +if exists('g:loaded_indent_guides') + call s:hi("IndentGuidesEven", "", s:nord1_gui, "", s:nord1_term, "", "") + call s:hi("IndentGuidesOdd", "", s:nord2_gui, "", s:nord3_term, "", "") +endif " vim-plug " > junegunn/vim-plug -call s:hi("plugDeleted", s:nord11_gui, "", "", s:nord11_term, "", "") +if exists('g:loaded_plug') + call s:hi("plugDeleted", s:nord11_gui, "", "", s:nord11_term, "", "") +endif " vim-signature " > kshenoy/vim-signature -call s:hi("SignatureMarkText", s:nord8_gui, "", s:nord8_term, "", "", "") +if exists('g:loaded_Signature') + call s:hi("SignatureMarkText", s:nord8_gui, "", s:nord8_term, "", "", "") +endif " vim-startify " > mhinz/vim-startify -call s:hi("StartifyFile", s:nord6_gui, "", s:nord6_term, "", "", "") -call s:hi("StartifyFooter", s:nord7_gui, "", s:nord7_term, "", "", "") -call s:hi("StartifyHeader", s:nord8_gui, "", s:nord8_term, "", "", "") -call s:hi("StartifyNumber", s:nord7_gui, "", s:nord7_term, "", "", "") -call s:hi("StartifyPath", s:nord8_gui, "", s:nord8_term, "", "", "") -hi! link StartifyBracket Delimiter -hi! link StartifySlash Normal -hi! link StartifySpecial Comment +if exists('g:loaded_startify') + call s:hi("StartifyFile", s:nord6_gui, "", s:nord6_term, "", "", "") + call s:hi("StartifyFooter", s:nord7_gui, "", s:nord7_term, "", "", "") + call s:hi("StartifyHeader", s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("StartifyNumber", s:nord7_gui, "", s:nord7_term, "", "", "") + call s:hi("StartifyPath", s:nord8_gui, "", s:nord8_term, "", "", "") + hi! link StartifyBracket Delimiter + hi! link StartifySlash Normal + hi! link StartifySpecial Comment +endif "+--- Languages ---+ " Haskell @@ -714,45 +743,49 @@ hi! link jsRegexpString SpecialChar " Pandoc " > vim-pandoc/vim-pandoc-syntax -call s:hi("pandocDefinitionBlockTerm", s:nord7_gui, "", s:nord7_term, "", s:italic, "") -call s:hi("pandocTableDelims", s:nord3_gui, "", s:nord3_term, "", "", "") -hi! link pandocAtxHeader markdownH1 -hi! link pandocBlockQuote markdownBlockquote -hi! link pandocCiteAnchor Operator -hi! link pandocCiteKey pandocReferenceLabel -hi! link pandocDefinitionBlockMark Operator -hi! link pandocEmphasis markdownItalic -hi! link pandocFootnoteID pandocReferenceLabel -hi! link pandocFootnoteIDHead markdownLinkDelimiter -hi! link pandocFootnoteIDTail pandocFootnoteIDHead -hi! link pandocGridTableDelims pandocTableDelims -hi! link pandocGridTableHeader pandocTableDelims -hi! link pandocOperator Operator -hi! link pandocPipeTableDelims pandocTableDelims -hi! link pandocReferenceDefinition pandocReferenceLabel -hi! link pandocReferenceLabel markdownLinkText -hi! link pandocReferenceURL markdownUrl -hi! link pandocSimpleTableHeader pandocAtxHeader -hi! link pandocStrong markdownBold -hi! link pandocTableHeaderWord pandocAtxHeader -hi! link pandocUListItemBullet Operator - -" tree-sitter -" > nvim-treesitter/nvim-treesitter -if has("nvim") - hi! link TSAnnotation Annotation - hi! link TSConstBuiltin Constant - hi! link TSConstructor Function - hi! link TSEmphasis Italic - hi! link TSFuncBuiltin Function - hi! link TSFuncMacro Function - hi! link TSStringRegex SpecialChar - hi! link TSStrong Bold - hi! link TSStructure Structure - hi! link TSTagDelimiter TSTag - hi! link TSUnderline Underline - hi! link TSVariable Variable - hi! link TSVariableBuiltin Keyword +if exists('g:vim_pandoc_syntax_exists') + call s:hi("pandocDefinitionBlockTerm", s:nord7_gui, "", s:nord7_term, "", s:italic, "") + call s:hi("pandocTableDelims", s:nord3_gui, "", s:nord3_term, "", "", "") + hi! link pandocAtxHeader markdownH1 + hi! link pandocBlockQuote markdownBlockquote + hi! link pandocCiteAnchor Operator + hi! link pandocCiteKey pandocReferenceLabel + hi! link pandocDefinitionBlockMark Operator + hi! link pandocEmphasis markdownItalic + hi! link pandocFootnoteID pandocReferenceLabel + hi! link pandocFootnoteIDHead markdownLinkDelimiter + hi! link pandocFootnoteIDTail pandocFootnoteIDHead + hi! link pandocGridTableDelims pandocTableDelims + hi! link pandocGridTableHeader pandocTableDelims + hi! link pandocOperator Operator + hi! link pandocPipeTableDelims pandocTableDelims + hi! link pandocReferenceDefinition pandocReferenceLabel + hi! link pandocReferenceLabel markdownLinkText + hi! link pandocReferenceURL markdownUrl + hi! link pandocSimpleTableHeader pandocAtxHeader + hi! link pandocStrong markdownBold + hi! link pandocTableHeaderWord pandocAtxHeader + hi! link pandocUListItemBullet Operator +endif + +if has('nvim') + " tree-sitter + " > nvim-treesitter/nvim-treesitter + if exists('g:loaded_nvim_treesitter') + hi! link TSAnnotation Annotation + hi! link TSConstBuiltin Constant + hi! link TSConstructor Function + hi! link TSEmphasis Italic + hi! link TSFuncBuiltin Function + hi! link TSFuncMacro Function + hi! link TSStringRegex SpecialChar + hi! link TSStrong Bold + hi! link TSStructure Structure + hi! link TSTagDelimiter TSTag + hi! link TSUnderline Underline + hi! link TSVariable Variable + hi! link TSVariableBuiltin Keyword + endif endif " TypeScript @@ -831,23 +864,25 @@ hi! link phpUseClass phpClass " Vimwiki " > vimwiki/vimwiki -if !exists("g:vimwiki_hl_headers") || g:vimwiki_hl_headers == 0 - for s:i in range(1,6) - call s:hi("VimwikiHeader".s:i, s:nord8_gui, "", s:nord8_term, "", s:bold, "") - endfor -else - let s:vimwiki_hcolor_guifg = [s:nord7_gui, s:nord8_gui, s:nord9_gui, s:nord10_gui, s:nord14_gui, s:nord15_gui] - let s:vimwiki_hcolor_ctermfg = [s:nord7_term, s:nord8_term, s:nord9_term, s:nord10_term, s:nord14_term, s:nord15_term] - for s:i in range(1,6) - call s:hi("VimwikiHeader".s:i, s:vimwiki_hcolor_guifg[s:i-1] , "", s:vimwiki_hcolor_ctermfg[s:i-1], "", s:bold, "") - endfor +if exists('g:loaded_vimwiki') + if !exists("g:vimwiki_hl_headers") || g:vimwiki_hl_headers == 0 + for s:i in range(1,6) + call s:hi("VimwikiHeader".s:i, s:nord8_gui, "", s:nord8_term, "", s:bold, "") + endfor + else + let s:vimwiki_hcolor_guifg = [s:nord7_gui, s:nord8_gui, s:nord9_gui, s:nord10_gui, s:nord14_gui, s:nord15_gui] + let s:vimwiki_hcolor_ctermfg = [s:nord7_term, s:nord8_term, s:nord9_term, s:nord10_term, s:nord14_term, s:nord15_term] + for s:i in range(1,6) + call s:hi("VimwikiHeader".s:i, s:vimwiki_hcolor_guifg[s:i-1] , "", s:vimwiki_hcolor_ctermfg[s:i-1], "", s:bold, "") + endfor + endif + + call s:hi("VimwikiLink", s:nord8_gui, "", s:nord8_term, "", s:underline, "") + hi! link VimwikiHeaderChar markdownHeadingDelimiter + hi! link VimwikiHR Keyword + hi! link VimwikiList markdownListMarker endif - -call s:hi("VimwikiLink", s:nord8_gui, "", s:nord8_term, "", s:underline, "") -hi! link VimwikiHeaderChar markdownHeadingDelimiter -hi! link VimwikiHR Keyword -hi! link VimwikiList markdownListMarker - + " YAML " > stephpy/vim-yaml call s:hi("yamlKey", s:nord7_gui, "", s:nord7_term, "", "", "") From b0a09b73f1e260ae1f4fc6e1e08604522ebe3bcd Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Mon, 11 Apr 2022 09:11:10 +0200 Subject: [PATCH 06/12] Guard more plugin specific features in conditional blocks (#296) This commit is a continuation of GH-294, see message and PR discussion of commit `a4bf0a63e8e1e62e884eee9ec04d577105f58aa7` for details. [1]: https://github.com/arcticicestudio/nord-vim/commit/a4bf0a63e8e1e62e884eee9ec04d577105f58aa7 Related to GH-294 GH-296 Co-authored-by: Julien Voisin Co-authored-by: Sven Greb --- colors/nord.vim | 100 +++++++++++++++++++++++++----------------------- 1 file changed, 53 insertions(+), 47 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index d8fd6df0..35cf88cf 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -726,9 +726,11 @@ endif "+--- Languages ---+ " Haskell " > neovimhaskell/haskell-vim -call s:hi("haskellPreProc", s:nord10_gui, "", s:nord10_term, "", "", "") -call s:hi("haskellType", s:nord7_gui, "", s:nord7_term, "", "", "") -hi! link haskellPragma haskellPreProc +if exist('g:cabal_indent_section') + call s:hi("haskellPreProc", s:nord10_gui, "", s:nord10_term, "", "", "") + call s:hi("haskellType", s:nord7_gui, "", s:nord7_term, "", "", "") + hi! link haskellPragma haskellPreProc +endif " JavaScript " > pangloss/vim-javascript @@ -790,44 +792,46 @@ endif " TypeScript " > HerringtonDarkholme/yats.vim -call s:hi("typescriptBOMWindowMethod", s:nord8_gui, "", s:nord8_term, "", s:italic, "") -call s:hi("typescriptClassName", s:nord7_gui, "", s:nord7_term, "", "", "") -call s:hi("typescriptDecorator", s:nord12_gui, "", s:nord12_term, "", "", "") -call s:hi("typescriptInterfaceName", s:nord7_gui, "", s:nord7_term, "", s:bold, "") -call s:hi("typescriptRegexpString", s:nord13_gui, "", s:nord13_term, "", "", "") -" TypeScript JSX - call s:hi("tsxAttrib", s:nord7_gui, "", s:nord7_term, "", "", "") -hi! link typescriptOperator Operator -hi! link typescriptBinaryOp Operator -hi! link typescriptAssign Operator -hi! link typescriptMember Identifier -hi! link typescriptDOMStorageMethod Identifier -hi! link typescriptArrowFuncArg Identifier -hi! link typescriptGlobal typescriptClassName -hi! link typescriptBOMWindowProp Function -hi! link typescriptArrowFuncDef Function -hi! link typescriptAliasDeclaration Function -hi! link typescriptPredefinedType Type -hi! link typescriptTypeReference typescriptClassName -hi! link typescriptTypeAnnotation Structure -hi! link typescriptDocNamedParamType SpecialComment -hi! link typescriptDocNotation Keyword -hi! link typescriptDocTags Keyword -hi! link typescriptImport Keyword -hi! link typescriptExport Keyword -hi! link typescriptTry Keyword -hi! link typescriptVariable Keyword -hi! link typescriptBraces Normal -hi! link typescriptObjectLabel Normal -hi! link typescriptCall Normal -hi! link typescriptClassHeritage typescriptClassName -hi! link typescriptFuncTypeArrow Structure -hi! link typescriptMemberOptionality Structure -hi! link typescriptNodeGlobal typescriptGlobal -hi! link typescriptTypeBrackets Structure -hi! link tsxEqual Operator -hi! link tsxIntrinsicTagName htmlTag -hi! link tsxTagName tsxIntrinsicTagName +if exists('g:typescript_compiler_options') + call s:hi("typescriptBOMWindowMethod", s:nord8_gui, "", s:nord8_term, "", s:italic, "") + call s:hi("typescriptClassName", s:nord7_gui, "", s:nord7_term, "", "", "") + call s:hi("typescriptDecorator", s:nord12_gui, "", s:nord12_term, "", "", "") + call s:hi("typescriptInterfaceName", s:nord7_gui, "", s:nord7_term, "", s:bold, "") + call s:hi("typescriptRegexpString", s:nord13_gui, "", s:nord13_term, "", "", "") + " TypeScript JSX + call s:hi("tsxAttrib", s:nord7_gui, "", s:nord7_term, "", "", "") + hi! link typescriptOperator Operator + hi! link typescriptBinaryOp Operator + hi! link typescriptAssign Operator + hi! link typescriptMember Identifier + hi! link typescriptDOMStorageMethod Identifier + hi! link typescriptArrowFuncArg Identifier + hi! link typescriptGlobal typescriptClassName + hi! link typescriptBOMWindowProp Function + hi! link typescriptArrowFuncDef Function + hi! link typescriptAliasDeclaration Function + hi! link typescriptPredefinedType Type + hi! link typescriptTypeReference typescriptClassName + hi! link typescriptTypeAnnotation Structure + hi! link typescriptDocNamedParamType SpecialComment + hi! link typescriptDocNotation Keyword + hi! link typescriptDocTags Keyword + hi! link typescriptImport Keyword + hi! link typescriptExport Keyword + hi! link typescriptTry Keyword + hi! link typescriptVariable Keyword + hi! link typescriptBraces Normal + hi! link typescriptObjectLabel Normal + hi! link typescriptCall Normal + hi! link typescriptClassHeritage typescriptClassName + hi! link typescriptFuncTypeArrow Structure + hi! link typescriptMemberOptionality Structure + hi! link typescriptNodeGlobal typescriptGlobal + hi! link typescriptTypeBrackets Structure + hi! link tsxEqual Operator + hi! link tsxIntrinsicTagName htmlTag + hi! link tsxTagName tsxIntrinsicTagName +endif " Markdown " > plasticboy/vim-markdown @@ -855,12 +859,14 @@ hi! link mkdDelimiter Keyword " PHP " > StanAngeloff/php.vim -call s:hi("phpClass", s:nord7_gui, "", s:nord7_term, "", "", "") -call s:hi("phpClassImplements", s:nord7_gui, "", s:nord7_term, "", s:bold, "") -hi! link phpClassExtends phpClass -hi! link phpFunction Function -hi! link phpMethod Function -hi! link phpUseClass phpClass +if exist('g:php_version_id') + call s:hi("phpClass", s:nord7_gui, "", s:nord7_term, "", "", "") + call s:hi("phpClassImplements", s:nord7_gui, "", s:nord7_term, "", s:bold, "") + hi! link phpClassExtends phpClass + hi! link phpFunction Function + hi! link phpMethod Function + hi! link phpUseClass phpClass +endif " Vimwiki " > vimwiki/vimwiki From 085a184d5de5f2b722b8e1a3791bfdaec32cebdc Mon Sep 17 00:00:00 2001 From: Justin Nel Date: Mon, 11 Apr 2022 23:32:13 +0200 Subject: [PATCH 07/12] Fix syntax error in `exists` function (#297) Fix syntax error in `exists` function In GH-296 a syntax errors has crept in where the `exists` function was missing the second `s` in two cases. Fixes GH-299 GH-297 Co-authored-by: Julien Voisin Co-authored-by: Sven Greb Co-authored-by: Arctic Ice Studio --- colors/nord.vim | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index 35cf88cf..87539895 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -726,7 +726,7 @@ endif "+--- Languages ---+ " Haskell " > neovimhaskell/haskell-vim -if exist('g:cabal_indent_section') +if exists('g:cabal_indent_section') call s:hi("haskellPreProc", s:nord10_gui, "", s:nord10_term, "", "", "") call s:hi("haskellType", s:nord7_gui, "", s:nord7_term, "", "", "") hi! link haskellPragma haskellPreProc @@ -859,7 +859,7 @@ hi! link mkdDelimiter Keyword " PHP " > StanAngeloff/php.vim -if exist('g:php_version_id') +if exists('g:php_version_id') call s:hi("phpClass", s:nord7_gui, "", s:nord7_term, "", "", "") call s:hi("phpClassImplements", s:nord7_gui, "", s:nord7_term, "", s:bold, "") hi! link phpClassExtends phpClass From bf09e50f5cd640fae38268e90a74855f274a8007 Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Sat, 16 Apr 2022 09:53:54 +0200 Subject: [PATCH 08/12] Refactor theme configuration conditions (#295) The conditions and default values of the theme configurations were quite verbose so this commit improves them by... - ...using inline ternary operators instead of if/else blocks to reduce the code overhead and make it way more readable. - ...using Vim builtin `get` function [1] instead of if/else blocks. - ...inlining the script-scoped `logWarning` function since it was only used once. - ...grouping some blocks where it made sense. [1]: https://vimhelp.org/builtin.txt.html#builtin.txt#get%28%29 GH-295 Co-authored-by: Sven Greb --- colors/nord.vim | 64 +++++++++++++------------------------------------ 1 file changed, 16 insertions(+), 48 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index 87539895..6341b7bf 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -72,68 +72,36 @@ let s:nord3_gui_brightened = [ \ "#7b88a1", \ ] -if !exists("g:nord_bold") - let g:nord_bold = 1 -endif - -let s:bold = "bold," -if g:nord_bold == 0 - let s:bold = "" -endif - -if !exists("g:nord_italic") - if has("gui_running") || $TERM_ITALICS == "true" - let g:nord_italic = 1 - else - let g:nord_italic = 0 - endif -endif +let g:nord_bold = get(g:, "nord_bold", 1) +let s:bold = (g:nord_bold == 0) ? "" : "bold," -let s:italic = "italic," -if g:nord_italic == 0 - let s:italic = "" -endif +let g:nord_underline = get(g:, "nord_underline", 1) +let s:underline = (g:nord_underline == 0) ? "NONE," : "underline," -let s:underline = "underline," -if ! get(g:, "nord_underline", 1) - let s:underline = "NONE," -endif +let g:nord_italic = get(g:, "nord_italic", (has("gui_running") || $TERM_ITALICS == "true")) +let s:italic = (g:nord_italic == 0) ? "" : "italic," let s:italicize_comments = "" -if exists("g:nord_italic_comments") - if g:nord_italic_comments == 1 - let s:italicize_comments = s:italic - endif +if get(g:, "nord_italic_comments", 0) + let s:italicize_comments = s:italic endif -if !exists('g:nord_uniform_status_lines') - let g:nord_uniform_status_lines = 0 -endif - -function! s:logWarning(msg) - echohl WarningMsg - echomsg 'nord: warning: ' . a:msg - echohl None -endfunction +let g:nord_uniform_status_lines = get(g:, "nord_uniform_status_lines", 0) if exists("g:nord_comment_brightness") - call s:logWarning('Variable g:nord_comment_brightness has been deprecated and will be removed in version 1.0.0!' . + echohl WarningMsg + echomsg 'nord: warning: Variable g:nord_comment_brightness has been deprecated and will be removed in version 1.0.0!' . \' The comment color brightness has been increased by 10% by default.' . - \' Please see https://github.com/arcticicestudio/nord-vim/issues/145 for more details.') + \' Please see https://github.com/arcticicestudio/nord-vim/issues/145 for more details.' + echohl None let g:nord_comment_brightness = 10 endif -if !exists("g:nord_uniform_diff_background") - let g:nord_uniform_diff_background = 0 -endif +let g:nord_uniform_diff_background = get(g:, "nord_uniform_diff_background", 0) -if !exists("g:nord_cursor_line_number_background") - let g:nord_cursor_line_number_background = 0 -endif +let g:nord_cursor_line_number_background = get(g:, "nord_cursor_line_number_background", 0) -if !exists("g:nord_bold_vertical_split_line") - let g:nord_bold_vertical_split_line = 0 -endif +let g:nord_bold_vertical_split_line = get(g:, "nord_bold_vertical_split_line", 0) function! s:hi(group, guifg, guibg, ctermfg, ctermbg, attr, guisp) if a:guifg != "" From dc6cc32341770d4789cdc5b7fc76040b712123b3 Mon Sep 17 00:00:00 2001 From: Sven Greb Date: Sat, 23 Apr 2022 22:14:08 +0200 Subject: [PATCH 09/12] Revert conditional plugin loading (#307) The changes introduced in PR GH-294 [1] did not take into account that the order how plugins are loaded are not always constant and can also change based on how users order plugins in their configurations. When a supported plugin is loaded after Nord the global `loaded_*` variable might not be available yet, causing the styles to be skipped due to the conditional block guard. Also each plugin manager handles the plugin loading order differently which is also a problem when checking for global variable existence. The loading time of the Nord plugin is still totally fine so improving the stability for only a minimal performance boost is no negative trade at all (tested via `vim --startuptime timing.out`): 4.956ms: sourcing ~/.local/share/vim/plugged/nord-vim/colors/nord.vim [1]: https://github.com/arcticicestudio/nord-vim/pull/294 [2]: https://github.com/arcticicestudio/nord-vim/issues/306 Fixes GH-306 --- colors/nord.vim | 388 +++++++++++++++++++++--------------------------- 1 file changed, 172 insertions(+), 216 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index 6341b7bf..b95ac39e 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -88,6 +88,7 @@ endif let g:nord_uniform_status_lines = get(g:, "nord_uniform_status_lines", 0) +let g:nord_bold_vertical_split_line = get(g:, "nord_bold_vertical_split_line", 0) if exists("g:nord_comment_brightness") echohl WarningMsg echomsg 'nord: warning: Variable g:nord_comment_brightness has been deprecated and will be removed in version 1.0.0!' . @@ -96,12 +97,8 @@ if exists("g:nord_comment_brightness") echohl None let g:nord_comment_brightness = 10 endif - -let g:nord_uniform_diff_background = get(g:, "nord_uniform_diff_background", 0) - let g:nord_cursor_line_number_background = get(g:, "nord_cursor_line_number_background", 0) - -let g:nord_bold_vertical_split_line = get(g:, "nord_bold_vertical_split_line", 0) +let g:nord_uniform_diff_background = get(g:, "nord_uniform_diff_background", 0) function! s:hi(group, guifg, guibg, ctermfg, ctermbg, attr, guisp) if a:guifg != "" @@ -546,67 +543,55 @@ hi! link yamlDocumentStart Keyword "+--- UI ---+ " ALE " > w0rp/ale -if exists('g:loaded_ale') - call s:hi("ALEWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("ALEErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("ALEWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") - call s:hi("ALEError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") -endif +call s:hi("ALEWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("ALEErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("ALEWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") +call s:hi("ALEError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") " Coc " > neoclide/coc.vim -if exists('g:did_coc_loaded') - call s:hi("CocWarningHighlight" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") - call s:hi("CocErrorHighlight" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") - call s:hi("CocWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("CocErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("CocInfoSign" , s:nord8_gui, "", s:nord8_term, "", "", "") - call s:hi("CocHintSign" , s:nord10_gui, "", s:nord10_term, "", "", "") -endif +call s:hi("CocWarningHighlight" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") +call s:hi("CocErrorHighlight" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") +call s:hi("CocWarningSign", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("CocErrorSign" , s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("CocInfoSign" , s:nord8_gui, "", s:nord8_term, "", "", "") +call s:hi("CocHintSign" , s:nord10_gui, "", s:nord10_term, "", "", "") if has('nvim') " Neovim LSP " > neovim/nvim-lspconfig - if exists('g:lspconfig') - call s:hi("LspCodeLens", s:nord3_gui_bright, "", s:nord3_term, "", "", "") - if has("nvim-0.5") - call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") - call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") - call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") - call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") - endif + call s:hi("LspCodeLens", s:nord3_gui_bright, "", s:nord3_term, "", "", "") + if has("nvim-0.5") + call s:hi("LspDiagnosticsDefaultWarning", s:nord13_gui, "", s:nord13_term, "", "", "") + call s:hi("LspDiagnosticsDefaultError" , s:nord11_gui, "", s:nord11_term, "", "", "") + call s:hi("LspDiagnosticsDefaultInformation" , s:nord8_gui, "", s:nord8_term, "", "", "") + call s:hi("LspDiagnosticsDefaultHint" , s:nord10_gui, "", s:nord10_term, "", "", "") + call s:hi("LspDiagnosticsUnderlineWarning" , s:nord13_gui, "", s:nord13_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineInformation" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") + call s:hi("LspDiagnosticsUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") endif endif " GitGutter " > airblade/vim-gitgutter -if exists('g:loaded_gitgutter') - call s:hi("GitGutterAdd", s:nord14_gui, "", s:nord14_term, "", "", "") - call s:hi("GitGutterChange", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("GitGutterChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("GitGutterDelete", s:nord11_gui, "", s:nord11_term, "", "", "") -endif +call s:hi("GitGutterAdd", s:nord14_gui, "", s:nord14_term, "", "", "") +call s:hi("GitGutterChange", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("GitGutterChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("GitGutterDelete", s:nord11_gui, "", s:nord11_term, "", "", "") " Signify " > mhinz/vim-signify -if exists('g:loaded_signify') - call s:hi("SignifySignAdd", s:nord14_gui, "", s:nord14_term, "", "", "") - call s:hi("SignifySignChange", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("SignifySignChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("SignifySignDelete", s:nord11_gui, "", s:nord11_term, "", "", "") -endif +call s:hi("SignifySignAdd", s:nord14_gui, "", s:nord14_term, "", "", "") +call s:hi("SignifySignChange", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("SignifySignChangeDelete", s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("SignifySignDelete", s:nord11_gui, "", s:nord11_term, "", "", "") " fugitive.vim " > tpope/vim-fugitive -if exists('g:loaded_fugitive') - call s:hi("gitcommitDiscardedFile", s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("gitcommitUntrackedFile", s:nord11_gui, "", s:nord11_term, "", "", "") - call s:hi("gitcommitSelectedFile", s:nord14_gui, "", s:nord14_term, "", "", "") -endif +call s:hi("gitcommitDiscardedFile", s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("gitcommitUntrackedFile", s:nord11_gui, "", s:nord11_term, "", "", "") +call s:hi("gitcommitSelectedFile", s:nord14_gui, "", s:nord14_term, "", "", "") " davidhalter/jedi-vim call s:hi("jediFunction", s:nord4_gui, s:nord3_gui, "", s:nord3_term, "", "") @@ -614,91 +599,73 @@ call s:hi("jediFat", s:nord8_gui, s:nord3_gui, s:nord8_term, s:nord3_term, s:und " NERDTree " > scrooloose/nerdtree -if exists('loaded_nerd_tree') - call s:hi("NERDTreeExecFile", s:nord7_gui, "", s:nord7_term, "", "", "") - hi! link NERDTreeDirSlash Keyword - hi! link NERDTreeHelp Comment -endif +call s:hi("NERDTreeExecFile", s:nord7_gui, "", s:nord7_term, "", "", "") +hi! link NERDTreeDirSlash Keyword +hi! link NERDTreeHelp Comment " CtrlP " > ctrlpvim/ctrlp.vim -if exists('g:loaded_ctrlp') - hi! link CtrlPMatch Keyword - hi! link CtrlPBufferHid Normal -endif +hi! link CtrlPMatch Keyword +hi! link CtrlPBufferHid Normal " vim-clap " > liuchengxu/vim-clap -if exists('g:loaded_clap') - call s:hi("ClapDir", s:nord4_gui, "", "", "", "", "") - call s:hi("ClapDisplay", s:nord4_gui, s:nord1_gui, "", s:nord1_term, "", "") - call s:hi("ClapFile", s:nord4_gui, "", "", "NONE", "", "") - call s:hi("ClapMatches", s:nord8_gui, "", s:nord8_term, "", "", "") - call s:hi("ClapNoMatchesFound", s:nord13_gui, "", s:nord13_term, "", "", "") - call s:hi("ClapSelected", s:nord7_gui, "", s:nord7_term, "", s:bold, "") - call s:hi("ClapSelectedSign", s:nord9_gui, "", s:nord9_term, "", "", "") - - let s:clap_matches = [ - \ [s:nord8_gui, s:nord8_term] , - \ [s:nord9_gui, s:nord9_term] , - \ [s:nord10_gui, s:nord10_term] , - \ ] - for s:nord_clap_match_i in range(1,12) - let clap_match_color = s:clap_matches[s:nord_clap_match_i % len(s:clap_matches) - 1] - call s:hi("ClapMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") - call s:hi("ClapFuzzyMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") - endfor - unlet s:nord_clap_match_i - - hi! link ClapCurrentSelection PmenuSel - hi! link ClapCurrentSelectionSign ClapSelectedSign - hi! link ClapInput Pmenu - hi! link ClapPreview Pmenu - hi! link ClapProviderAbout ClapDisplay - hi! link ClapProviderColon Type - hi! link ClapProviderId Type -endif +call s:hi("ClapDir", s:nord4_gui, "", "", "", "", "") +call s:hi("ClapDisplay", s:nord4_gui, s:nord1_gui, "", s:nord1_term, "", "") +call s:hi("ClapFile", s:nord4_gui, "", "", "NONE", "", "") +call s:hi("ClapMatches", s:nord8_gui, "", s:nord8_term, "", "", "") +call s:hi("ClapNoMatchesFound", s:nord13_gui, "", s:nord13_term, "", "", "") +call s:hi("ClapSelected", s:nord7_gui, "", s:nord7_term, "", s:bold, "") +call s:hi("ClapSelectedSign", s:nord9_gui, "", s:nord9_term, "", "", "") +let s:clap_matches = [ + \ [s:nord8_gui, s:nord8_term] , + \ [s:nord9_gui, s:nord9_term] , + \ [s:nord10_gui, s:nord10_term] , + \ ] +for s:nord_clap_match_i in range(1,12) + let clap_match_color = s:clap_matches[s:nord_clap_match_i % len(s:clap_matches) - 1] + call s:hi("ClapMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") + call s:hi("ClapFuzzyMatches" . s:nord_clap_match_i, clap_match_color[0], "", clap_match_color[1], "", "", "") +endfor +unlet s:nord_clap_match_i +hi! link ClapCurrentSelection PmenuSel +hi! link ClapCurrentSelectionSign ClapSelectedSign +hi! link ClapInput Pmenu +hi! link ClapPreview Pmenu +hi! link ClapProviderAbout ClapDisplay +hi! link ClapProviderColon Type +hi! link ClapProviderId Type " vim-indent-guides " > nathanaelkane/vim-indent-guides -if exists('g:loaded_indent_guides') - call s:hi("IndentGuidesEven", "", s:nord1_gui, "", s:nord1_term, "", "") - call s:hi("IndentGuidesOdd", "", s:nord2_gui, "", s:nord3_term, "", "") -endif +call s:hi("IndentGuidesEven", "", s:nord1_gui, "", s:nord1_term, "", "") +call s:hi("IndentGuidesOdd", "", s:nord2_gui, "", s:nord3_term, "", "") " vim-plug " > junegunn/vim-plug -if exists('g:loaded_plug') - call s:hi("plugDeleted", s:nord11_gui, "", "", s:nord11_term, "", "") -endif +call s:hi("plugDeleted", s:nord11_gui, "", "", s:nord11_term, "", "") " vim-signature " > kshenoy/vim-signature -if exists('g:loaded_Signature') - call s:hi("SignatureMarkText", s:nord8_gui, "", s:nord8_term, "", "", "") -endif +call s:hi("SignatureMarkText", s:nord8_gui, "", s:nord8_term, "", "", "") " vim-startify " > mhinz/vim-startify -if exists('g:loaded_startify') - call s:hi("StartifyFile", s:nord6_gui, "", s:nord6_term, "", "", "") - call s:hi("StartifyFooter", s:nord7_gui, "", s:nord7_term, "", "", "") - call s:hi("StartifyHeader", s:nord8_gui, "", s:nord8_term, "", "", "") - call s:hi("StartifyNumber", s:nord7_gui, "", s:nord7_term, "", "", "") - call s:hi("StartifyPath", s:nord8_gui, "", s:nord8_term, "", "", "") - hi! link StartifyBracket Delimiter - hi! link StartifySlash Normal - hi! link StartifySpecial Comment -endif +call s:hi("StartifyFile", s:nord6_gui, "", s:nord6_term, "", "", "") +call s:hi("StartifyFooter", s:nord7_gui, "", s:nord7_term, "", "", "") +call s:hi("StartifyHeader", s:nord8_gui, "", s:nord8_term, "", "", "") +call s:hi("StartifyNumber", s:nord7_gui, "", s:nord7_term, "", "", "") +call s:hi("StartifyPath", s:nord8_gui, "", s:nord8_term, "", "", "") +hi! link StartifyBracket Delimiter +hi! link StartifySlash Normal +hi! link StartifySpecial Comment "+--- Languages ---+ " Haskell " > neovimhaskell/haskell-vim -if exists('g:cabal_indent_section') - call s:hi("haskellPreProc", s:nord10_gui, "", s:nord10_term, "", "", "") - call s:hi("haskellType", s:nord7_gui, "", s:nord7_term, "", "", "") - hi! link haskellPragma haskellPreProc -endif +call s:hi("haskellPreProc", s:nord10_gui, "", s:nord10_term, "", "", "") +call s:hi("haskellType", s:nord7_gui, "", s:nord7_term, "", "", "") +hi! link haskellPragma haskellPreProc " JavaScript " > pangloss/vim-javascript @@ -713,93 +680,87 @@ hi! link jsRegexpString SpecialChar " Pandoc " > vim-pandoc/vim-pandoc-syntax -if exists('g:vim_pandoc_syntax_exists') - call s:hi("pandocDefinitionBlockTerm", s:nord7_gui, "", s:nord7_term, "", s:italic, "") - call s:hi("pandocTableDelims", s:nord3_gui, "", s:nord3_term, "", "", "") - hi! link pandocAtxHeader markdownH1 - hi! link pandocBlockQuote markdownBlockquote - hi! link pandocCiteAnchor Operator - hi! link pandocCiteKey pandocReferenceLabel - hi! link pandocDefinitionBlockMark Operator - hi! link pandocEmphasis markdownItalic - hi! link pandocFootnoteID pandocReferenceLabel - hi! link pandocFootnoteIDHead markdownLinkDelimiter - hi! link pandocFootnoteIDTail pandocFootnoteIDHead - hi! link pandocGridTableDelims pandocTableDelims - hi! link pandocGridTableHeader pandocTableDelims - hi! link pandocOperator Operator - hi! link pandocPipeTableDelims pandocTableDelims - hi! link pandocReferenceDefinition pandocReferenceLabel - hi! link pandocReferenceLabel markdownLinkText - hi! link pandocReferenceURL markdownUrl - hi! link pandocSimpleTableHeader pandocAtxHeader - hi! link pandocStrong markdownBold - hi! link pandocTableHeaderWord pandocAtxHeader - hi! link pandocUListItemBullet Operator -endif +call s:hi("pandocDefinitionBlockTerm", s:nord7_gui, "", s:nord7_term, "", s:italic, "") +call s:hi("pandocTableDelims", s:nord3_gui, "", s:nord3_term, "", "", "") +hi! link pandocAtxHeader markdownH1 +hi! link pandocBlockQuote markdownBlockquote +hi! link pandocCiteAnchor Operator +hi! link pandocCiteKey pandocReferenceLabel +hi! link pandocDefinitionBlockMark Operator +hi! link pandocEmphasis markdownItalic +hi! link pandocFootnoteID pandocReferenceLabel +hi! link pandocFootnoteIDHead markdownLinkDelimiter +hi! link pandocFootnoteIDTail pandocFootnoteIDHead +hi! link pandocGridTableDelims pandocTableDelims +hi! link pandocGridTableHeader pandocTableDelims +hi! link pandocOperator Operator +hi! link pandocPipeTableDelims pandocTableDelims +hi! link pandocReferenceDefinition pandocReferenceLabel +hi! link pandocReferenceLabel markdownLinkText +hi! link pandocReferenceURL markdownUrl +hi! link pandocSimpleTableHeader pandocAtxHeader +hi! link pandocStrong markdownBold +hi! link pandocTableHeaderWord pandocAtxHeader +hi! link pandocUListItemBullet Operator if has('nvim') " tree-sitter " > nvim-treesitter/nvim-treesitter - if exists('g:loaded_nvim_treesitter') - hi! link TSAnnotation Annotation - hi! link TSConstBuiltin Constant - hi! link TSConstructor Function - hi! link TSEmphasis Italic - hi! link TSFuncBuiltin Function - hi! link TSFuncMacro Function - hi! link TSStringRegex SpecialChar - hi! link TSStrong Bold - hi! link TSStructure Structure - hi! link TSTagDelimiter TSTag - hi! link TSUnderline Underline - hi! link TSVariable Variable - hi! link TSVariableBuiltin Keyword - endif + hi! link TSAnnotation Annotation + hi! link TSConstBuiltin Constant + hi! link TSConstructor Function + hi! link TSEmphasis Italic + hi! link TSFuncBuiltin Function + hi! link TSFuncMacro Function + hi! link TSStringRegex SpecialChar + hi! link TSStrong Bold + hi! link TSStructure Structure + hi! link TSTagDelimiter TSTag + hi! link TSUnderline Underline + hi! link TSVariable Variable + hi! link TSVariableBuiltin Keyword endif " TypeScript " > HerringtonDarkholme/yats.vim -if exists('g:typescript_compiler_options') - call s:hi("typescriptBOMWindowMethod", s:nord8_gui, "", s:nord8_term, "", s:italic, "") - call s:hi("typescriptClassName", s:nord7_gui, "", s:nord7_term, "", "", "") - call s:hi("typescriptDecorator", s:nord12_gui, "", s:nord12_term, "", "", "") - call s:hi("typescriptInterfaceName", s:nord7_gui, "", s:nord7_term, "", s:bold, "") - call s:hi("typescriptRegexpString", s:nord13_gui, "", s:nord13_term, "", "", "") - " TypeScript JSX - call s:hi("tsxAttrib", s:nord7_gui, "", s:nord7_term, "", "", "") - hi! link typescriptOperator Operator - hi! link typescriptBinaryOp Operator - hi! link typescriptAssign Operator - hi! link typescriptMember Identifier - hi! link typescriptDOMStorageMethod Identifier - hi! link typescriptArrowFuncArg Identifier - hi! link typescriptGlobal typescriptClassName - hi! link typescriptBOMWindowProp Function - hi! link typescriptArrowFuncDef Function - hi! link typescriptAliasDeclaration Function - hi! link typescriptPredefinedType Type - hi! link typescriptTypeReference typescriptClassName - hi! link typescriptTypeAnnotation Structure - hi! link typescriptDocNamedParamType SpecialComment - hi! link typescriptDocNotation Keyword - hi! link typescriptDocTags Keyword - hi! link typescriptImport Keyword - hi! link typescriptExport Keyword - hi! link typescriptTry Keyword - hi! link typescriptVariable Keyword - hi! link typescriptBraces Normal - hi! link typescriptObjectLabel Normal - hi! link typescriptCall Normal - hi! link typescriptClassHeritage typescriptClassName - hi! link typescriptFuncTypeArrow Structure - hi! link typescriptMemberOptionality Structure - hi! link typescriptNodeGlobal typescriptGlobal - hi! link typescriptTypeBrackets Structure - hi! link tsxEqual Operator - hi! link tsxIntrinsicTagName htmlTag - hi! link tsxTagName tsxIntrinsicTagName -endif +call s:hi("typescriptBOMWindowMethod", s:nord8_gui, "", s:nord8_term, "", s:italic, "") +call s:hi("typescriptClassName", s:nord7_gui, "", s:nord7_term, "", "", "") +call s:hi("typescriptDecorator", s:nord12_gui, "", s:nord12_term, "", "", "") +call s:hi("typescriptInterfaceName", s:nord7_gui, "", s:nord7_term, "", s:bold, "") +call s:hi("typescriptRegexpString", s:nord13_gui, "", s:nord13_term, "", "", "") +" TypeScript JSX + call s:hi("tsxAttrib", s:nord7_gui, "", s:nord7_term, "", "", "") +hi! link typescriptOperator Operator +hi! link typescriptBinaryOp Operator +hi! link typescriptAssign Operator +hi! link typescriptMember Identifier +hi! link typescriptDOMStorageMethod Identifier +hi! link typescriptArrowFuncArg Identifier +hi! link typescriptGlobal typescriptClassName +hi! link typescriptBOMWindowProp Function +hi! link typescriptArrowFuncDef Function +hi! link typescriptAliasDeclaration Function +hi! link typescriptPredefinedType Type +hi! link typescriptTypeReference typescriptClassName +hi! link typescriptTypeAnnotation Structure +hi! link typescriptDocNamedParamType SpecialComment +hi! link typescriptDocNotation Keyword +hi! link typescriptDocTags Keyword +hi! link typescriptImport Keyword +hi! link typescriptExport Keyword +hi! link typescriptTry Keyword +hi! link typescriptVariable Keyword +hi! link typescriptBraces Normal +hi! link typescriptObjectLabel Normal +hi! link typescriptCall Normal +hi! link typescriptClassHeritage typescriptClassName +hi! link typescriptFuncTypeArrow Structure +hi! link typescriptMemberOptionality Structure +hi! link typescriptNodeGlobal typescriptGlobal +hi! link typescriptTypeBrackets Structure +hi! link tsxEqual Operator +hi! link tsxIntrinsicTagName htmlTag +hi! link tsxTagName tsxIntrinsicTagName " Markdown " > plasticboy/vim-markdown @@ -827,35 +788,30 @@ hi! link mkdDelimiter Keyword " PHP " > StanAngeloff/php.vim -if exists('g:php_version_id') - call s:hi("phpClass", s:nord7_gui, "", s:nord7_term, "", "", "") - call s:hi("phpClassImplements", s:nord7_gui, "", s:nord7_term, "", s:bold, "") - hi! link phpClassExtends phpClass - hi! link phpFunction Function - hi! link phpMethod Function - hi! link phpUseClass phpClass -endif +call s:hi("phpClass", s:nord7_gui, "", s:nord7_term, "", "", "") +call s:hi("phpClassImplements", s:nord7_gui, "", s:nord7_term, "", s:bold, "") +hi! link phpClassExtends phpClass +hi! link phpFunction Function +hi! link phpMethod Function +hi! link phpUseClass phpClass " Vimwiki " > vimwiki/vimwiki -if exists('g:loaded_vimwiki') - if !exists("g:vimwiki_hl_headers") || g:vimwiki_hl_headers == 0 - for s:i in range(1,6) - call s:hi("VimwikiHeader".s:i, s:nord8_gui, "", s:nord8_term, "", s:bold, "") - endfor - else - let s:vimwiki_hcolor_guifg = [s:nord7_gui, s:nord8_gui, s:nord9_gui, s:nord10_gui, s:nord14_gui, s:nord15_gui] - let s:vimwiki_hcolor_ctermfg = [s:nord7_term, s:nord8_term, s:nord9_term, s:nord10_term, s:nord14_term, s:nord15_term] - for s:i in range(1,6) - call s:hi("VimwikiHeader".s:i, s:vimwiki_hcolor_guifg[s:i-1] , "", s:vimwiki_hcolor_ctermfg[s:i-1], "", s:bold, "") - endfor - endif - - call s:hi("VimwikiLink", s:nord8_gui, "", s:nord8_term, "", s:underline, "") - hi! link VimwikiHeaderChar markdownHeadingDelimiter - hi! link VimwikiHR Keyword - hi! link VimwikiList markdownListMarker -endif +if !exists("g:vimwiki_hl_headers") || g:vimwiki_hl_headers == 0 + for s:i in range(1,6) + call s:hi("VimwikiHeader".s:i, s:nord8_gui, "", s:nord8_term, "", s:bold, "") + endfor +else + let s:vimwiki_hcolor_guifg = [s:nord7_gui, s:nord8_gui, s:nord9_gui, s:nord10_gui, s:nord14_gui, s:nord15_gui] + let s:vimwiki_hcolor_ctermfg = [s:nord7_term, s:nord8_term, s:nord9_term, s:nord10_term, s:nord14_term, s:nord15_term] + for s:i in range(1,6) + call s:hi("VimwikiHeader".s:i, s:vimwiki_hcolor_guifg[s:i-1] , "", s:vimwiki_hcolor_ctermfg[s:i-1], "", s:bold, "") + endfor +endif +call s:hi("VimwikiLink", s:nord8_gui, "", s:nord8_term, "", s:underline, "") +hi! link VimwikiHeaderChar markdownHeadingDelimiter +hi! link VimwikiHR Keyword +hi! link VimwikiList markdownListMarker " YAML " > stephpy/vim-yaml From dd7666d8b06a1961dd931b9865749b1d38231fba Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Sun, 24 Apr 2022 09:28:35 +0200 Subject: [PATCH 10/12] Use ternary for "italic" theme configuration (#305) Instead of using a if/else block and empty variable declaration Vim's builtin `get` function [1] is now used to simplify the code. Co-authored-by: Sven Greb Co-authored-by: Arctic Ice Studio [1]: https://vimhelp.org/builtin.txt.html#builtin.txt#get%28%29 GH-305 --- colors/nord.vim | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index b95ac39e..d07ffb97 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -81,10 +81,8 @@ let s:underline = (g:nord_underline == 0) ? "NONE," : "underline," let g:nord_italic = get(g:, "nord_italic", (has("gui_running") || $TERM_ITALICS == "true")) let s:italic = (g:nord_italic == 0) ? "" : "italic," -let s:italicize_comments = "" -if get(g:, "nord_italic_comments", 0) - let s:italicize_comments = s:italic -endif +let g:nord_italic_comments = get(g:, "nord_italic_comments", 0) +let s:italicize_comments = (g:nord_italic_comments == 0) ? "" : get(s:, "italic") let g:nord_uniform_status_lines = get(g:, "nord_uniform_status_lines", 0) From f3327dbde7c328832bd2f7187895890c0fa1a00d Mon Sep 17 00:00:00 2001 From: Julien Voisin Date: Sun, 24 Apr 2022 10:13:22 +0200 Subject: [PATCH 11/12] Only call `execute` function once per syntax group (#303) Before the custom `s:hi` function called Vim's `execute` function [1] for each defined attribute which is quite expensive in terms of performance. To improve this the attributes are now concatenate as string and passed to `exec` at the end of the function instead. Co-authored-by: Julien Voisin Co-authored-by: Sven Greb Co-authored-by: Arctic Ice Sudio [1]: https://vimhelp.org/builtin.txt.html#builtin.txt#execute%28%29 GH-303 --- colors/nord.vim | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/colors/nord.vim b/colors/nord.vim index d07ffb97..23f95865 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -99,23 +99,27 @@ let g:nord_cursor_line_number_background = get(g:, "nord_cursor_line_number_back let g:nord_uniform_diff_background = get(g:, "nord_uniform_diff_background", 0) function! s:hi(group, guifg, guibg, ctermfg, ctermbg, attr, guisp) + let cmd = "" if a:guifg != "" - exec "hi " . a:group . " guifg=" . a:guifg + let cmd = cmd . " guifg=" . a:guifg endif if a:guibg != "" - exec "hi " . a:group . " guibg=" . a:guibg + let cmd = cmd . " guibg=" . a:guibg endif if a:ctermfg != "" - exec "hi " . a:group . " ctermfg=" . a:ctermfg + let cmd = cmd . " ctermfg=" . a:ctermfg endif if a:ctermbg != "" - exec "hi " . a:group . " ctermbg=" . a:ctermbg + let cmd = cmd . " ctermbg=" . a:ctermbg endif if a:attr != "" - exec "hi " . a:group . " gui=" . a:attr . " cterm=" . substitute(a:attr, "undercurl", s:underline, "") + let cmd = cmd . " gui=" . a:attr . " cterm=" . substitute(a:attr, "undercurl", s:underline, "") endif if a:guisp != "" - exec "hi " . a:group . " guisp=" . a:guisp + let cmd = cmd . " guisp=" . a:guisp + endif + if cmd != "" + exec "hi " . a:group . cmd endif endfunction @@ -188,12 +192,12 @@ if has('nvim') call s:hi("DiagnosticUnderlineError" , s:nord11_gui, "", s:nord11_term, "", "undercurl", "") call s:hi("DiagnosticUnderlineInfo" , s:nord8_gui, "", s:nord8_term, "", "undercurl", "") call s:hi("DiagnosticUnderlineHint" , s:nord10_gui, "", s:nord10_term, "", "undercurl", "") - + "+- Neovim DocumentHighlight -+ call s:hi("LspReferenceText", "", s:nord3_gui, "", s:nord3_term, "", "") call s:hi("LspReferenceRead", "", s:nord3_gui, "", s:nord3_term, "", "") call s:hi("LspReferenceWrite", "", s:nord3_gui, "", s:nord3_term, "", "") - + "+- Neovim LspSignatureHelp -+ call s:hi("LspSignatureActiveParameter", s:nord8_gui, "", s:nord8_term, "", s:underline, "") endif @@ -805,12 +809,12 @@ else for s:i in range(1,6) call s:hi("VimwikiHeader".s:i, s:vimwiki_hcolor_guifg[s:i-1] , "", s:vimwiki_hcolor_ctermfg[s:i-1], "", s:bold, "") endfor -endif +endif call s:hi("VimwikiLink", s:nord8_gui, "", s:nord8_term, "", s:underline, "") hi! link VimwikiHeaderChar markdownHeadingDelimiter hi! link VimwikiHR Keyword hi! link VimwikiList markdownListMarker - + " YAML " > stephpy/vim-yaml call s:hi("yamlKey", s:nord7_gui, "", s:nord7_term, "", "", "") From c9e7f43e7fbdca887ebc23edbeae7627aecb8117 Mon Sep 17 00:00:00 2001 From: Sven Greb Date: Sat, 14 May 2022 11:24:40 +0200 Subject: [PATCH 12/12] Release version 0.19.0 --- CHANGELOG.md | 571 ++++++++++++++---------- README.md | 80 ++-- autoload/airline/themes/nord.vim | 2 +- autoload/lightline/colorscheme/nord.vim | 2 +- colors/nord.vim | 2 +- 5 files changed, 387 insertions(+), 270 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 97cec598..d8279844 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,11 +6,94 @@ +# 0.19.0 + +![Release Date: 2022-05-14](https://img.shields.io/static/v1.svg?style=flat-square&label=Release%20Date&message=2022-05-14&colorA=4c566a&colorB=88c0d0) [![Project Board](https://img.shields.io/static/v1.svg?style=flat-square&label=Project%20Board&message=0.19.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/users/arcticicestudio/projects/9/views/9) [![Milestone](https://img.shields.io/static/v1.svg?style=flat-square&label=Milestone&message=0.19.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/milestone/21) + +⇅ [Show all commits][111] + +## Features + +### Syntax + +
+Support for LSP textDocument/documentHighlight — #284 (⊶ 3e4e273d) by @cmoscofian + +↠ The [Neovim LSP `textDocument` / `documentHightlight` groups][114] are responsible to highlight tokens in a document that are related to each +other, e.g. declared variables, using the `vim.buf.lsp.document_highlight()` function. +Also see the [LSP specification about "Document Highlights Request"][115] for more details. + +

+ +

+ +
+ +### UI + +
+Support for LSP LSPSignatureActiveParameter — #286 (⊶ a8256787) by @cmoscofian + +↠ The [`vim.lsp.buf.signature_help` function is used to highlight the active parameter in the signature help][117] [1]. Before the active parameter was not styled differently to any other parameter which made it hard to distinguish it. This has been improved by adding support for the `LspSignatureActiveParameter` syntax highlighting group where the active parameter now uses `nord8` are foreground color and additionally a font underline with the same color. + +

Before

+

+ +

After

+

+ +
+ +## Improvements + +
+Refactored theme configuration conditions — #295, #305 (⊶ 291e05d9, e3eb2084) by @jvoisin and @svengreb + +↠ The conditions and default values of the theme configurations were quite verbose so this commit improves them by… + +- …using inline ternary operators instead of if/else blocks to reduce the code overhead and make it way more readable. +- …using [Vim builtin `get` function][118] instead of if/else blocks. +- …inlining the script-scoped `logWarning` function since it was only used once. +- …grouping some blocks where it made sense. + +
+ +
+Only call execute function once per syntax group — #303 (⊶ 77fe4b3f) by @jvoisin and @svengreb + +↠ Before the custom `s:hi` function called [Vim's `execute` function][119] for each defined attribute which is quite expensive in terms of performance. To improve this the attributes are now concatenate as string and passed to `exec` at the end of the function instead. + +
+ +### Syntax + +
+Readability of C language constants — #283 (⊶ b32592eb) by @jvoisin + +↠ To improve the readability of C language constants, defined by [the `cConstant` syntax highlighting group][116], these are now colored with `nord9` for the foreground to make them stand out. This is important in C, since interesting things are usually happening in their proximity, like checking/returning an error, passing particular values/flags to functions and so on. + +

Before

+

+ +

After

+

+ +
+ +## Tasks + +
+Support for Neovim 0.6.0 diagnostic API highlight groups — #282 (⊶ 8035ba07) by @jan-xyz + +↠ In [Neovim `0.6.0`][112] the [naming scheme for the highlight groups of the diagnostic API changed][113] [2]. The new groups have been added as default while the previous groups are conditionally guarded when using Neovim `0.5.0`. + +
+ # 0.18.0 ![Release Date: 2021-09-12](https://img.shields.io/static/v1.svg?style=flat-square&label=Release%20Date&message=2021-09-12&colorA=4c566a&colorB=88c0d0) [![Project Board](https://img.shields.io/static/v1.svg?style=flat-square&label=Project%20Board&message=0.18.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/projects/24) [![Milestone](https://img.shields.io/static/v1.svg?style=flat-square&label=Milestone&message=0.18.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/milestone/20) -⇅ [Show all commits][gh-compare-tag-v0.17.0_v0.18.0] +⇅ [Show all commits][106] ## Features @@ -19,7 +102,7 @@
Support for vim-pandoc/vim-pandoc-syntax — #220 (⊶ 8d8b9bf8) by @tpoisot and @BirgerNi -↠ To improve syntax highlighting for [Pandoc][], support for the [vim-pandoc/vim-pandoc-syntax][] plugin has been implemented. +↠ To improve syntax highlighting for [Pandoc][9], support for the [vim-pandoc/vim-pandoc-syntax][13] plugin has been implemented. Most groups are linked to existing Markdown groups to ensure a consistent style across languages and different plugins.

@@ -31,13 +114,13 @@ Most groups are linked to existing Markdown groups to ensure a consistent style
Support for LSP code lenses — #266 (⊶ 02ddfadb) by @jan-xyz -↠ Before [LSP code lenses][nvim-docs-lsp#codelens] were highlighted with the default color which has been changed to make it less visually intrusive, like other UI related elements, e.g. messages of linters. +↠ Before [LSP code lenses][107] were highlighted with the default color which has been changed to make it less visually intrusive, like other UI related elements, e.g. messages of linters.

Before

-

+

After

-

+

@@ -48,11 +131,15 @@ Most groups are linked to existing Markdown groups to ensure a consistent style
Prevent aggressive error highlighting — #269 ⇄ #270 (⊶ e3e8a75c) by @jan-xyz -↠ The `TSError` group is used to [highlight syntax/parser errors][nvim-treesitter/nvim-treesitter-blob-fb5d6e04#l493-l495] which caused an aggressive styling where the background color of many syntax elements was rendered with `nord11` during typing. This is a known problem and was fixed by many other themes by removing the group again. One of the [core maintainers of `nvim-treesitter` provided a solution by remapping groups][nvim-treesitter/nvim-treesitter#78#comment-647140700] and also mentioned that the group is [styled by the `nvim-treesitter` plugin but the active theme][nvim-treesitter/nvim-treesitter#1016#comment-797049591]. +↠ The `TSError` group is used to [highlight syntax/parser errors][108] which caused an aggressive styling where the background color of many syntax elements was rendered with `nord11` during typing. This is a known problem and was fixed by many other themes by removing the group again. One of the [core maintainers of `nvim-treesitter` provided a solution by remapping groups][110] and also mentioned that the group is [styled by the `nvim-treesitter` plugin but the active theme][109]. -Syntax errors can still be highlighted through linters and parsers like [Neovim's LSP][neovim/nvim-lspconfig] can still be used instead to highlight errors with the correct style, e.g. only change the foreground color of a single word. +Syntax errors can still be highlighted through linters and parsers like [Neovim's LSP][8] can still be used instead to highlight errors with the correct style, e.g. only change the foreground color of a single word. -

+

Before

+

+ +

After

+

@@ -60,7 +147,7 @@ Syntax errors can still be highlighted through linters and parsers like [Neovim' ![Release Date: 2021-07-10](https://img.shields.io/static/v1.svg?style=flat-square&label=Release%20Date&message=2021-07-10&colorA=4c566a&colorB=88c0d0) [![Project Board](https://img.shields.io/static/v1.svg?style=flat-square&label=Project%20Board&message=0.17.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/projects/23) [![Milestone](https://img.shields.io/static/v1.svg?style=flat-square&label=Milestone&message=0.17.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/milestone/19) -⇅ [Show all commits][gh-compare-tag-v0.16.0_v0.17.0] +⇅ [Show all commits][101] ## Features @@ -69,8 +156,8 @@ Syntax errors can still be highlighted through linters and parsers like [Neovim'
Support for nvim-treesitter/nvim-treesitter — #235 ⇄ #253 (⊶ b3e712a9) by @s-u-d-o-e-r and @mrswats -↠ Neovim [version 0.5][neovim/neovim-v0.5.0] is a long-time awaited update that introduces features like support for [tree-sitter][tree-sitter/tree-sitter] via [nvim-treesitter][nvim-treesitter/nvim-treesitter] and [LSP][neovim-docs-lsp] via [nvim-lspconfig][neovim/nvim-lspconfig]. -Even though Neovim divides more and more from Vim through specific features like first-class Lua support with custom APIs, the highlighting for tree-sitter is achieved through “normal“ syntax highlighting groups. Most of the groups are already [linked by the `nvim-treesitter` plugin by default][nvim-treesitter/nvim-treesitter-blob-90f15d9] so only a few groups have been adjusted for now to fit the Nord style. +↠ Neovim [version 0.5][102] is a long-time awaited update that introduces features like support for [tree-sitter][105] via [nvim-treesitter][104] and [LSP][7] via [nvim-lspconfig][8]. +Even though Neovim divides more and more from Vim through specific features like first-class Lua support with custom APIs, the highlighting for tree-sitter is achieved through “normal“ syntax highlighting groups. Most of the groups are already [linked by the `nvim-treesitter` plugin by default][103] so only a few groups have been adjusted for now to fit the Nord style. ⚠️ Note that this is the first iteration and **it is very likely that there will be inconsistencies compared to the current highlighting when using “normal“ Vim plugins per language**. Please **report any problem** you find so that the support for tree-sitter can be improved continuously! @@ -80,7 +167,7 @@ Even though Neovim divides more and more from Vim through specific features like ![Release Date: 2021-06-09](https://img.shields.io/static/v1.svg?style=flat-square&label=Release%20Date&message=2021-06-09&colorA=4c566a&colorB=88c0d0) [![Project Board](https://img.shields.io/static/v1.svg?style=flat-square&label=Project%20Board&message=0.16.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/projects/22) [![Milestone](https://img.shields.io/static/v1.svg?style=flat-square&label=Milestone&message=0.16.0&logo=github&logoColor=eceff4&colorA=4c566a&colorB=88c0d0)](https://github.com/arcticicestudio/nord-vim/milestone/18) -⇅ [Show all commits][gh-compare-tag-v0.15.0_v0.16.0] +⇅ [Show all commits][88] ## Features @@ -89,7 +176,7 @@ Even though Neovim divides more and more from Vim through specific features like
Public API function NordPalette to get Nord colors — #224 (⊶ 5867535c) by @jandamm -↠ Implemented a new `NordPalette` pubic API function that returns all [Nord colors][docs-colors] as dictionary. This allows to use the colors in other Vim scripts without the need to copy & paste the colors from the documentations or the [Nord Vim theme sources][blob-master-colors/nord.vim]. +↠ Implemented a new `NordPalette` pubic API function that returns all [Nord colors][87] as dictionary. This allows to use the colors in other Vim scripts without the need to copy & paste the colors from the documentations or the [Nord Vim theme sources][85].
@@ -98,10 +185,10 @@ Even though Neovim divides more and more from Vim through specific features like
Support for the php.vim plugin — #218, #262 ⇄ #263 (⊶ b3c46c87, 07452c71) by @pirey -↠ In [arcticicestudio/nord-vim#218][] new highlighting groups for the bundled PHP syntax were added to improve the highlighting of classes, function and methods and the overall syntax token detection, but they are actually defined by the [php.vim][stanangeloff/php.vim] plugin. Therefore the added highlighting calls have been moved to a plugin section. +↠ In [arcticicestudio/nord-vim#218][84] new highlighting groups for the bundled PHP syntax were added to improve the highlighting of classes, function and methods and the overall syntax token detection, but they are actually defined by the [php.vim][98] plugin. Therefore the added highlighting calls have been moved to a plugin section. Additionally, the `phpClassExtends` and `phpClassImplements` groups have been added to improve the highlighting for classes that implement or extended interfaces/classes. The `phpUseClass` has also been added to improve the highlighting for imports. -To improve the highlighting with the bundled PHP syntax, the [following options][vim-docs#php_syntax] can be set: +To improve the highlighting with the bundled PHP syntax, the [following options][99] can be set: ```vim let php_asp_tags = 1 @@ -122,12 +209,12 @@ let php_parent_error_open = 1
Conceal highlighting group support — #149, #207, #211, #256 ⇄ #261 (⊶ f3f28b93) -↠ The `Conceal` group is was not supported which could resulted in rendering problems for (Unicode) characters that require special encoding like the ones from the [Greek alphabet][wikip-greek_alphabet] and [mathematical expressions][overleaf-latex-learn-math_expr] that are often used in [LaTeX][latex] or [Pandoc][pandoc] documents. These characters were highlighted with the default background color which made them kind of unreadable with the theme foreground color. +↠ The `Conceal` group is was not supported which could resulted in rendering problems for (Unicode) characters that require special encoding like the ones from the [Greek alphabet][100] and [mathematical expressions][97] that are often used in [LaTeX][92] or [Pandoc][9] documents. These characters were highlighted with the default background color which made them kind of unreadable with the theme foreground color. See `:help conceal` and `:help concealcursor` for more details about concealing in Vim. To fix the problem, the `Conceal` group has been added with its background color set to `NONE` for GUI and terminal mode to either use the terminal default background color or let loaded scripts apply custom styles based on the current runtime context. -The problem has been reported in #149, #207 and #211 with LaTeX and Pandoc being used by the reporters. PR #220 adds support for [vim-pandoc/vim-pandoc-syntax][vim-pandoc/vim-pandoc-syntax] specific highlighting groups and can be merged after adding basic support for `Conceal`. +The problem has been reported in #149, #207 and #211 with LaTeX and Pandoc being used by the reporters. PR #220 adds support for [vim-pandoc/vim-pandoc-syntax][13] specific highlighting groups and can be merged after adding basic support for `Conceal`. To get the correct rendering for such elements the following configurations must be set: @@ -147,13 +234,13 @@ set conceallevel=2
Updated highlights for Neovim LSP diagnostics — #229, #248 (⊶ a3af928a) by @gbrlsnchs and @thallium -↠ To ensure compatibility with the latest versions of Neovim LSP the highlighting groups for diagnostics have been adapted to the changes of [neovim/neovim#12655][]. -See [`:help lsp-highlight-diagnostics`][neovim-docs-lsp] for more details. +↠ To ensure compatibility with the latest versions of Neovim LSP the highlighting groups for diagnostics have been adapted to the changes of [neovim/neovim#12655][96]. +See [`:help lsp-highlight-diagnostics`][7] for more details. -Note that LSP will be available as of [Neovim 0.5][neovim/neovim-ms#19] which is (at the time of this commit) still in development and only available as nightly build. -Also see great articles from Nord Vim contributors like [“Neovim (0.5) Is Overpowering“][crispgm-blog-neovim_overpowering] for more information about Neovim 0.5 features, including LSP. +Note that LSP will be available as of [Neovim 0.5][95] which is (at the time of this commit) still in development and only available as nightly build. +Also see great articles from Nord Vim contributors like [“Neovim (0.5) Is Overpowering“][86] for more information about Neovim 0.5 features, including LSP. -Thanks to [@clason][gh-user-clason], [@crispgm][gh-user-crispgm] and [@ojroques][gh-user-ojroques] for the review support! +Thanks to [@clason][89], [@crispgm][90] and [@ojroques][91] for the review support!
@@ -162,8 +249,8 @@ Thanks to [@clason][gh-user-clason], [@crispgm][gh-user-crispgm] and [@ojroques]
Support for the vim-indent-guides plugin — #186 ⇄ #226 (⊶ ea7ff9c3) by @mitinarseny -↠ Added support for the [vim-indent-guides][nathanaelkane/vim-indent-guides] plugin. The even and odd highlighting blocks using `nord1` and `nord2` (`nord3`in terminal mode) to provide a subtle and non-disturbing style. -Note that the [custom theme colors][nathanaelkane/vim-indent-guides#custom_color] are only applied when the `indent_guides_auto_colors` variable has been set to `0`: +↠ Added support for the [vim-indent-guides][93] plugin. The even and odd highlighting blocks using `nord1` and `nord2` (`nord3`in terminal mode) to provide a subtle and non-disturbing style. +Note that the [custom theme colors][94] are only applied when the `indent_guides_auto_colors` variable has been set to `0`: ```vim let g:indent_guides_auto_colors = 0 @@ -184,7 +271,7 @@ let g:indent_guides_auto_colors = 0
coc.vim error and warning highlighting — #213 (⊶ 8a9754ce) by @butterywombat -↠ Added the [coc.nvim][nathanaelkane/vim-indent-guides] highlighting groups for errors and warnings using their respective foreground colors and the `undercurl` font style. +↠ Added the [coc.nvim][6] highlighting groups for errors and warnings using their respective foreground colors and the `undercurl` font style.
@@ -200,7 +287,7 @@ let g:indent_guides_auto_colors = 0 - `PMenuSel` -> `PmenuSel` - `PMenu` -> `Pmenu` -This mismatch was never really noticed because most of the time users rely on plugins like [coc.vim][neoclide/coc.nvim] or [vim-clap][liuchengxu/vim-clap] which come with custom highlighting groups and UI libraries. +This mismatch was never really noticed because most of the time users rely on plugins like [coc.vim][6] or [vim-clap][5] which come with custom highlighting groups and UI libraries.
@@ -212,9 +299,9 @@ This mismatch was never really noticed because most of the time users rely on pl ### Syntax -**Extended support for TypeScript and TSX** — #208 (⊶ 1bd44ade) by [@iamdidev][gh-user-iamdidev] -↠ Added extended support for [TypeScript][] and [TSX][ts-docs-jsx] through the [yats.vim][herringtonharkholme/yats.vim] plugin. -This provides, among many other good changes, better highlighting for syntax elements like [decorators][ts-docs-decorators], more granular separation of different language elements within a single code line as well as highlighting for… +**Extended support for TypeScript and TSX** — #208 (⊶ 1bd44ade) by [@iamdidev][78] +↠ Added extended support for [TypeScript][83] and [TSX][82] through the [yats.vim][80] plugin. +This provides, among many other good changes, better highlighting for syntax elements like [decorators][81], more granular separation of different language elements within a single code line as well as highlighting for…

…interfaces with bold font style, typing characters and types.

@@ -236,8 +323,8 @@ This provides, among many other good changes, better highlighting for syntax ele ### UI -**Support for vim-clap** — #178 (⊶ 7a52f66c) by [@meck][gh-user-meck] and [@ikalnytskyi][gh-user-ikalnytskyi] -↠ Added basic support for [vim-clap][liuchengxu/vim-clap], a modern and performant generic finder and dispatcher for Vim and NeoVim. +**Support for vim-clap** — #178 (⊶ 7a52f66c) by [@meck][44] and [@ikalnytskyi][79] +↠ Added basic support for [vim-clap][5], a modern and performant generic finder and dispatcher for Vim and NeoVim.

@@ -249,14 +336,14 @@ This provides, among many other good changes, better highlighting for syntax ele ### UI -**Basic support for nvim-lsp (Language Server Protocol)** — #198 (⊶ 0ccf70b6) by [@alexanderjeurissen][gh-user-alexanderjeurissen] -↠ Added basic support for [nvim-lsp][neovim/nvim-lsp], a collection of common configurations for the NVim language server protocol client. +**Basic support for nvim-lsp (Language Server Protocol)** — #198 (⊶ 0ccf70b6) by [@alexanderjeurissen][74] +↠ Added basic support for [nvim-lsp][76], a collection of common configurations for the NVim language server protocol client. ## Improvements ### UI -**Consistent error highlighting between GUI and terminal mode** — #202 (⊶ 974a9190) by [@xulongwu4][gh-user-xulongwu4] +**Consistent error highlighting between GUI and terminal mode** — #202 (⊶ 974a9190) by [@xulongwu4][75] ↠ The highlighting of errors in GUI and _true color_ terminal mode now also uses `nord4` as foreground color of instead of `nord0`.

Before

@@ -264,7 +351,7 @@ This provides, among many other good changes, better highlighting for syntax ele

After

-**Improved highlighting for “More“ separator** — #202 (⊶ 974a9190) by [@xulongwu4][gh-user-xulongwu4] +**Improved highlighting for “More“ separator** — #202 (⊶ 974a9190) by [@xulongwu4][75] ↠ The highlighting of the _More_ separator is now highlighted with the `nord8` accent color.

Before

@@ -272,8 +359,8 @@ This provides, among many other good changes, better highlighting for syntax ele

After

-**Transparent line number and cursor line background by default** — #204 (⊶ 6323f662) by [@xulongwu4][gh-user-xulongwu4] -↠ Before the background color of the `LineNr` and `CursorLineNr` highlighting groups were set to `nord0` which was fine in most cases, but conflicted with plugins like [Yggdroot/LeaderF][] that renders line numbers in a popup windows with a different background color. +**Transparent line number and cursor line background by default** — #204 (⊶ 6323f662) by [@xulongwu4][75] +↠ Before the background color of the `LineNr` and `CursorLineNr` highlighting groups were set to `nord0` which was fine in most cases, but conflicted with plugins like [Yggdroot/LeaderF][77] that renders line numbers in a popup windows with a different background color.

Before

@@ -288,8 +375,8 @@ This provides, among many other good changes, better highlighting for syntax ele ### UI -**Support uniform status line background configuration for _vim-airline_ and _lightline.vim_ themes** — #168 ⇄ #169 (⊶ 73b3d340) by [@jmurinello][gh-user-jmurinello] -↠ Added support for the [uniform status line][nord-config-port-vim#uni_st_line] theme configuration, [introduced in version 0.7.0][gh-rel-v0.7.0] through [arcticicestudio/nord-vim#58][], for the bundled _vim-airline_ and _lightline.vim_ themes. +**Support uniform status line background configuration for _vim-airline_ and _lightline.vim_ themes** — #168 ⇄ #169 (⊶ 73b3d340) by [@jmurinello][66] +↠ Added support for the [uniform status line][73] theme configuration, [introduced in version 0.7.0][63] through [arcticicestudio/nord-vim#58][62], for the bundled _vim-airline_ and _lightline.vim_ themes.

lightline.vim

Before

@@ -303,11 +390,11 @@ This provides, among many other good changes, better highlighting for syntax ele

After

-**Basic support for coc.vim (Conquer of Completion)** — #164 (⊶ a7797269) by [@hennessey][gh-user-hennessey] -↠ Added basic support for [coc.nvim][neoclide/coc.nvim], a _Intellisense_ engine for Vim 8 & NeoVim with full language server protocol support. +**Basic support for coc.vim (Conquer of Completion)** — #164 (⊶ a7797269) by [@hennessey][65] +↠ Added basic support for [coc.nvim][6], a _Intellisense_ engine for Vim 8 & NeoVim with full language server protocol support. **Basic support for _vim-startify_** — #159 ⇄ #176 (⊶ 38ab4a9c) -↠ Added basic support for [vim-startify][mhinz/vim-startify] with custom highlight groups. +↠ Added basic support for [vim-startify][69] with custom highlight groups.

@@ -315,8 +402,8 @@ This provides, among many other good changes, better highlighting for syntax ele ### UI -**No underlined style for gutter line numbers** — #174 ⇄ #185 (⊶ 0d352c4b) by [@nixtrace][gh-user-nixtrace] and [@alexandremjacques][gh-user-alexandremjacques] -↠ [Vim version 8.1.2029][vim/vim-rel-v8.1.2029] added the [`underline` attribute for the `CursorLineNr` group to `cterm`][vim/vim-diff#d9b0d83b...017ba07f] based on [vim/vim#4933][]. +**No underlined style for gutter line numbers** — #174 ⇄ #185 (⊶ 0d352c4b) by [@nixtrace][67] and [@alexandremjacques][64] +↠ [Vim version 8.1.2029][71] added the [`underline` attribute for the `CursorLineNr` group to `cterm`][70] based on [vim/vim#4933][72]. This change resulted in gutter line numbers being underlined which has now been reverted back to Nord's style by explicitly setting the attribute for the group to `NONE`.

Before

@@ -329,7 +416,7 @@ This change resulted in gutter line numbers being underlined which has now been ### Documentation -**Fix missing whitespace** — #165 (⊶ 81d80e4a) by [@vasilescur][gh-user-vasilescur] +**Fix missing whitespace** — #165 (⊶ 81d80e4a) by [@vasilescur][68] ↠ Fixed a missing whitespace in the README project description. # 0.12.0 @@ -339,8 +426,8 @@ This change resulted in gutter line numbers being underlined which has now been ## Features **Nord Docs Transition** — #158, #144 ⇄ #160 (⊶ 7be26147) -↠ Transferred all documentations, assets and from „Nord Vim“ to [Nord Docs][nord] -Please see the [corresponding issue in the Nord Docs repository][nord-docs#143] to get an overview of what has changed for Nord Vim and what has been done to migrate to Nord Docs. +↠ Transferred all documentations, assets and from „Nord Vim“ to [Nord Docs][1] +Please see the [corresponding issue in the Nord Docs repository][60] to get an overview of what has changed for Nord Vim and what has been done to migrate to Nord Docs. ###### Landing Page @@ -362,15 +449,15 @@ Please see the [corresponding issue in the Nord Docs repository][nord-docs#143]

Preview: Nord Vim Docs Configuration Docs Page

-**Theme configuration for bold font style rendering** — #143 ⇄ #161 (⊶ 18a4e350) requested by [@tobydeh][gh-user-tobydeh] -↠ Added a new [`nord_bold` theme configuration to allow to explicitly toggle bold font rendering styles][nord-docs-config-font-bold]. +**Theme configuration for bold font style rendering** — #143 ⇄ #161 (⊶ 18a4e350) requested by [@tobydeh][59] +↠ Added a new [`nord_bold` theme configuration to allow to explicitly toggle bold font rendering styles][61]. It is enabled by default when running for both in GUI and terminal mode since most terminals and shells are capable to handle bold fonts.

## Improvements -**Active match for increment search** — #139 ⇄ #140 (⊶ de24841a) by [@aborzunov][gh-user-aborzunov] +**Active match for increment search** — #139 ⇄ #140 (⊶ de24841a) by [@aborzunov][58] ↠ The currently active match during increment searches (`IncSearch`) is now highlighted differently (`nord10` as background and `nord6` as foreground) than inactive matches for a better visual distinction.

@@ -383,28 +470,28 @@ It is enabled by default when running for both in GUI and terminal mode since mo ### Syntax -**Basic support for Asciidoc syntax highlighting** — #131 ⇄ #152 (⊶ 6e6025b9) by [@tidux][gh-user-tidux] -↠ Added basic syntax highlighting support for [Asciidoc][] that comes bundled with Vim 8. +**Basic support for Asciidoc syntax highlighting** — #131 ⇄ #152 (⊶ 6e6025b9) by [@tidux][46] +↠ Added basic syntax highlighting support for [Asciidoc][39] that comes bundled with Vim 8.

-**Basic syntax highlighting support for Rust** — #138 ⇄ #154 (⊶ b0ffc6b5) by [@TerminalWitchcraft][gh-user-terminalwitchcraft] -↠ Added basic syntax highlighting support for [Rust][]. +**Basic syntax highlighting support for Rust** — #138 ⇄ #154 (⊶ b0ffc6b5) by [@TerminalWitchcraft][45] +↠ Added basic syntax highlighting support for [Rust][55]. -[Traits][rustdoc-traits] and [enums][rustdoc-enums] are colorized with `nord7` and with bold font to make them visually stand out more. -Also [attributes][rustdoc-attributes] and [derives][rustdoc-derives] are colored with `nord10`. +[Traits][54] and [enums][51] are colorized with `nord7` and with bold font to make them visually stand out more. +Also [attributes][49] and [derives][50] are colored with `nord10`.

Before

After

-[Macros][rustdoc-macros] are colorized with `nord8` and bold font to make them visually different from "normal" functions. +[Macros][53] are colorized with `nord8` and bold font to make them visually different from "normal" functions.

Before

After

-[Escape][rustdoc-escapes] sequences are colored with `nord13`. +[Escape][52] sequences are colored with `nord13`.

Before

@@ -418,8 +505,8 @@ Import statements and paths are correctly colored with keyword and type colors. #### Plugin Support -**Haskell Syntax Plugin Support** — #104 ⇄ #150 (⊶ b0ffc6b5) by [@vabatta][gh-user-vabatta] -↠ Added support for Haskell syntax through the [neovimhaskell/haskell-vim][] plugin. +**Haskell Syntax Plugin Support** — #104 ⇄ #150 (⊶ b0ffc6b5) by [@vabatta][47] +↠ Added support for Haskell syntax through the [neovimhaskell/haskell-vim][48] plugin. This includes better coloring for types/classes using `nord7` instead of highlighting them like keywords (`nord9`) and pre-processor and pragma elements are now colorized correctly with `nord10`. #### Pragma @@ -442,8 +529,8 @@ This includes better coloring for types/classes using `nord7` instead of highlig ### UI -**Theme config for bolder vertical split line** — #132 ⇄ #153 (⊶ 9059d7d8) by [@huyvohcmc][gh-user-huyvohcmc] -↠ Previously the [`VertSplit`][vdoc-vsplit] (`:help VertSplit`) key used `nord1` as background color by default making the line appear to be very lumpy. This has now been changed to use `nord0` as background instead to visually merge with the background so only the separator characters are a visual indicator for the split line which makes it look more lightweight and declutters the overall appearance. +**Theme config for bolder vertical split line** — #132 ⇄ #153 (⊶ 9059d7d8) by [@huyvohcmc][42] +↠ Previously the [`VertSplit`][57] (`:help VertSplit`) key used `nord1` as background color by default making the line appear to be very lumpy. This has now been changed to use `nord0` as background instead to visually merge with the background so only the separator characters are a visual indicator for the split line which makes it look more lightweight and declutters the overall appearance.

With base editor background (default)

@@ -455,12 +542,12 @@ To allow user who liked the previous implementation to keep the style a new `nor let g:nord_bold_vertical_split_line = 1 ``` -The README includes information and hints how to change the separator character by customizing Vim's [`fillchars`][vdoc-fchar] (`:help fillchars`) variable. +The README includes information and hints how to change the separator character by customizing Vim's [`fillchars`][56] (`:help fillchars`) variable. #### Plugin Support -**`:terminal` status line in airline** — #134 (⊶ be815f09) by [@meck][gh-user-meck] -↠ Added support for Vim's new `:terminal` mode in [airline][gh-src-airline]. +**`:terminal` status line in airline** — #134 (⊶ be815f09) by [@meck][44] +↠ Added support for Vim's new `:terminal` mode in [airline][4].

Before: No :terminal support (before)

@@ -470,8 +557,8 @@ The README includes information and hints how to change the separator character ### Syntax -**Better generator expressions in CMake** — #137 ⇄ #151 (⊶ d2774cbb) by [@markand][gh-user-markand] -↠ [CMake generator expressions][cmake-doc-genexpr] are now highlighted using `nord10` as foreground instead of `nord13` as background and `nord0` as foreground. +**Better generator expressions in CMake** — #137 ⇄ #151 (⊶ d2774cbb) by [@markand][43] +↠ [CMake generator expressions][40] are now highlighted using `nord10` as foreground instead of `nord13` as background and `nord0` as foreground.

Before

@@ -481,15 +568,15 @@ The README includes information and hints how to change the separator character #### Plugin Support -**airline warnings and errors** — #130 (⊶ e85dbe75) by [@axelitus][gh-user-axelitus] -↠ Added support for error and warning elements of [airline][gh-src-airline]. +**airline warnings and errors** — #130 (⊶ e85dbe75) by [@axelitus][41] +↠ Added support for error and warning elements of [airline][4].

Before

After

-**ALE error and warning support** — #135 (⊶ 9d82b7a1) by [@meck][gh-user-meck] -↠ Added support highlighting and underlines for [ALE][plugin-ale] errors and warnings to also align the style with gutter signs. +**ALE error and warning support** — #135 (⊶ 9d82b7a1) by [@meck][44] +↠ Added support highlighting and underlines for [ALE][10] errors and warnings to also align the style with gutter signs. # 0.10.0 @@ -497,7 +584,7 @@ The README includes information and hints how to change the separator character ## Features -**Vim 8 terminal highlighting** — #125 ⇄ #126 (⊶ 83f8c260) by [@cg433n][gh-user-cg433n] +**Vim 8 terminal highlighting** — #125 ⇄ #126 (⊶ 83f8c260) by [@cg433n][38] ↠ Added support for the Vim's built-in terminal (`:terminal`) that comes with version 8.0.0 and higher. ## Improvements @@ -505,16 +592,16 @@ The README includes information and hints how to change the separator character **Comment Color Brightness** — #145 ⇄ #146 (⊶ 9e0249ca) ↠ Implemented the increase of the comment color (`nord3`) brightness by 10% from a lightness level of ~35% to ~45%. -➜ **Please see [arcticicestudio/nord#94][gh-nord#94] for all details about this design change decision**! +➜ **Please see [arcticicestudio/nord#94][36] for all details about this design change decision**! -⚠ **NOTE**: This change also **deprecates the [comment contrast][readme-config-comment-brightness] configuration** that will be removed in Nord Vim version 1.0.0! +⚠ **NOTE**: This change also **deprecates the [comment contrast][11] configuration** that will be removed in Nord Vim version 1.0.0! The default comment color has been adjusted so the configuration is not required anymore for users to increase the brightness on their own. To notify users about this change a deprecation warning will be shown when the `g:nord_comment_brightness` configuration variable has been set and initialized through the user's configuration. **Improved compatibility of airline with tmuxline.vim plugin** — #117 ⇄ #128 (⊶ 3150628f) -↠ The [Nord airline.vim][gh-src-airline] UI plugin theme now includes better support for the [tmuxline.vim][gh-tmuxline.vim] plugin. Previously text shown in the main segment of the _tmuxline_, generated via the `:Tmuxline airline` command, caused a `bad colour: NONE` error or has been colorized using `nord0` which resulted in unreadable text due to a `nord3` background. +↠ The [Nord airline.vim][4] UI plugin theme now includes better support for the [tmuxline.vim][37] plugin. Previously text shown in the main segment of the _tmuxline_, generated via the `:Tmuxline airline` command, caused a `bad colour: NONE` error or has been colorized using `nord0` which resulted in unreadable text due to a `nord3` background. -This has been fixed by using `nord5` as foreground color. …[#11][gh-11] was used as implementation reference since it fixed the same incompatibility for the [lightline.vim][gh-lightline.vim] plugin. +This has been fixed by using `nord5` as foreground color. …[#11][34] was used as implementation reference since it fixed the same incompatibility for the [lightline.vim][35] plugin. ![](https://user-images.githubusercontent.com/7836623/41835439-e3f2388c-7857-11e8-91e0-a0440b7ecf35.png) @@ -528,19 +615,19 @@ This has been fixed by using `nord5` as foreground color. …[#11][gh-11] was us #### Plugin Support -❯ Added support for the [YAML][] plugin [stephpy/vim-yaml][plugin-stephpy/vim-yaml] which improves the highlighting for keys to match the JSON syntax style. (PR #120, @mdzhang, b1478b07) +❯ Added support for the [YAML][33] plugin [stephpy/vim-yaml][29] which improves the highlighting for keys to match the JSON syntax style. (PR #120, @mdzhang, b1478b07)

Before

After

-❯ Added basic syntax highlighting support for [vimwiki][plugin-vimwiki/vimwiki]. (PR #98 in PR #114, @smesko85, 9e7addbc) +❯ Added basic syntax highlighting support for [vimwiki][30]. (PR #98 in PR #114, @smesko85, 9e7addbc)

### UI -❯ Added a new [configuration to allow users to enable background for the line number of the current line][readme-config-line-number-background]. It can be enabled by setting the `g:nord_cursor_line_number_background` variable to `1`. (PR #100, @andrepolischuk, 035e36de) +❯ Added a new [configuration to allow users to enable background for the line number of the current line][31]. It can be enabled by setting the `g:nord_cursor_line_number_background` variable to `1`. (PR #100, @andrepolischuk, 035e36de) ```vim let g:nord_cursor_line_number_background = 1 @@ -550,7 +637,7 @@ let g:nord_cursor_line_number_background = 1

Enabled background

-❯ Added a new [configuration to allow users to globally toggle underlines][readme-config-underline-support] for cases where the terminal emulator might not be capable to handle underlines in terminal mode. It can be enabled by setting the `g:nord_underline` variable to `1`. (#106 in PR #127 (supersedes #109), @dylnmc @markand , 01cfd1be) +❯ Added a new [configuration to allow users to globally toggle underlines][32] for cases where the terminal emulator might not be capable to handle underlines in terminal mode. It can be enabled by setting the `g:nord_underline` variable to `1`. (#106 in PR #127 (supersedes #109), @dylnmc @markand , 01cfd1be)

Underlined Text

@@ -562,7 +649,7 @@ let g:nord_cursor_line_number_background = 1 #### Plugin Support -❯ Added highlighting support for the navigation marks in the sign column of the [kshenoy/vim-signature][plugin-kshenoy/vim-signature] plugin. (PR #122, @kooparse, 1df39453) +❯ Added highlighting support for the navigation marks in the sign column of the [kshenoy/vim-signature][28] plugin. (PR #122, @kooparse, 1df39453)

@@ -580,7 +667,7 @@ let g:nord_cursor_line_number_background = 1 ❯ The cursor is now correctly shown and visible when leaving a terminal window from within Vim or Neovim by adding the `TermCursorNC` group. (PR #101, @meck, 2fac9fa0) -❯ The „inline marker“ in unified _diffs_ is now colorized differently than the background of the changed line to make the changes better and faster recognizable. This applies for both the [uniform _diff_ background mode][readme-config-uniform-diff-background] and normal _diff_ mode. (PR #121, @ironhouzi, 65c559ee) +❯ The „inline marker“ in unified _diffs_ is now colorized differently than the background of the changed line to make the changes better and faster recognizable. This applies for both the [uniform _diff_ background mode][12] and normal _diff_ mode. (PR #121, @ironhouzi, 65c559ee)

Before/After comparison of default diff mode


@@ -606,7 +693,7 @@ let g:nord_cursor_line_number_background = 1 #### UI -❯ Added support for [vim-signify][plugin-mhinz/vim-signify]. (PR #81, @dabio, edcdd0e4) +❯ Added support for [vim-signify][27]. (PR #81, @dabio, edcdd0e4)

@@ -622,7 +709,7 @@ let g:nord_cursor_line_number_background = 1 ### Documentation -❯ The lightline screenshots in the documentation have been made using the [lightline's advanced configurations][itchyny/lightline-adv-config]. This confused users when the lighline does not equal the one seen on the screenshot due to the default lightline configuration. This has now been clarified including a additional screenshot showing the appearance of the lightline when using the default configuration. (#74 in PR #94, @lokesh-krishna, 3c14c961) +❯ The lightline screenshots in the documentation have been made using the [lightline's advanced configurations][26]. This confused users when the lighline does not equal the one seen on the screenshot due to the default lightline configuration. This has now been clarified including a additional screenshot showing the appearance of the lightline when using the default configuration. (#74 in PR #94, @lokesh-krishna, 3c14c961)

@@ -640,7 +727,7 @@ let g:nord_cursor_line_number_background = 1 ## Features -❯ Added a new [configuration to allow users to increase the comment brightness][readme-config-comment-brightness] by 1 - 20 percent. It can be enabled by setting the `g:nord_comment_brightness variable` to a number between `1` and `20`. (#48 in PR #56, @drzel, e18ab4e8) +❯ Added a new [configuration to allow users to increase the comment brightness][11] by 1 - 20 percent. It can be enabled by setting the `g:nord_comment_brightness variable` to a number between `1` and `20`. (#48 in PR #56, @drzel, e18ab4e8) **This option should only be enabled if the terminal supports 24bit true color (16 million colors) and requires the `termguicolors` option to be set is in `~/.vimrc` or via `:set termguicolors`!** @@ -650,7 +737,7 @@ let g:nord_cursor_line_number_background = 1 To adhere to the Nord design guidelines this option uses `nord3` by default. -This is a reference table if users like to use the same increased contrast values as provided by the [Nord Atom Syntax accessibility custom comment contrast theme setting][nord-atom-syntax-pr-47] which are calculated using the LESSCSS [`lighten`][lesscss-doc-fn-lighten] function. +This is a reference table if users like to use the same increased contrast values as provided by the [Nord Atom Syntax accessibility custom comment contrast theme setting][19] which are calculated using the LESSCSS [`lighten`][18] function. | Increased by | Calculated value | | ------------ | ---------------- | @@ -675,9 +762,9 @@ This is a reference table if users like to use the same increased contrast value | 19% | `#78859e` | | 20% | `#7b88a1` | -More information about true color and the support in various terminals can be found in [this gist][gist-colors-in-terminals]. +More information about true color and the support in various terminals can be found in [this gist][16]. -❯ Added a new [configuration for a uniform _diff_ background color][readme-config-uniform-diff-background]. (#60 in PR #61 #62 #65, @dylnmc @aidanharris @berkin, 958322d0) +❯ Added a new [configuration for a uniform _diff_ background color][12]. (#60 in PR #61 #62 #65, @dylnmc @aidanharris @berkin, 958322d0) ![](https://user-images.githubusercontent.com/7836623/30969227-0dbcb982-a462-11e7-86a8-a69e91ff7bc0.png) @@ -685,13 +772,13 @@ Setting `g:nord_uniform_diff_background` to `1` enables the uniform diff backgro ![](https://user-images.githubusercontent.com/7836623/30969233-12a37d64-a462-11e7-8253-3c083eba5174.png) -❯ Added a new [configuration to use uniform activate- and inactive status line backgrounds][readme-config-uniform-statusline-background]. (#37 in PR #58, @dylnmc @DenniJensen, 93056802) +❯ Added a new [configuration to use uniform activate- and inactive status line backgrounds][24]. (#37 in PR #58, @dylnmc @DenniJensen, 93056802)

Default status lines

Uniform status lines

-❯ Added a new [configuration to explicitly enable italic text formatting][readme-config-italic]. (#88 in PR #89, @lokesh-krishna @dylnmc, dbfc55ff) +❯ Added a new [configuration to explicitly enable italic text formatting][23]. (#88 in PR #89, @lokesh-krishna @dylnmc, dbfc55ff) **Please note that this option should only be enabled if the used terminal supports italics!** @@ -705,7 +792,7 @@ Setting `g:nord_uniform_diff_background` to `1` enables the uniform diff backgro #### Syntax -❯ Added support for the [plasticboy/vim-markdown][plugin-plasticboy/vim-markdown] syntax plugin to match the style of the built-in markdown syntax styles. (#45 in PR #57, @VVVFO, 09921268) +❯ Added support for the [plasticboy/vim-markdown][21] syntax plugin to match the style of the built-in markdown syntax styles. (#45 in PR #57, @VVVFO, 09921268) ![](https://user-images.githubusercontent.com/7836623/30773618-63ffde56-a074-11e7-9452-121283afcb44.png) @@ -713,13 +800,13 @@ Setting `g:nord_uniform_diff_background` to `1` enables the uniform diff backgro #### UI -❯ Added support for the `PlugClean` command of the [junegunn/vim-plug][plugin-junegunn/vim-plug] plugin which used the `Ignore` group by default for deleted directory listings resulting in unreadable text when `cursorline` has been set. (#43 in PR #59, @dylnmc, e532b5d6) +❯ Added support for the `PlugClean` command of the [junegunn/vim-plug][20] plugin which used the `Ignore` group by default for deleted directory listings resulting in unreadable text when `cursorline` has been set. (#43 in PR #59, @dylnmc, e532b5d6)

Before

After

-❯ Added basic support for [tpope/vim-fugitive][plugin-tpope/vim-fugitive]. (#76 in PR #77, @anhari, fa09c3b1) +❯ Added basic support for [tpope/vim-fugitive][22]. (#76 in PR #77, @anhari, fa09c3b1) Filenames are now highlighted when using the `:Gstatus` command. @@ -731,7 +818,7 @@ Filenames are now highlighted when using the `:Gstatus` command. ❯ Added highlight support for legacy _diff_ groups `diffAdded` and `diffRemoved` of the `git.vim` and `diff.vim` syntx definitions. (#66 in PR #67, @brandoniffert, 99e59e67) -These groups are not in the [official vim documentation][vim-doc-diffadd] but are still used by the syntax for example when run with `git commit --verbose`. +These groups are not in the [official vim documentation][25] but are still used by the syntax for example when run with `git commit --verbose`.

Before

@@ -781,11 +868,11 @@ To optimally improve the highlighting `nord3` will now be used as background col ## Tasks -❯ Added the included [lightline theme to the official lightline repository][itchyny/lightline.vim-gh-257]. (#68 in [itchyny/lightline#257][itchyny/lightline.vim-gh-257], @lokesh-krishna, itchyny/lightline@e69081c1370a57647e05df21b60a4ef092c3ce91) +❯ Added the included [lightline theme to the official lightline repository][17]. (#68 in [itchyny/lightline#257][17], @lokesh-krishna, itchyny/lightline@e69081c1370a57647e05df21b60a4ef092c3ce91) ### Documentation -❯ Migrated to the MIT license to adapt to the migration of the main [Nord][nord-gh] project. Detailed information can be found in the [main task ticket][gh-55-arcticicestudio/nord]. (#69 in PR #70, fa55dc35) +❯ Migrated to the MIT license to adapt to the migration of the main [Nord][3] project. Detailed information can be found in the [main task ticket][15]. (#69 in PR #70, fa55dc35) # 0.6.0 @@ -797,12 +884,12 @@ To optimally improve the highlighting `nord3` will now be used as background col #### UI -❯ Added basic support for [CtrlP][plugin-ctrlp]. (PR #33, @syedelec) +❯ Added basic support for [CtrlP][14]. (PR #33, @syedelec) - Matched characters are using the keyword color instead of the normal text color to make matched characters visible - Already opened buffers now take the normal text color instead of the comment color -❯ Added basic support [ALE][plugin-ale]. (PR #44, @meck) +❯ Added basic support [ALE][10]. (PR #44, @meck) - Warning signs are colorized using a `nord13` foreground - Error signs are colorized using a `nord11` foreground instead of a red background with a white foreground @@ -900,7 +987,7 @@ let g:nord_italic_comments = 1 ### Plugin Support -❯ The [Nord lightline.vim][nord-lightline] UI plugin theme now includes better support for the [tmuxline.vim](https://github.com/edkolev/tmuxline.vim) plugin. Before this implementation text shown in the main segment of the tmuxline, generated via the `:Tmuxline lightline` command, has been colorized using `nord0` which resulted in unreadable text due to a `nord3` background. +❯ The [Nord lightline.vim][2] UI plugin theme now includes better support for the [tmuxline.vim](https://github.com/edkolev/tmuxline.vim) plugin. Before this implementation text shown in the main segment of the tmuxline, generated via the `:Tmuxline lightline` command, has been colorized using `nord0` which resulted in unreadable text due to a `nord3` background. This has been fixed by using `nord5` as foreground color. (@scottwillmoore, #11, 4ea37f7e)

Before

After

With unicode separators

Without specified configurations (tmuxline.vim autodetect)

@@ -990,139 +1077,169 @@ otherwise Markdown elements are not parsed and rendered! + + +[1]: https://www.nordtheme.com +[2]: https://github.com/arcticicestudio/nord-vim/blob/develop/autoload/lightline/colorscheme/nord.vim +[3]: https://github.com/arcticicestudio/nord + -[asciidoc]: https://asciidoctor.org -[gh-11]: https://github.com/arcticicestudio/nord-vim/issues/11 -[gh-55-arcticicestudio/nord]: https://github.com/arcticicestudio/nord/issues/55 -[gh-lightline.vim]: https://github.com/itchyny/lightline.vim -[gh-nord#94]: https://github.com/arcticicestudio/nord/issues/94 -[gh-src-airline]: https://github.com/arcticicestudio/nord-vim/blob/develop/autoload/airline/themes/nord.vim -[gh-tmuxline.vim]: https://github.com/edkolev/tmuxline.vim -[gh-user-cg433n]: https://github.com/cg433n -[gist-colors-in-terminals]: https://gist.github.com/XVilka/8346728 -[itchyny/lightline-adv-config]: https://github.com/itchyny/lightline.vim#advanced-configuration -[itchyny/lightline.vim-gh-257]: https://github.com/itchyny/lightline.vim/pull/257 -[lesscss-doc-fn-lighten]: http://lesscss.org/functions/#color-operations-lighten -[liuchengxu/vim-clap]: https://github.com/liuchengxu/vim-clap -[neoclide/coc.nvim]: https://github.com/neoclide/coc.nvim -[neovim-docs-lsp]: https://neovim.io/doc/user/lsp.html -[neovim/nvim-lspconfig]: https://github.com/neovim/nvim-lspconfig -[nord-atom-syntax-pr-47]: https://github.com/arcticicestudio/nord-atom-syntax/pull/47 -[nord-config-port-vim#uni_st_line]: https://www.nordtheme.com/docs/ports/vim/configuration#uniform-status-lines -[nord-docs-config-font-bold]: https://www.nordtheme.com/ports/vim/configuration#bold-styles -[nord-gh]: https://github.com/arcticicestudio/nord -[nord-lightline]: https://github.com/arcticicestudio/nord-vim/blob/develop/autoload/lightline/colorscheme/nord.vim -[nord]: https://www.nordtheme.com -[pandoc]: https://pandoc.org -[plugin-ale]: https://github.com/w0rp/ale -[plugin-ctrlp]: https://github.com/ctrlpvim/ctrlp.vim -[plugin-junegunn/vim-plug]: https://github.com/junegunn/vim-plug -[plugin-kshenoy/vim-signature]: https://github.com/kshenoy/vim-signature -[plugin-mhinz/vim-signify]: https://github.com/mhinz/vim-signify -[plugin-plasticboy/vim-markdown]: https://github.com/plasticboy/vim-markdown -[plugin-stephpy/vim-yaml]: https://github.com/stephpy/vim-yaml -[plugin-tpope/vim-fugitive]: https://github.com/tpope/vim-fugitive -[plugin-vimwiki/vimwiki]: https://github.com/vimwiki/vimwiki -[readme-config-comment-brightness]: https://github.com/arcticicestudio/nord-vim#comment-contrast -[readme-config-italic]: https://github.com/arcticicestudio/nord-vim#italic-support -[readme-config-line-number-background]: https://github.com/arcticicestudio/nord-vim#line-number-background -[readme-config-underline-support]: https://github.com/arcticicestudio/nord-vim#underline-support -[readme-config-uniform-diff-background]: https://github.com/arcticicestudio/nord-vim#uniform-diff-background -[readme-config-uniform-statusline-background]: https://github.com/arcticicestudio/nord-vim#uniform-status-lines -[rust]: https://www.rust-lang.org -[vdoc-fchar]: http://vimdoc.sourceforge.net/htmldoc/options.html#'fillchars' -[vdoc-vsplit]: http://vimdoc.sourceforge.net/htmldoc/syntax.html#hl-VertSplit -[vim-doc-diffadd]: http://vimdoc.sourceforge.net/htmldoc/syntax.html#hl-DiffAdd -[vim-pandoc/vim-pandoc-syntax]: https://github.com/vim-pandoc/vim-pandoc-syntax -[yaml]: http://yaml.org - - - -[cmake-doc-genexpr]: https://cmake.org/cmake/help/latest/manual/cmake-generator-expressions.7.html -[gh-user-axelitus]: https://github.com/axelitus -[gh-user-huyvohcmc]: https://github.com/huyvohcmc -[gh-user-markand]: https://github.com/markand -[gh-user-meck]: https://github.com/meck -[gh-user-terminalwitchcraft]: https://github.com/terminalwitchcraft -[gh-user-tidux]: https://github.com/tidux -[gh-user-vabatta]: https://github.com/vabatta -[neovimhaskell/haskell-vim]: https://github.com/neovimhaskell/haskell-vim -[rustdoc-attributes]: https://doc.rust-lang.org/reference/attributes.html -[rustdoc-derives]: https://doc.rust-lang.org/edition-guide/rust-2018/macros/custom-derive.html -[rustdoc-enums]: https://doc.rust-lang.org/1.1.0/book/enums.html -[rustdoc-escapes]: https://doc.rust-lang.org/reference/tokens.html#ascii-escapes -[rustdoc-macros]: https://doc.rust-lang.org/1.8.0/book/macros.html -[rustdoc-traits]: https://doc.rust-lang.org/book/ch10-02-traits.html - - - -[gh-user-aborzunov]: https://github.com/aborzunov -[gh-user-tobydeh]: https://github.com/tobydeh -[nord-docs#143]: https://github.com/arcticicestudio/nord-docs/issues/143 - - - -[arcticicestudio/nord-vim#58]: https://github.com/arcticicestudio/nord-vim/pull/58 -[gh-rel-v0.7.0]: https://github.com/arcticicestudio/nord-vim/releases/tag/v0.7.0 -[gh-user-alexandremjacques]: https://github.com/alexandremjacques -[gh-user-hennessey]: https://github.com/hennessey -[gh-user-jmurinello]: https://github.com/jmurinello -[gh-user-nixtrace]: https://github.com/nixtrace -[gh-user-vasilescur]: https://github.com/vasilescur -[mhinz/vim-startify]: https://github.com/mhinz/vim-startify -[vim/vim-diff#d9b0d83b...017ba07f]: https://github.com/vim/vim/compare/d9b0d83b13d2691e4544709abd87eac004715175...017ba07fa2cdc578245618717229444fd50c470d#diff-80fffb3e9c20e93e5b2328a9a20e19c -[vim/vim-rel-v8.1.2029]: https://github.com/vim/vim/releases/tag/v8.1.2029 -[vim/vim#4933]: https://github.com/vim/vim/pull/4933 - - - -[gh-user-alexanderjeurissen]: https://github.com/alexanderjeurissen -[gh-user-xulongwu4]: https://github.com/xulongwu4 -[neovim/nvim-lsp]: https://github.com/neovim/nvim-lsp -[yggdroot/leaderf]: https://github.com/Yggdroot/LeaderF - - - -[gh-user-iamdidev]: https://github.com/iamdidev -[gh-user-ikalnytskyi]: https://github.com/ikalnytskyi -[herringtonharkholme/yats.vim]: https://github.com/HerringtonDarkholme/yats.vim -[ts-docs-decorators]: https://www.typescriptlang.org/docs/handbook/decorators.html -[ts-docs-jsx]: https://www.typescriptlang.org/docs/handbook/jsx.html -[typescript]: https://www.typescriptlang.org - - - -[arcticicestudio/nord-vim#218]: https://github.com/arcticicestudio/nord-vim/pull/218 -[blob-master-colors/nord.vim]: https://github.com/arcticicestudio/nord-vim/blob/master/colors/nord.vim -[crispgm-blog-neovim_overpowering]: https://crispgm.com/page/neovim-is-overpowering.html -[docs-colors]: https://www.nordtheme.com/docs/colors-and-palettes -[gh-compare-tag-v0.15.0_v0.16.0]: https://github.com/arcticicestudio/nord-vim/compare/v0.15.0...v0.16.0 -[gh-user-clason]: https://github.com/clason -[gh-user-crispgm]: https://github.com/crispgm -[gh-user-ojroques]: https://github.com/ojroques -[latex]: https://www.latex-project.org -[nathanaelkane/vim-indent-guides]: https://github.com/nathanaelkane/vim-indent-guides -[nathanaelkane/vim-indent-guides#custom_color]: https://github.com/nathanaelkane/vim-indent-guides#setting-custom-indent-colors -[neovim/neovim-ms#19]: https://github.com/neovim/neovim/milestone/19 -[neovim/neovim#12655]: https://github.com/neovim/neovim#12655 -[overleaf-latex-learn-math_expr]: https://www.overleaf.com/learn/latex/mathematical_expressions -[stanangeloff/php.vim]: https://github.com/StanAngeloff/php.vim -[vim-docs#php_syntax]: https://vimhelp.org/syntax.txt.html#ft%2dphp%2dsyntax -[wikip-greek_alphabet]: https://en.wikipedia.org/wiki/Greek_alphabet +[4]: https://github.com/arcticicestudio/nord-vim/blob/develop/autoload/airline/themes/nord.vim +[5]: https://github.com/liuchengxu/vim-clap +[6]: https://github.com/neoclide/coc.nvim +[7]: https://neovim.io/doc/user/lsp.html +[8]: https://github.com/neovim/nvim-lspconfig +[9]: https://pandoc.org +[10]: https://github.com/w0rp/ale +[11]: https://github.com/arcticicestudio/nord-vim#comment-contrast +[12]: https://github.com/arcticicestudio/nord-vim#uniform-diff-background +[13]: https://github.com/vim-pandoc/vim-pandoc-syntax +[44]: https://github.com/meck + + + +[14]: https://github.com/ctrlpvim/ctrlp.vim + + + +[15]: https://github.com/arcticicestudio/nord/issues/55 +[16]: https://gist.github.com/XVilka/8346728 +[17]: https://github.com/itchyny/lightline.vim/pull/257 +[18]: http://lesscss.org/functions/#color-operations-lighten +[19]: https://github.com/arcticicestudio/nord-atom-syntax/pull/47 +[20]: https://github.com/junegunn/vim-plug +[21]: https://github.com/plasticboy/vim-markdown +[22]: https://github.com/tpope/vim-fugitive +[23]: https://github.com/arcticicestudio/nord-vim#italic-support +[24]: https://github.com/arcticicestudio/nord-vim#uniform-status-lines +[25]: http://vimdoc.sourceforge.net/htmldoc/syntax.html#hl-DiffAdd + + + +[26]: https://github.com/itchyny/lightline.vim#advanced-configuration +[27]: https://github.com/mhinz/vim-signify + + + +[28]: https://github.com/kshenoy/vim-signature +[29]: https://github.com/stephpy/vim-yaml +[30]: https://github.com/vimwiki/vimwiki +[31]: https://github.com/arcticicestudio/nord-vim#line-number-background +[32]: https://github.com/arcticicestudio/nord-vim#underline-support +[33]: http://yaml.org + + + +[34]: https://github.com/arcticicestudio/nord-vim/issues/11 +[35]: https://github.com/itchyny/lightline.vim +[36]: https://github.com/arcticicestudio/nord/issues/94 +[37]: https://github.com/edkolev/tmuxline.vim +[38]: https://github.com/cg433n + + + +[39]: https://asciidoctor.org +[40]: https://cmake.org/cmake/help/latest/manual/cmake-generator-expressions.7.html +[41]: https://github.com/axelitus +[42]: https://github.com/huyvohcmc +[43]: https://github.com/markand +[45]: https://github.com/terminalwitchcraft +[46]: https://github.com/tidux +[47]: https://github.com/vabatta +[48]: https://github.com/neovimhaskell/haskell-vim +[49]: https://doc.rust-lang.org/reference/attributes.html +[50]: https://doc.rust-lang.org/edition-guide/rust-2018/macros/custom-derive.html +[51]: https://doc.rust-lang.org/1.1.0/book/enums.html +[52]: https://doc.rust-lang.org/reference/tokens.html#ascii-escapes +[53]: https://doc.rust-lang.org/1.8.0/book/macros.html +[54]: https://doc.rust-lang.org/book/ch10-02-traits.html +[55]: https://www.rust-lang.org +[56]: http://vimdoc.sourceforge.net/htmldoc/options.html#'fillchars' +[57]: http://vimdoc.sourceforge.net/htmldoc/syntax.html#hl-VertSplit + + + +[58]: https://github.com/aborzunov +[59]: https://github.com/tobydeh +[60]: https://github.com/arcticicestudio/nord-docs/issues/143 +[61]: https://www.nordtheme.com/ports/vim/configuration#bold-styles + + + +[62]: https://github.com/arcticicestudio/nord-vim/pull/58 +[63]: https://github.com/arcticicestudio/nord-vim/releases/tag/v0.7.0 +[64]: https://github.com/alexandremjacques +[65]: https://github.com/hennessey +[66]: https://github.com/jmurinello +[67]: https://github.com/nixtrace +[68]: https://github.com/vasilescur +[69]: https://github.com/mhinz/vim-startify +[70]: https://github.com/vim/vim/compare/d9b0d83b13d2691e4544709abd87eac004715175...017ba07fa2cdc578245618717229444fd50c470d#diff-80fffb3e9c20e93e5b2328a9a20e19c +[71]: https://github.com/vim/vim/releases/tag/v8.1.2029 +[72]: https://github.com/vim/vim/pull/4933 +[73]: https://www.nordtheme.com/docs/ports/vim/configuration#uniform-status-lines + + + +[74]: https://github.com/alexanderjeurissen +[75]: https://github.com/xulongwu4 +[76]: https://github.com/neovim/nvim-lsp +[77]: https://github.com/Yggdroot/LeaderF + + + +[78]: https://github.com/iamdidev +[79]: https://github.com/ikalnytskyi +[80]: https://github.com/HerringtonDarkholme/yats.vim +[81]: https://www.typescriptlang.org/docs/handbook/decorators.html +[82]: https://www.typescriptlang.org/docs/handbook/jsx.html +[83]: https://www.typescriptlang.org + + + +[84]: https://github.com/arcticicestudio/nord-vim/pull/218 +[85]: https://github.com/arcticicestudio/nord-vim/blob/master/colors/nord.vim +[86]: https://crispgm.com/page/neovim-is-overpowering.html +[87]: https://www.nordtheme.com/docs/colors-and-palettes +[88]: https://github.com/arcticicestudio/nord-vim/compare/v0.15.0...v0.16.0 +[89]: https://github.com/clason +[90]: https://github.com/crispgm +[91]: https://github.com/ojroques +[92]: https://www.latex-project.org +[93]: https://github.com/nathanaelkane/vim-indent-guides +[94]: https://github.com/nathanaelkane/vim-indent-guides#setting-custom-indent-colors +[95]: https://github.com/neovim/neovim/milestone/19 +[96]: https://github.com/neovim/neovim#12655 +[97]: https://www.overleaf.com/learn/latex/mathematical_expressions +[98]: https://github.com/StanAngeloff/php.vim +[99]: https://vimhelp.org/syntax.txt.html#ft%2dphp%2dsyntax +[100]: https://en.wikipedia.org/wiki/Greek_alphabet -[gh-compare-tag-v0.16.0_v0.17.0]: https://github.com/arcticicestudio/nord-vim/compare/v0.16.0...v0.17.0 -[neovim/neovim-v0.5.0]: https://github.com/neovim/neovim/releases/tag/v0.5.0 -[nvim-treesitter/nvim-treesitter-blob-90f15d9]: https://github.com/nvim-treesitter/nvim-treesitter/blob/90f15d9/plugin/nvim-treesitter.vim -[nvim-treesitter/nvim-treesitter]: https://github.com/nvim-treesitter/nvim-treesitter -[tree-sitter/tree-sitter]: https://github.com/tree-sitter/tree-sitter +[101]: https://github.com/arcticicestudio/nord-vim/compare/v0.16.0...v0.17.0 +[102]: https://github.com/neovim/neovim/releases/tag/v0.5.0 +[103]: https://github.com/nvim-treesitter/nvim-treesitter/blob/90f15d9/plugin/nvim-treesitter.vim +[104]: https://github.com/nvim-treesitter/nvim-treesitter +[105]: https://github.com/tree-sitter/tree-sitter -[gh-compare-tag-v0.17.0_v0.18.0]: https://github.com/arcticicestudio/nord-vim/compare/v0.17.0...v0.18.0 -[nvim-docs-lsp#codelens]: https://neovim.io/doc/user/lsp.html#lsp-highlight-codelens -[nvim-treesitter/nvim-treesitter-blob-fb5d6e04#l493-l495]: https://github.com/nvim-treesitter/nvim-treesitter/blob/fb5d6e04/doc/nvim-treesitter.txt#L493-L495 -[nvim-treesitter/nvim-treesitter#1016#comment-797049591]: https://github.com/nvim-treesitter/nvim-treesitter/issues/1016#issuecomment-797049591 -[nvim-treesitter/nvim-treesitter#78#comment-647140700]: https://github.com/nvim-treesitter/nvim-treesitter/issues/78#issuecomment-647140700 +[106]: https://github.com/arcticicestudio/nord-vim/compare/v0.17.0...v0.18.0 +[107]: https://neovim.io/doc/user/lsp.html#lsp-highlight-codelens +[108]: https://github.com/nvim-treesitter/nvim-treesitter/blob/fb5d6e04/doc/nvim-treesitter.txt#L493-L495 +[109]: https://github.com/nvim-treesitter/nvim-treesitter/issues/1016#issuecomment-797049591 +[110]: https://github.com/nvim-treesitter/nvim-treesitter/issues/78#issuecomment-647140700 + + + +[111]: https://github.com/arcticicestudio/nord-vim/compare/v0.18.0...v0.19.0 +[112]: https://github.com/neovim/neovim/releases/tag/v0.6.0 +[113]: https://github.com/neovim/neovim/commit/a5bbb932f9094098bd656d3f6be3c58344576709#diff-51fab2b766d0a3b606462e95de492190df173b7296147912307cdad636cd492aR77 +[114]: https://github.com/neovim/neovim/blob/f92a2457c2e7ad14d9a5a907ef4213fa770b6d95/runtime/doc/lsp.txt#L423 +[115]: https://microsoft.github.io/language-server-protocol/specification#textDocument_documentHighlight +[116]: https://github.com/vim/vim/blob/0e6adf8a29d5c2c96c42cc7157f71bf22c2ad471/runtime/syntax/c.vim#L313-L375 +[117]: https://github.com/neovim/neovim/blob/70db972e5fbcab39946ad8ac05472a693cf65b68/runtime/doc/lsp.txt#L456-L459 +[118]: https://vimhelp.org/builtin.txt.html#builtin.txt#get%28%29 +[119]: https://vimhelp.org/builtin.txt.html#builtin.txt#execute%28%29 diff --git a/README.md b/README.md index 12367764..9dce0492 100644 --- a/README.md +++ b/README.md @@ -10,27 +10,27 @@

-Build for Vim's terminal- and GUI mode with _true colors_ with support for many third-party syntax and UI plugins including bundled themes for [lightline.vim][gh-itchyny/lightline.vim] and [vim-airline][gh-vim-airline/vim-airline]. +Build for Vim's terminal- and GUI mode with _true colors_ with support for many third-party syntax and UI plugins including bundled themes for [lightline.vim][1] and [vim-airline][4]. ## Getting Started -Visit the [official website][nord-home] to learn all about the [syntax highlighting][nord-home#syntax] features, details and elements of [UI and editor elements][nord-home#editor-details], the [various theme configurations][nord-home#configurations] and the [support for many plugins][nord-home#plugin-support]. +Visit the [official website][23] to learn all about the [syntax highlighting][27] features, details and elements of [UI and editor elements][25], the [various theme configurations][24] and the [support for many plugins][26]. -Learn about the [installation and activation][nord-docs-home-install], how to [configure][nord-docs-home-config] and [customize][nord-docs-home-custom] the theme from the [official documentations][nord-docs-home]. +Learn about the [installation and activation][20], how to [configure][18] and [customize][19] the theme from the [official documentations][22]. ### Quick Start -Thanks to existing plugin/_runtimepath_ managers for Vim, Nord Vim can be installed for all platforms and the various variants/forks of Vim in a uniform way within a few lines of codes. The recommended manager is [vim-plug][gh-junegunn/vim-plug], but any other manager like [pathogen][gh-tpope/vim-pathogen] or [Vundle][gh-vundlevim/vundle.vim] can also be used. +Thanks to existing plugin/_runtimepath_ managers for Vim, Nord Vim can be installed for all platforms and the various variants/forks of Vim in a uniform way within a few lines of codes. The recommended manager is [vim-plug][2], but any other manager like [pathogen][3] or [Vundle][5] can also be used. -To automatically download and activate Nord Vim, follow the install instructions for [vim-plug][gh-junegunn/vim-plug] and +To automatically download and activate Nord Vim, follow the install instructions for [vim-plug][2] and -1. add `Plug 'arcticicestudio/nord-vim'` to your [`vimrc`][vimhelp-vimrc] within _vim-plug_'s plugin loading function +1. add `Plug 'arcticicestudio/nord-vim'` to your [`vimrc`][28] within _vim-plug_'s plugin loading function 2. run the `:PlugInstall` command in Vim -3. activate the theme by adding `colorscheme nord` to the [vimrc][vimhelp-vimrc] or change it on-the-fly by running `:colorscheme nord` +3. activate the theme by adding `colorscheme nord` to the [vimrc][28] or change it on-the-fly by running `:colorscheme nord`

-See the Nord Vim's documentation for [more installation options][nord-docs-home-install] and how to [set it up manually][nord-docs-home-install#manual]. +See the Nord Vim's documentation for [more installation options][20] and how to [set it up manually][21]. ## Features @@ -42,13 +42,13 @@ See the Nord Vim's documentation for [more installation options][nord-docs-home- ## Contributing -Nord is an open source project and we love to receive contributions from the [community][nord-comm]! +Nord is an open source project and we love to receive contributions from the [community][6]! -There are many ways to contribute, from [writing- and improving documentation and tutorials][nord-contrib-guide-docs], [reporting bugs][nord-contrib-guide-bugs], [submitting enhancement suggestions][nord-contrib-guide-enhance] that can be added to Nord by [submitting pull requests][nord-contrib-guide-pr]. +There are many ways to contribute, from [writing- and improving documentation and tutorials][9], [reporting bugs][8], [submitting enhancement suggestions][10] that can be added to Nord by [submitting pull requests][14]. -Please take a moment to read Nord's full [contributing guide][nord-contrib-guide] to learn about the development process, the project's used [styleguides][nord-contrib-guide-styles], [branch organization][nord-contrib-guide-branching] and [versioning][nord-contrib-guide-versioning] model. +Please take a moment to read Nord's full [contributing guide][17] to learn about the development process, the project's used [styleguides][15], [branch organization][7] and [versioning][16] model. -The guide also includes information about [minimal, complete, and verifiable examples][nord-contrib-guide-mcve] and other ways to contribute to the project like [improving existing issues][nord-contrib-guide-impr-issues] and [giving feedback on issues and pull requests][nord-contrib-guide-feedback]. +The guide also includes information about [minimal, complete, and verifiable examples][13] and other ways to contribute to the project like [improving existing issues][12] and [giving feedback on issues and pull requests][11].

@@ -56,31 +56,31 @@ The guide also includes information about [minimal, complete, and verifiable exa

-[gh-itchyny/lightline.vim]: https://github.com/itchyny/lightline.vim -[gh-junegunn/vim-plug]: https://github.com/junegunn/vim-plug -[gh-tpope/vim-pathogen]: https://github.com/tpope/vim-pathogen -[gh-vim-airline/vim-airline]: https://github.com/vim-airline/vim-airline -[gh-vundlevim/vundle.vim]: https://github.com/tpope/vim-pathogen -[nord-comm]: https://www.nordtheme.com/community -[nord-contrib-guide-branching]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#branch-organization -[nord-contrib-guide-bugs]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#bug-reports -[nord-contrib-guide-docs]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#documentations -[nord-contrib-guide-enhance]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#enhancement-suggestions -[nord-contrib-guide-feedback]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#give-feedback-on-issues-and-pull-requests -[nord-contrib-guide-impr-issues]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#improve-issues -[nord-contrib-guide-mcve]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#mcve -[nord-contrib-guide-pr]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#pull-requests -[nord-contrib-guide-styles]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#styleguides -[nord-contrib-guide-versioning]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#versioning -[nord-contrib-guide]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md -[nord-docs-home-config]: https://www.nordtheme.com/docs/ports/vim/configuration -[nord-docs-home-custom]: https://www.nordtheme.com/docs/ports/vim/customization -[nord-docs-home-install]: https://www.nordtheme.com/docs/ports/vim/installation -[nord-docs-home-install#manual]: https://www.nordtheme.com/docs/ports/vim/installation#manual -[nord-docs-home]: https://www.nordtheme.com/docs/ports/vim -[nord-home]: https://www.nordtheme.com/ports/vim -[nord-home#configurations]: https://www.nordtheme.com/ports/vim#configurations -[nord-home#editor-details]: https://www.nordtheme.com/ports/vim#editor-details -[nord-home#plugin-support]: https://www.nordtheme.com/ports/vim#plugin-support -[nord-home#syntax]: https://www.nordtheme.com/ports/vim#syntax -[vimhelp-vimrc]: https://vimhelp.org/starting.txt.html#vimrc +[1]: https://github.com/itchyny/lightline.vim +[2]: https://github.com/junegunn/vim-plug +[3]: https://github.com/tpope/vim-pathogen +[4]: https://github.com/vim-airline/vim-airline +[5]: https://github.com/tpope/vim-pathogen +[6]: https://www.nordtheme.com/community +[7]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#branch-organization +[8]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#bug-reports +[9]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#documentations +[10]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#enhancement-suggestions +[11]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#give-feedback-on-issues-and-pull-requests +[12]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#improve-issues +[13]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#mcve +[14]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#pull-requests +[15]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#styleguides +[16]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md#versioning +[17]: https://github.com/arcticicestudio/nord/blob/develop/CONTRIBUTING.md +[18]: https://www.nordtheme.com/docs/ports/vim/configuration +[19]: https://www.nordtheme.com/docs/ports/vim/customization +[20]: https://www.nordtheme.com/docs/ports/vim/installation +[21]: https://www.nordtheme.com/docs/ports/vim/installation#manual +[22]: https://www.nordtheme.com/docs/ports/vim +[23]: https://www.nordtheme.com/ports/vim +[24]: https://www.nordtheme.com/ports/vim#configurations +[25]: https://www.nordtheme.com/ports/vim#editor-details +[26]: https://www.nordtheme.com/ports/vim#plugin-support +[27]: https://www.nordtheme.com/ports/vim#syntax +[28]: https://vimhelp.org/starting.txt.html#vimrc diff --git a/autoload/airline/themes/nord.vim b/autoload/airline/themes/nord.vim index 9c478762..5d400313 100755 --- a/autoload/airline/themes/nord.vim +++ b/autoload/airline/themes/nord.vim @@ -5,7 +5,7 @@ " Repository: https://github.com/arcticicestudio/nord-vim " License: MIT -let s:nord_vim_version="0.18.0" +let s:nord_vim_version="0.19.0" let g:airline#themes#nord#palette = {} let s:nord0_gui = "#2E3440" diff --git a/autoload/lightline/colorscheme/nord.vim b/autoload/lightline/colorscheme/nord.vim index 5138a943..97800a16 100755 --- a/autoload/lightline/colorscheme/nord.vim +++ b/autoload/lightline/colorscheme/nord.vim @@ -5,7 +5,7 @@ " Repository: https://github.com/arcticicestudio/nord-vim " License: MIT -let s:nord_vim_version="0.18.0" +let s:nord_vim_version="0.19.0" let s:p = {'normal': {}, 'inactive': {}, 'insert': {}, 'replace': {}, 'visual': {}, 'tabline': {}} let s:nord0 = ["#2E3440", "NONE"] diff --git a/colors/nord.vim b/colors/nord.vim index 23f95865..f14e1d8a 100755 --- a/colors/nord.vim +++ b/colors/nord.vim @@ -13,7 +13,7 @@ if version > 580 endif let g:colors_name = "nord" -let s:nord_vim_version="0.18.0" +let s:nord_vim_version="0.19.0" set background=dark let s:nord0_gui = "#2E3440"