Vim -p:致命的なシグナルSEGVをキャッチしましたか?


12

-pオプションでVimを起動すると、この問題が発生します。と私が始めたとしましょう

vim -p first.txt second.txt

次に、編集後first.txt、のsecond.txt使用に移りgtます。キーggGもう一度押します。これによりエラーが発生します

Vim: Caught deadly signal SEGV

この時点から、Vimはを含むどの信号にも応答しなくなりますCtrl D。このセッションを閉じるには、ターミナルを終了する必要があります。

この問題は、-pオプションでVimを起動した場合にのみ発生します。first.txt最初に開いてからを使用:tabeして開くsecond.txt場合、この問題は発生しません。

なぜこれが発生する可能性があるのでしょうか?


の出力vim --version

VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Jan  2 2014 19:40:46)
Included patches: 1-52
Modified by pkg-vim-maintainers@lists.alioth.debian.org
Compiled by buildd@
Huge version with GTK2-GNOME 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: "$VIM/vimrc"
     user vimrc file: "$HOME/.vimrc"
 2nd user vimrc file: "~/.vim/vimrc"
      user exrc file: "$HOME/.exrc"
  system gvimrc file: "$VIM/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/i386-linux-gnu/gtk-2.0/include -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/pango-1.0 -I/usr/include/gio-unix-2.0/ -I/usr/include/freetype2 -I/usr/include/glib-2.0 -I/usr/lib/i386-linux-gnu/glib-2.0/include -I/usr/include/pixman-1 -I/usr/include/libpng12 -I/usr/include/harfbuzz   -pthread -DORBIT2=1 -D_REENTRANT -I/usr/include/libgnomeui-2.0 -I/usr/include/libart-2.0 -I/usr/include/gconf/2 -I/usr/include/gnome-keyring-1 -I/usr/include/libgnome-2.0 -I/usr/include/libbonoboui-2.0 -I/usr/include/libgnomecanvas-2.0 -I/usr/include/gtk-2.0 -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/gnome-vfs-2.0 -I/usr/lib/i386-linux-gnu/gnome-vfs-2.0/include -I/usr/include/dbus-1.0 -I/usr/lib/i386-linux-gnu/dbus-1.0/include -I/usr/include/glib-2.0 -I/usr/lib/i386-linux-gnu/glib-2.0/include -I/usr/include/orbit-2.0 -I/usr/include/libbonobo-2.0 -I/usr/include/bonobo-activation-2.0 -I/usr/include/libxml2 -I/usr/include/pango-1.0 -I/usr/include/gail-1.0 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/atk-1.0 -I/usr/lib/i386-linux-gnu/gtk-2.0/include -I/usr/include/cairo -I/usr/include/gio-unix-2.0/ -I/usr/include/pixman-1 -I/usr/include/libpng12     -g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=1     -I/usr/include/tcl8.6  -D_REENTRANT=1  -D_THREAD_SAFE=1  -D_LARGEFILE64_SOURCE=1  
Linking: gcc   -L. -Wl,-Bsymbolic-functions -Wl,-z,relro -rdynamic -Wl,-export-dynamic -Wl,-E  -Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,--as-needed -o vim   -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lgobject-2.0 -lglib-2.0 -lfreetype     -lgnomeui-2 -lSM -lICE -lbonoboui-2 -lgnomevfs-2 -lgnomecanvas-2 -lgnome-2 -lpopt -lbonobo-2 -lbonobo-activation -lORBit-2 -lart_lgpl_2 -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lfreetype -lgconf-2 -lgthread-2.0 -lgmodule-2.0 -lgobject-2.0 -lglib-2.0   -lSM -lICE -lXpm -lXt -lX11 -lXdmcp -lSM -lICE  -lm -ltinfo -lnsl  -lselinux  -lacl -lattr -lgpm -ldl  -L/usr/lib -llua5.2 -Wl,-E  -fstack-protector -L/usr/local/lib  -L/usr/lib/perl/5.18/CORE -lperl -ldl -lm -lpthread -lcrypt -L/usr/lib/python2.7/config-i386-linux-gnu -lpython2.7 -lpthread -ldl -lutil -lm -Xlinker -export-dynamic -Wl,-O1 -Wl,-Bsymbolic-functions  -L/usr/lib/i386-linux-gnu -ltcl8.6 -ldl -lz -lpthread -lieee -lm -lruby-1.9.1 -lpthread -lrt -ldl -lcrypt -lm  -L/usr/lib   

の出力uname -a

