Definindo o tipo de arquivo vim com a modelina não funcionando como esperado

12

De acordo com a resposta aceita para este question , estou tentando usar modelines no vim para forçar a detecção de tipos de arquivos em alguns arquivos.

Por exemplo, na parte superior de um arquivo chamado gitconfig (observe que não há nenhum líder . ), eu tenho a seguinte linha:

# vim: set filetype=gitconfig : 

modeline está ativado no meu sistema. No entanto, quando abro o arquivo no vim, set filetype? retorna conf , em vez do esperado gitconfig .

É possível que outras partes da configuração do meu vim (por exemplo, filetype.vim) estejam causando esse comportamento estranho?

Editado em resposta a comentários:

set compatible? retorna nocompatible

set modeline? retorna modeline

verbose set filetype? retorna:

filetype=conf
      Last set from /usr/share/vim/vim73/filetype.vim

Não entendo por que o plug-in de tipo de arquivo do sistema estaria substituindo o que eu configurei no próprio arquivo.

Uma nota final: esta é a versão do Vim 7.3 enviada com o OSX.

A versão mais recente do MacVim em execução no mesmo sistema que usa o mesmo .vimrc se comporta conforme o esperado, com set ft? retornando filetype=gitconfig .

    
por Murali Suriar 01.09.2011 / 01:31

2 respostas

17

Assim, após algumas pesquisas, constatou-se que o sistema vimrc fornecido com o OSX define a variável modelines (observe a variável 's') como 0. Essa variável controla o número de linhas em um arquivo que é verificado para definir comandos. Definir modelines para um valor diferente de zero no meu .vimrc resolveu o problema.

Saída completa, para os curiosos: a saída de vim --version me levou a verificar o sistema vimrc:

% vim --version
VIM - Vi IMproved 7.3 (2010 Aug 15, compiled Jun 24 2011 20:00:09)
Compiled by [email protected]
Normal version without GUI.  Features included (+) or not (-):
...
   system vimrc file: "$VIM/vimrc"
     user vimrc file: "$HOME/.vimrc"
      user exrc file: "$HOME/.exrc"
  fall-back for $VIM: "/usr/share/vim"
Compilation: gcc -c -I. -D_FORTIFY_SOURCE=0 -Iproto -DHAVE_CONFIG_H -arch i386 -arch x86_64 -g -Os -pipe
Linking: gcc -arch i386 -arch x86_64 -o vim -lncurses

Olhando para o sistema vimrc:

% cat /usr/share/vim/vimrc 
" Configuration file for vim
set modelines=0         " CVE-2007-2438
...

Levou-me para a variável modelines . Parece que o MacVim não procura esse arquivo de sistema (talvez procurando um sistema GVIMRC em vez disso? :help startup não está claro).

VIM - Vi IMproved 7.3 (2010 Aug 15, compiled Jul 27 2011 19:46:24)
MacOS X (unix) version
Included patches: 1-260
Compiled by XXXXX
Huge version with MacVim GUI.  Features included (+) or not (-):
...
   system vimrc file: "$VIM/vimrc"
     user vimrc file: "$HOME/.vimrc"
      user exrc file: "$HOME/.exrc"
  system gvimrc file: "$VIM/gvimrc"
    user gvimrc file: "$HOME/.gvimrc"
    system menu file: "$VIMRUNTIME/menu.vim"
  fall-back for $VIM: "/Applications/MacVim.app/Contents/Resources/vim"
Compilation: gcc -c -I. -Iproto -DHAVE_CONFIG_H -DFEAT_GUI_MACVIM -Wall -Wno-unknown-pragmas -p
ipe  -DMACOS_X_UNIX -no-cpp-precomp  -g -O2 -D_FORTIFY_SOURCE=1
Linking: gcc   -L.         -Wl,-syslibroot,/Developer/SDKs/MacOSX10.6.sdk -L/usr/local/lib -o V
im -framework Cocoa -framework Carbon      -lncurses  -liconv -framework Cocoa    -fstack-prote
ctor -L/usr/local/lib  -L/System/Library/Perl/5.10/darwin-thread-multi-2level/CORE -lperl -lm -
lutil -lc -framework Python   -framework Ruby
    
por 04.09.2011 / 02:43
1

Para isso funcionar no meu sistema macOS eu tive que definir algumas configurações em ~ / .vimrc:

modeline
modelines=2

Onde ' modeline ' ativa o uso de configurações no arquivo, e ' modelines = # ' define o número de linhas que o vim / vi verificará quanto aos comandos definidos .

Quando esses parâmetros foram definidos, consegui usar a sintaxe, como a linha abaixo, em meus arquivos para substituir os parâmetros definidos.

# vim: ts=4 sw=4 ai
    
por 20.12.2017 / 18:38

Tags