Por que a ordem de: set bg = dark e: set bg = light importam?

11

Ao tentar combinar a paleta de cores do meu terminal e do GVim, notei o seguinte:

  1. Quando abro o GVim e o Vim, vejo: insira a descrição da imagem aqui (Esse é o mesmo arquivo, meu vimrc.)
  2. Se sim :set t_Co=256, nada acontece no GVim (exceto que pisca), enquanto as cores no terminal agora parecem diferentes. Se eu fizer :set bg=darkagora, não faz diferença (novamente o GVim pisca). Se eu fizer :set bg=lighte depois :set bg=darknovamente, recebo: insira a descrição da imagem aqui

Ambos :set bg=darke :set t_Co=256estão presentes no meu vimrc . Por que não é meu :set bge :set t_Copersistente e por que a configuração :set bg=darknovamente depois :set bg=lightfaz a diferença onde originalmente não aconteceu?

Estou usando o Arch Linux, o terminal é o GNOME Terminal e não tenho um .gvimrc.

$ vim --version
VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Feb  4 2015 08:03:11)
Included patches: 1-617
Compiled by Arch Linux
Huge version with GTK2 GUI.  Features included (+) or not (-):
+acl             +farsi           +mouse_netterm   +syntax
+arabic          +file_in_path    +mouse_sgr       +tag_binary
+autocmd         +find_in_path    -mouse_sysmouse  +tag_old_static
+balloon_eval    +float           +mouse_urxvt     -tag_any_white
+browse          +folding         +mouse_xterm     -tcl
++builtin_terms  -footer          +multi_byte      +terminfo
+byte_offset     +fork()          +multi_lang      +termresponse
+cindent         +gettext         -mzscheme        +textobjects
+clientserver    -hangul_input    +netbeans_intg   +title
+clipboard       +iconv           +path_extra      +toolbar
+cmdline_compl   +insert_expand   +perl            +user_commands
+cmdline_hist    +jumplist        +persistent_undo +vertsplit
+cmdline_info    +keymap          +postscript      +virtualedit
+comments        +langmap         +printer         +visual
+conceal         +libcall         +profile         +visualextra
+cryptv          +linebreak       -python          +viminfo
+cscope          +lispindent      +python3         +vreplace
+cursorbind      +listcmds        +quickfix        +wildignore
+cursorshape     +localmap        +reltime         +wildmenu
+dialog_con_gui  +lua             +rightleft       +windows
+diff            +menu            +ruby            +writebackup
+digraphs        +mksession       +scrollbind      +X11
+dnd             +modify_fname    +signs           -xfontset
-ebcdic          +mouse           +smartindent     +xim
+emacs_tags      +mouseshape      -sniff           +xsmp_interact
+eval            +mouse_dec       +startuptime     +xterm_clipboard
+ex_extra        +mouse_gpm       +statusline      -xterm_save
+extra_search    -mouse_jsbterm   -sun_workshop    -xpm
   system vimrc file: "/etc/vimrc"
     user vimrc file: "$HOME/.vimrc"
 2nd user vimrc file: "~/.vim/vimrc"
      user exrc file: "$HOME/.exrc"
  system gvimrc file: "/etc/gvimrc"
    user gvimrc file: "$HOME/.gvimrc"
2nd user gvimrc file: "~/.vim/gvimrc"
    system menu file: "$VIMRUNTIME/menu.vim"
  fall-back for $VIM: "/usr/share/vim"
Compilation: gcc -c -I. -Iproto -DHAVE_CONFIG_H -DFEAT_GUI_GTK  -pthread -I/usr/include/gtk-2.0 -I/usr/lib/gtk-2.0/include -I/usr/include/pango-1.0 -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/pixman-1 -I/usr/include/libdrm -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/libpng16 -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib/glib-2.0/include -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/harfbuzz  -D_FORTIFY_SOURCE=2  -march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4 -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=1      
Linking: gcc   -L. -Wl,-O1,--sort-common,--as-needed,-z,relro -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,-E -Wl,-rpath,/usr/lib/perl5/core_perl/CORE  -Wl,-O1,--sort-common,--as-needed,-z,relro -L/usr/local/lib -Wl,--as-needed -o vim   -lgtk-x11-2.0 -lgdk-x11-2.0 -lpangocairo-1.0 -latk-1.0 -lcairo -lgdk_pixbuf-2.0 -lgio-2.0 -lpangoft2-1.0 -lpango-1.0 -lgobject-2.0 -lglib-2.0 -lfontconfig -lfreetype  -lSM -lICE -lXt -lX11 -lXdmcp -lSM -lICE  -lm -lncurses -lelf -lnsl   -lacl -lattr -lgpm -ldl  -L/usr/lib -llua -Wl,-E -Wl,-rpath,/usr/lib/perl5/core_perl/CORE -Wl,-O1,--sort-common,--as-needed,-z,relro -fstack-protector -L/usr/local/lib  -L/usr/lib/perl5/core_perl/CORE -lperl -lnsl -ldl -lm -lcrypt -lutil -lpthread -lc  -L/usr/lib/python3.4/config-3.4m -lpython3.4m -lpthread -ldl -lutil -lm  -lruby -lpthread -lgmp -ldl -lcrypt -lm  -L/usr/lib
muru
fonte

Respostas:

9
  1. O esquema de cores elflord sim set background=dark. Uma vez que é originada após o seu set bg=light, substituirá-o.

  2. set t_Co=256é inútil . Ele não faz nada no GVim e você deve configurar o emulador de terminal corretamente.

    Além disso, o elflord usa apenas cores ANSI básicas em terminais de cores, portanto, não importa se você força o Vim a ver 256 cores ou se define o TERMvalor com 256 cores ; seu esquema de cores não usará essa paleta estendida de qualquer maneira. O que acontece é que seu original TERMé provavelmente xtermou screenou algum outro valor que restringe o Vim a 8 cores. Mas o Elflord usa cores "escuras" e "claras", que precisam de um valor TERMacima de 8. Portanto, forçar 256 cores alterará suas cores.

  3. Recomendações:

    • Não mude o valor de 't_Co'.
    • Não set background.
romainl
fonte
11
Se elflord é definido bgcomo dark, por que sua aparência muda se eu o definir para lighte voltar novamente? Note que meu vimrc não funciona set bg=light.
muru
set bgaltera as cores e os atributos de alguns grupos de destaque para que funcionem melhor em fundo escuro ou claro. É principalmente arbitrário e pode ou não ter um efeito, dependendo do esquema de cores que você usa. Mexer com essa opção não é uma boa ideia.
Romainl
Eu segui o seu conselho bge t_Co. Só estou me perguntando por que o elflord set bg=darke o meu causam resultados tão diferentes (ainda que repetíveis)?
muru
2
É a ordem em que eles são aplicados. Como um não é exatamente o oposto do outro, alternar várias vezes entre "escuro" e "claro" não é uma alternância entre dois estados definidos e estáveis.
Romainl