Linux nitish 3.13.0-45-generic #74-Ubuntu SMP Tue Jan 13 19:37:48 UTC 2015 i686 i686 i686 GNU/Linux

@Carpetsmokerのコメントに基づいて、問題の原因は.vimrcファイルにあることがわかりました。そのため、問題の原因となったコマンドを.vimrc実行し、ファイルの一部がコメント化されていることを確認しました。最後に、問題はラインにあることがわかりました

set columns=1000

どのようにして無実のコマンドがこの問題を引き起こすのでしょうか?:help columnsこれに関する有用な情報はありませんでした。


2
どのvim(およびパッチレベル)を使用していますか?(vim --version出力のように)、そしてどのOSですか?いずれにしても、vimを更新することをお勧めします。Macを使用していて、rubyプラグイン(command-Tなど)を使用している場合は、それらを再インストールするか、vimがrvm ruby​​ではなくシステムrubyを使用していることを確認します(一部の人に問題を引き起こしているようです)
davidlowryduda

1
次のようにvimを起動できvim -u NONE -p first.txt second.txtます。これにより、vimrcファイルが読み込まれなくなります。
Martin Tournoij、2015

@hatter vimがインストールまたはコンパイルされましたか?それを7.4にアップグレードして、それが役立つかどうかを確認できますか。
ケノーブ2015

@kenorb Vimをインストールしました。
ニティッシュ2015

@Carpetsmokerうまくいきました!! これは間違いなく.vimrcファイルに問題があることを示していますか?
ニティッシュ2015

回答:


6

SEGV信号はsegfaultとも呼ばれ、ほとんどの場合、実行中のプログラム(この場合はvim)のバグが原因です。(他の原因は、ハードウェアの欠陥、またはブルームーンに一度、カーネルバグなどです。)

したがって、実際には、バグを報告する必要があります。:help bug-reportsバグを報告する方法について説明します。問題を再現するための最小限の手順がすでにあるように思えるので、それがほとんどの作業です。ただし、おそらく新しいバージョンのVimを最初にテストして、まだ修正されていないことを確認する必要があります。


Vim 7.4を使用しています。公式サイトはこれが最新バージョンだと言っています。
ニティッシュ2015

@hatter利用可能なパッチよりも少ないパッチが適用されています。
derobert、2015

彼はDebianを実行しているため、次のように説明されています:-)
Martin Tournoij、2015

@Carpetsmoker私はDebianを実行していて、パッチ488を通過しています... OPがなぜ古いかわかりません。Wheezy(現在のリリース)には7.3があるため、OPはそれを使用していません。不安定、ジェシー、および喘鳴バックポートはすべて7.4のパッチ488持って(考えると、640がそうそれはまだ多少古いですが、現在では。)
derobert

3

セグメンテーション違反が原因でvimがクラッシュする場合は、ソフトウェアのバグまたはハードウェアの問題が原因のメモリアクセス違反を示しています。

これが繰り返し発生する場合は、次の順序で行う必要があります。

  1. 実行してプラグインを無効にvim -u NONEします。それが役立つかどうかを確認します。
  2. vimを最新の安定バージョンにアップグレードします。
  3. vimを最新の開発バージョンにアップグレードします。
  4. オプションで、異なるマシンで同じvimバージョンを再確認します(ハードウェアの問題が原因である可能性があります)。
  5. vimデバッガーの下で実行してみてください:gdb vimとバックトレースを確認してください(SEGVの後、gdbbtまたはで入力bt full)。
  6. バックトレースにシンボルがない場合は、vimを再コンパイルしてこれらを含める必要があります。
  7. バックトレースを完了したら、同様の問題を確認するか、vimのバグトラッカー(プレーンなvimの場合)で新しいバグを報告するか、を確認してください:help bugs。vimのバージョンが異なる場合(gVim、MacVim、NeoVimなど)、適切なメンテナに報告してください。

2
これは私のシステムでのみ発生します。では発生しません-u NONE。ライン思えるset columns=1000では.vimrc犯人です。
ニティッシュ2015

0

セグメンテーション障害はまた、NetBeansとのようなサーバーの相互作用に接続することができるautocmdバッファ(例えば、無効BufNewFileで別のプログラム(プラグイン、...)を期待(または類似)する操作).vimの構成は、例えばにおけるこれらの行のコメントを試みます.vimrc

一般的なエラーメッセージは次のとおりです。

missing ! or / in <number>:<command>

どこにあり commandますかeditFile

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.