Category: Vim

Neovimでyyがpで貼り付けられない?コンテナ×tmux×mac環境でハマったクリップボード問題の解決法

概要

Neovimでコピー(yy)した内容を貼り付け(p)ようとしたところ、意図しないテキストが挿入されるという現象に遭遇しました。 本記事では、OSC52ベースのクリップボード連携を導入していた際にこの問題に出会い、どのように原因を特定し、どのように理想の挙動を取り戻したかを記録します。

🐞 課題:yy でコピーしたのに p で貼れない?

Neovim上で yy で行をコピーし、その後 p で貼り付けようとしたところ、**貼り付けられたのは直前の yy ではなく、古い内容(またはシステムクリップボードの内容)**でした。

この問題は特に以下の構成で再現しました:

  • macOS (WezTerm)
  • tmux をホスト側とコンテナ内両方で利用
  • Neovimで OSC52 を使った vim.g.clipboard を定義

🔍 調査ログ

1. レジスタの状態を確認

Neovimで以下のコマンドを使って、各レジスタの状態を確認:

:reg "
:reg 0
:reg +
  • yy 実行後、無名レジスタ(")には値が入っている

  • p で貼り付けられる内容は + レジスタの中身だった

2. p のマッピングを確認

:verbose nmap p

結果は no mapping found → p はデフォルト挙動のはず。

3. vim.opt.clipboard の影響を再確認

設定では以下を定義していた:

vim.opt.clipboard:append({ "unnamedplus" })

これは p を “+p に読み替える効果を持つ可能性があり、貼り付け元が無名レジスタではなく、+ レジスタになっていた。

4. vim.g.clipboard による外部プロバイダ使用

vim.g.clipboard = {
  name = "osc-copy",
  copy = {
    ["+"] = 'osc copy -d ' .. tty,
    ["*"] = 'osc copy -d ' .. tty,
  },
  paste = {
    ["+"] = 'osc paste -d ' .. tty,
    ["*"] = 'osc paste -d ' .. tty,
  },
  cache_enabled = 0,
}

この設定により、Neovimは “+ や “* レジスタをすべて osc に委ねており、p の貼り付け対象が “0(ヤンクレジスタ)ではなくなっていた。 (yyによるヤンクは正しく機能していたが、pによる貼り付け時に問題が起きていた)

Read more...

neovim関連

プラグインの状況を確認する

コマンドモードで :checkhealth と入力。

neovimでカラフルにする

:checkhealthで次のエラーが出ていた

tmux
   - OK escape-time: 1
   - OK focus-events: on
   - $TERM: tmux-256color
   - WARNING Neither Tc nor RGB capability set. True colors are disabled.     ⤷  'termguicolors' won't work properly.
     - ADVICE:
       - Put this in your ~/.tmux.conf and replace XXX by your $TERM              ⤷  outside of tmux:
         set-option -sa terminal-features ',XXX:RGB'
       - For older tmux versions use this instead:
         set-option -ga terminal-overrides ',XXX:Tc'

いくつか設定に修正が必要だった。

Read more...

vim-refのキーバインドのメモ

vim-refのキーマップ

とりあえず大文字の「K」を押す

| K | カーソルしたのキーワードにジャンプ |

ref-viewerの内部ではKに加えて以下のキーマップが利用できる。要はKやEnterキーで読み進めて、<C-t><C-o> で戻ることができる。

| Enter | カーソル下のキーワードにジャンプ | | ダブルクリック | 同上 | | <C-j> | 同上 | | <C-t> | 前のページに戻る | | <C-o> | 同上 | | <C-i> | 次のページに進む |

Read more...

vimをコンパイル

背景

  • rafi/vim-configを使いたかった
    • Ubuntu 2023.04 のaptパッケージのバージョンは7
      • 2023/05時点、rafi/vim-configが要求するneovimのバージョンが8以上だった
        • このためコンパイルすることにした
      • lazy.nvim は neovim8以上を要求していた。

オフィシャルの手順

コンパイル

# neovim
RUN git clone --depth 1 https://github.com/neovim/neovim.git
RUN apt -y install gettext
RUN cd neovim && \
make CMAKE_BUILD_TYPE=Release && \
make install

CentOS 6.3 vimのコンパイル

CentOS 6.3にVim 7.3をインストールする #CentOS - Qiita

sudo yum install lua lua-devel lua-static mercurial ncurses-devel
mkdir -p ~/tmp/vim/
hg clone https://vim.googlecode.com/hg/ ~/tmp/vim
cd ~/tmp/vim
./configure
./configure --enable-multibyte --with-features=huge --enable-fail-if-missing --enable-luainterp=dynamic --enable-rubyinterp --enable-luainterp --disable-selinux --prefix=/usr/local
make && sudo make install
Read more...

rafi-vim-config

vimというよりはneovimの話になる。

rafi/vim-config vim用のconfigのレポジトリ

個人というよりContributorsが多数いる非常に多機能なneovimの設定を目指したレポジトリ。

rafi/vim-config: Lean mean Neovim machine, carefully crafted with Use with latest Neovim.

  • エラーメッセージが出ている状態だと非常にもっさりする
  • 初回インストール時に大量のプラグインがインストールされる(好みが分かれそうなポイント)

インストール

~/.config/nvim 配下になるようにgit cloneすれば良い。 私はghqを使っているので

ghq get https://github.com/rafi/vim-config.git
cd ~/.config/
ln -s ~/workspace/git/github.com/rafi/vim-config ./nvim

現在の管理方針

2026年時点では、Neovim 本体の設定は rafi/vim-config を upstream として使い、個人差分は別リポジトリに分ける方針にしている。

  • ~/.config/nvim
    • rafi/vim-config 本体
  • ~/.config/nvim/lua/config
    • 個人設定用リポジトリ tin-machine/nvim_config
  • ~/.config/nvim/lua/plugins
    • 個人プラグイン設定用リポジトリ tin-machine/nvim_plugins
  • ~/.config/nvim/lazyvim.json
    • :LazyExtras で有効化した extras の状態

rafi 側の README でも、現在の前提は Neovim 0.11 系で、ユーザー拡張は lua/configlua/plugins に置く構成になっている。 そのため、Ubuntu Desktop でも rafi 本体を直接 fork して改造するより、upstream の lua/rafi 配下には触らず、個人差分だけを別 repo で symlink する方が追従しやすい。

Read more...

vim関連のあれこれ

開いているファイルの文字コードの確認

set fileencoding?

デフォルトの文字コードをUTF8にする

set encoding=utf-8
set fileencodings=utf-8

vim-refでriを検索する

vim-refはRubyに限らずvimでリファレンスを参照するプラグイン、そこからRubyのリファレンス参照コマンドのriを使うプラグインが vim-ref-ri

[[Uniteを使ってriを検索できるvim-ref-riというプラグインを作った|http://yuku-tech.hatenablog.com/entry/20120429/1335628327]

使い方は簡単。vim-refとして検索するなら

:Ref ri NAME

Uniteインタフェースでインクリメンタルに検索したいなら

:Unite ref/ri

と実行する

vim-refで辞書を引く

※ 一通り、動作するように設定できてから気づいた… これは、tmuxで範囲を選択し、翻訳できた方が汎用性が広い…

:Ref alc hello

などとして、vim-refにalcが定義されていた時代もあったのだが、アルクから指摘があり、コードから削除した背景があったようだ

今のvim-refは webdictというソースに変更され、これを設定することで複数ソースに対応している(上記URLのすぐ次のエントリで対応している)

設定方法はvim-refの環境を整えるを参考にした

"webdictサイトの設定
let g:ref_source_webdict_sites = {
\   'je': {
\     'url': 'http://dictionary.infoseek.ne.jp/jeword/%s',
\   },
\   'ej': {
\     'url': 'http://dictionary.infoseek.ne.jp/ejword/%s',
\   },
\   'wiki': {
\     'url': 'http://ja.wikipedia.org/wiki/%s',
\   },
\ }

"デフォルトサイト
let g:ref_source_webdict_sites.default = 'ej'

"出力に対するフィルタ。最初の数行を削除
function! g:ref_source_webdict_sites.je.filter(output)
  return join(split(a:output, "\n")[15 :], "\n")
endfunction
function! g:ref_source_webdict_sites.ej.filter(output)
  return join(split(a:output, "\n")[15 :], "\n")
endfunction
function! g:ref_source_webdict_sites.wiki.filter(output)
  return join(split(a:output, "\n")[17 :], "\n")
endfunction

nmap <Leader>rj :<C-u>Ref webdict je<Space>
nmap <Leader>re :<C-u>Ref webdict ej<Space>

vimのリストいろいろ

2007-01-22 - 窓の外に出てみれば リストいろいろ

Read more...