Perché l'ordine di: set bg = dark e: set bg = light importa?


11

Durante il tentativo di abbinare la tavolozza dei colori del mio terminale e quella di GVim ho notato questo:

  1. Quando apro GVim e Vim, vedo: inserisci qui la descrizione dell'immagine (Questo è lo stesso file, mio vimrc.)
  2. Se lo faccio :set t_Co=256, non succede nulla in GVim (tranne che lampeggia), mentre i colori nel terminale ora sembrano diversi. Se lo faccio :set bg=darkora, non fa differenza (di nuovo GVim lampeggia). Se poi lo faccio :set bg=lighte poi di :set bg=darknuovo, ottengo: inserisci qui la descrizione dell'immagine

Entrambi :set bg=darke :set t_Co=256sono presenti nel mio vimrc . Perché non sono il mio :set bge il mio :set t_Coattaccamento, e perché l'impostazione di :set bg=darknuovo dopo aver :set bg=lightfatto la differenza dove inizialmente non lo faceva?

Sto usando Arch Linux, il terminale è GNOME Terminal e non ne ho uno .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

Risposte:


9
  1. Lo schema di colori elflord lo fa set background=dark. Dal momento che proviene dal tuo set bg=light, lo sovrascriverà.

  2. set t_Co=256è inutile . Non fa nulla in GVim e dovresti invece impostare correttamente l'emulatore di terminale.

    Inoltre, elflord utilizza solo i colori ANSI di base nei terminali di colore, quindi non importa se si forza Vim a vedere 256 colori o se si imposta TERMun valore di 256 colori ; il vostro schema di colori non utilizzerà comunque quella palette estesa. Quello che succede invece è che l'originale TERMè probabilmente xtermo screeno qualche altro valore che limita Vim a 8 colori. Ma Elflord utilizza sia colori "scuri" che "chiari" che richiedono un valore TERMsuperiore a 8. Quindi, forzando 256 colori, i tuoi colori cambieranno.

  3. raccomandazioni:

    • Non modificare il valore di 't_Co'.
    • Non farlo set background.

1
Se elflord è impostato bgsu dark, perché il suo aspetto cambia se lo imposto su lighte viceversa? Nota che il mio vimrc non funziona set bg=light.
Muru,

set bgmodifica i colori e gli attributi di alcuni gruppi di luci in modo che funzionino meglio su sfondo scuro o chiaro. È per lo più arbitrario e può avere o meno un effetto a seconda del colore che usi. Fare casini con quell'opzione non è una buona idea.
Romainl,

Ho seguito i tuoi consigli su bge t_Co. Mi chiedo solo perché Elflord set bg=darke il mio causino risultati così diversi (ma ripetibili)?
Muru,

2
È l'ordine in cui vengono applicati. Perché uno non è l'esatto opposto dell'altro passare più volte tra "buio" e "luce" non è un passaggio tra due stati definiti e stabili.
Romainl,
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.