5
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

[Vim]ステータスラインにファイル名+一つ上のディレクトリを表示する[lightline]

Last updated at Posted at 2019-01-07

まとめ

困っていたこと
Reactで開発していて、 components/{Component名}/index.js としてディレクトリをわけていたら、ステータスラインにファイル名しか表示されないと「どのindex.jsだよ!」となった。

解決策

Before
image.png

After
image.png

一つ上のディレクトリまで表示することにしました。

やったこと

lightlineを使っていたため、 lightlineのカスタマイズをすることにしました。

公式READMEの"ファイル名と変更サインの間のバーを消すことはできますか?"を参考にしました。

完成形vimrc

.vimrc
let g:lightline = {
      \ 'component_function': {
      \   'filename': 'LightLineFileNameWithParentDir'
      \ }
      \ }

function! LightLineFileNameWithParentDir()
    if expand('%:t') ==# ''
        let filename = '[No Name]'
    else
        let dirfiles = split(expand('%:p'), '/')
        if len(dirfiles) < 2
            let filename = dirfiles[0]
        else
            let filename = dirfiles[-2] . '/' . dirfiles[-1]
        endif
    endif
    return filename
endfunction

解説
lightlineの設定を入れる変数である g:lightlinecomponent_function という、新しい表示項目を生成、もしくは既存の項目を上書きする関数を登録する項目があります。
既存のfilenameという項目はREADMEを見る限り1 expand('%:t') !=# '' ? expand('%:t') : '[No Name]' で表示されているようなので、それを参考にカスタマイズしました。

  1. ソースコードの中では見つけられませんでしたが..

5
0
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?