LINUX.ORG.RU

Делаем из Vim IDE

 , ,

Делаем из Vim IDE

24

5

В стародавние времена когда деревья были большими, трава зеленее, а мороженное стоило по 10 копеек, на Земле жили динозавры, и эти динозавры программировали в Vim.

Предисловие

У Vim есть особый ореол причастности к программистской элите. Умение писать и отлаживать код прямо в терминале — атрибут успешного программиста или девопса, дающий экспы к сеньористости, а так же повод лишний раз выпендриться перед вайтишниками. Я сам какое-то время пользовался Vim, но в определенный момент мне надоело возиться с его настройками.

Ну что ж, вспомним былое и настроим с нуля Vim.

О Vim

Vim — это текстовый редактор для терминала, особенностью которого является переключение режимов.

Существует три основных режима:

  • нормальный;
  • редактирования;
  • командный.

Из нормального режима в режим редактирования (вставки) можно перейти, нажав i. Чтобы выйти из режима вставки и вернуться в нормальный режим, надо нажать <Esc>.

Меметичность этих режимов связана с тем, что на Stack Overflow самым популярным вопросом является «Как выйти из Vim?». Правильный ответ: для этого нужно нажать <Esc> (перейти в нормальный режим), а потом набрать :q!.

Когда вы вводите : в нормальном режиме, то переходите в командный. Из него можно выйти, нажав <Enter>, тем самым выполнив команду (если та была введена) или <Esc>.

Есть так же дополнительные режимы, которые я не буду рассматривать. Есть еще режимы выделения, замены…

Переключение между режимами, например, позволяет быстро перемещаться по тексту, редактировать его. Для этого нужно запоминать кучу клавиш, но избавляет от необходимости постоянно держать руку на мышке. Но слепой 10-пальцевый метод для программиста — вещь сомнительная, и Vim ценят не за быстрый набор текста, а во многом за его расширяемость через плагины. В Vim для написания конфигураций и плагинов используется Vimscript, что является недостатком, ибо нужно учить дополнительный язык с нестандартным синтаксисом. Для Neovim, например, плагины пишутся на Lua, но тут последний рассматриваться не будет.

Далее немного пройдемся по основам, чтобы те кто не видел этого Vim мог хотя бы выйти.

Основы использования

Команды навешиваются на клавиши или их сочетания — маппинги. Базовые легко запомнить тем кто знает английский язык типа u (undo), p (paste), d (delete), но в семье не без уродца y (yank), который служит для копирования…

Существует лишь одна универсальная клавиша — <Esc>. Она выходит из любого режима и отменяет текущие действия. Для удобства выхода из режимов редактирования и вставки вызов этой клавиши вешают на <C-s> или <C-c>. Через <C-...> обозначают сочетания с клавишей Ctrl, <S-...> — Shift и <A-...> — Alt. Так же важен регистр буковок, например, q и Q — это разные команды.

Нормальный режим — это словно нейтральная передача для переключения скоростей. Это основной режим, в котором вы можете перемещаться по тексту, выполнять команды и переключаться между другими режимами. Вот команды, которые работают только в нормальном режиме:

КомандаОписание
iПереключиться в режим вставки перед курсором
IПереключиться в режим вставки в начале строки
aПереключиться в режим вставки после курсора
AПереключиться в режим вставки в конце строки
oПереключиться в режим вставки на новой строке ниже
OПереключиться в режим вставки на новой строке выше
vПереключиться в визуальный режим (посимвольный)
VПереключиться в визуальный режим (построчный)
<C-v>Переключиться в визуальный режим (поблочный)
:Переключиться в командный режим

Команды для навигации и редактирования для нормального режима:

КомандаОписание
hПереместить курсор влево
jПереместить курсор вниз
kПереместить курсор вверх
lПереместить курсор вправо
0Перейти к началу текущей строки
$Перейти к концу текущей строки
:<n>Перейти к определенной строке
ggПерейти к началу файла
GПерейти к концу файла
gxПерейти по ссылке
<C-u>Переместиться на полстраницы вверх
<C-d>Переместиться на полстраницы вниз
<C-b>Переместиться на страницу вверх
<C-f>Переместиться на страницу вниз
<C-o>Перейти к предыдущему положению курсора
<C-i>Перейти к следующему положению курсора после <C-o>
xУдалить символ под курсором
ddУдалить текущую строку
DУдалить оставшуюся строку после курсора
yyСкопировать текущую строку
pВставить скопированный текст после курсора
PВставить скопированный текст перед курсором
uОтменить последнее действие
<C-r>Повторить последнее отмененное действие
.Повторить последнюю команду
cwУдалить слово и перейти в режим вставки
ciwУдалить слово под курсором и перейти в режим вставки
c$Удалить текст от курсора до конца строки и перейти в режим вставки
c0Удалить текст от курсора до начала строки и перейти в режим вставки
:%s/old/new/gЗаменить все вхождения «old» на «new» во всем файле
:wСохранить файл
:qВыйти из Vim
:wqСохранить файл и выйти из Vim
:xСохранить файл и выйти из Vim [2]
:q!Выйти из Vim без сохранения

Так же, например, мы можем введя 3b переместиться на 3 слова назад, 5l — на 5 символов вправо, 10dd удалит 10 строк, включая текущую. Что такое есть знать нужно, но применяется это в основном для «программирования» редактора.

Команды режима вставки:

КомандаОписание
Ctrl+wУдалить слово перед курсором
Ctrl+uУдалить текст от курсора до начала строки
Ctrl+tСдвинуть текущую строку вправо
Ctrl+dСдвинуть текущую строку влево
Ctrl+oВременно перейти в нормальный режим для выполнения одной команды

Команды визуального режима:

КомандаОписание
dУдалить выделенный текст
yСкопировать выделенный текст
>Сдвинуть выделенный текст вправо
<Сдвинуть выделенный текст влево
oПереместить курсор в противоположный угол выделения
OПереместить курсор в противоположный угол выделения (для блочного режима)
~Изменить регистр выделенного текста
guСделать выделенный текст строчными буквами
gUСделать выделенный текст заглавными буквами
JОбъединить выделенные строки в одну
gqОтформатировать выделенный текст

Пример 1: жмем V (режим выделения строк), cтрелками выделяем текст, нажимаем и жмем d чтобы удалить блок кода.

Пример 2: для добавления отступов, жмем v, перемещаем курсор до нужно места и жмем > для увеличения отступов или < — для уменьшения.

Поиск по тексту осуществляется /. Эта команда не работает в режиме редактирования. Чтобы перейти к следующему результату используйте n, предыдущему N.

Адок? — В общем-то, да, но попоболь сглаживает то, что Vim — это программируемый редактор, где на сочетания клавиш можно повесить как бы ввод других сочетаний. Это делается командами map и noremap. Первая является рекурсивной и выполняет все сочетания, которые были навешены на используемые в ней сочетания. У этих двух команд есть версии с преффиксами, обозначающими версии для соответствующих режимов.

Про интерфейс и буферы

Буферы в Vim — это область памяти, в которой хранятся данные. Окна служат для отображения буферов, но буферы никак не привязаны к окну. Когда мы что-то открываем через :e, то содержимое текущего окна заменяется на содержимое файла, но сам буфер остается в памяти. Чтобы просматривать буферы, используйте команды :ls(list), :bp(previous) и bn(next).

Вкладки содержат окна. По умолчанию у нас одна вкладка и одно окно в нем, но окон во вкладке может быть более одного. Если закрыть последнее окно, то закроется и вкладка вместе с vim (что логично). Для перемещения используется Ctrl-W + h, j, k, l. Для разбиения окна используются команды :split (по горизонтали) и :vsplit (по вертикали). Вкладки можно открывать (:tabnew), закрывать (:tabclose) и перемещаться по ним (:tabprevious, :tabnext) и тд. Вместо :e можно использовать :tabedit.

Внизу располагается строка (ряд) статуса. В нем отображается режим и прочая полезная информация. Он же служит полем для ввода команд. Историю введенных команд можно увидеть, нажав q:. Чтобы переместиться в конец командной строки, используем Ctrl-e, в начало — Ctrl-b.

Подготовка

Установите vim любым доступным способом, но лучше через пакетный менеджер:

# этот пакет собран без unnamed, а значит текст копированный в vim нельзя будет вставить в браузере без костылей с xclip или плагинов
yay -S vim

# можно поставить vim с фронтендом в виде gtk, он содержит все нужные флаги, но придется доставить мегабайты gtk-шного мусора 
yay -S gvim

sudo apt install -y vim

Чтобы не засирать мусором хомяка, перенесем конфиги туда, где они должны находиться.

Добавьте переменные окружения в .bashrc или .zshrc, либо другое удобное вам место (~/.zshenv и т.п.):

# Это костыль который позволяет обойти захардкоженное поведение vim и разместить конфиг в любом месте
export VIMINIT='source $MYVIMRC'
export VIMHOME=${XDG_CONFIG_HOME:-$HOME/.config}/vim
export MYVIMRC=$VIMHOME/vimrc

Если вы до сих пор не установили переменные окружения xdg, то почитайте эту статью.

Так же можете установить переменную EDITOR, чтобы vim вызывался для редактирования тех же коммитов:

EDITOR=vim
VISUAL=$EDITOR
export EDITOR VISUAL

Еще можно добавить алиас для редактирования конфига:

alias vimrc='vim $MYVIMRC'

Чтобы переменные применились, выполните:

exec -l "$SHELL"

Создайте каталог:

mkdir -p $VIMHOME

Теперь нам нужно поставить менеджер плагинов. Без менеджера плагинов обойтись можно, но они сильно упрощают работу с плагинами, что делает их незаменимыми помощниками. Самым популярным является vim-plug, значит будем его использовать.

Установка на примере Arch:

yay -S vim-plug

В конфиге добавлена автоматическая установка vim-plug, но он не будет обновляться в отличии от пакета из репозитория.

Приступим к редактированию конфига:

kate $MYVIMRC

Минимальный конфиг

Минимальный конфиг с использование vim-plug будет выглядеть так:

" Устанавливаем переменные окружения, если они не заданы
if empty($VIMHOME)
  let $VIMHOME = expand('~/.vim')
endif

if empty($MYVIMRC)
  let $MYVIMRC = expand('%:p')
endif

" Проверяем, есть ли уже путь в runtimepath
if index(split(&runtimepath, ','), expand('$VIMHOME')) == -1
  " Если пути нет, добавляем его
  set runtimepath+=$VIMHOME
endif

" Проверяем, установлен ли vim-plug, и устанавливаем его при необходимости
" filereadable не умеет работать с путями, начинающимися с '~', поэтому
" используется странная конструкция empty(glob('...'))
if empty(glob($VIMHOME . '/autoload/plug.vim')) && !filereadable('/usr/share/vim/vimfiles/autoload/plug.vim')
  silent !curl -fLo $VIMHOME/autoload/plug.vim --create-dirs
      \ https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
endif

" Автоматически ставим отсутствующие плагины
autocmd VimEnter *
  \  if len(filter(values(g:plugs), '!isdirectory(v:val.dir)'))
  \|   PlugInstall --sync | source $MYVIMRC
  \| endif

" Инициализируем vim-plug
call plug#begin('$VIMHOME/plugged')

" Добавляем плагины
Plug 'tpope/vim-sensible'  " Настройки по умолчанию для Vim

" Тут добавляем свои плагины

" Завершаем инициализацию vim-plug
call plug#end()

" А тут пользовательские настройки и настройки плагинов

Пользовательские настройки должны идти после плагинов, так как в плагинах многие настройки могут быть переопределены.

vim-plug плагины по умолчанию ищет на хостинге исходного кода github.com. Т.е. плагин tpope/vim-sensible будет скачен с https://github.com/tpope/vim-sensible.

Используйте :source $MYVIMRC либо :so %, если текущий редактируемый файл vimrc, для применения настроек.

Чем хорош этот конфиг:

  • Учитывается случай, если нужные переменные окружения не были установлены.
  • $VIMHOME добавляется в runtimepath. Без этого, например, не будут работать темы из ~/.config/vim.
  • vim-plug ставится автоматически, если его нет в системе — что полезно для бубунтят.
  • Плагины ставятся автоматически после добавления их в конфиг.

Как пользоваться?

  • Установить плагины можно, выполнив :PlugInstall.
  • Для обновления используйте :PlugUpdate. Так же можно указать конкретный плагин для обновления.
  • :PlugClean позволяет удалить неиспользуемсые плагины.
  • :PlugStatus показывает плагины, которые можно обновить.

Все установленные плагины можно снести так:

rm -rf $VIMHOME/plugged

Базовые настройки

Допишем в конец файла любые нужные настройки, но учитывайте, что в vim-sensible тоже задаются настройки:

" Базовые настройки

" Настройки ввода

" В coc.nvim прокрутка с помощью клавиш C-f и C-b не работает в vim
set mouse=a

" Включаем использование системного буфера
set clipboard=unnamedplus

" Задержка в мс для сочетаний клавиш
set timeoutlen=500


" Работа с текстом

" Табуляция и отступы
set tabstop=2
set shiftwidth=2
set expandtab

" Python использует 4 пробела для отступов
autocmd FileType python setlocal tabstop=4 shiftwidth=4

" Кодировка текста
set encoding=utf-8
set fileencoding=utf-8
set fileencodings=utf-8,cp1251,koi8-r,cp866

" Поиск по тексту
set hlsearch " подсвечивать результаты поиска

" Перемещение по тексту
" Когда достигаем границ строки, то перемещаемся на предыдующую/следующую
set whichwrap+=h,l,<,>,[,]

" Визуальные настройки

" Включаем номера строк
set number

" Отображение скрытых символов
set list
set listchars=tab:»·,trail:·,nbsp:␣,extends:>,precedes:<

" Ширина строки и красная линия
set textwidth=80
set cc=+1

" Если мешает отображение режима в поле для команд
set noshowmode

" Настройки автодополнения
set completeopt=menu,menuone,noselect

" Разделение экрана
set splitbelow " разбивать вниз
set splitright " разбивать вправо

" Задержка CursorHold
set updatetime=100

" Настройки поведения
" Отключаем visual bell
set noerrorbells
set novisualbell
set t_vb=

" Игнорировать 'No write since last change' (буфер не сохранен)
set hidden

" Отключить создание бекапов, своп-файлов и файлов отмены
set nobackup noundofile noswapfile

" Эти комментарии потенциально опасны
set nomodeline

" Включаем автоматическое обновление буфера
set autoread

" Обновляем буфер при изменении файла внешними инструментами
autocmd FocusGained,BufEnter * checktime

Сочетания клавиш:

" Переход в нормальный режим
inoremap <C-s> <Esc>
vnoremap <C-s> <ESC>

" Копирование в системный буфер
vnoremap <C-c> "+y

" Выделение всего текста
nnoremap <C-a> ggVG
inoremap <C-a> <Esc>ggVG

" Использование h, j, k, l для перемещения с зажатым Ctrl в режиме редактирования
inoremap <C-h> <Left>
inoremap <C-j> <Down>
inoremap <C-k> <Up>
inoremap <C-l> <Right>

" Переместиться в начало строки
inoremap <C-0> <Home>
" Переместиться в конец строки
inoremap <C-$> <End>
" Переместиться к первому непробельному символу
inoremap <C-^> <Home>

" Клавиши leader и альтернативная основной
let g:mapleader = "\<Space>"
let g:maplocalleader = ','

" Очистить результаты поиска
nnoremap <leader>h :noh<CR>

" Переключение между вкладками
nnoremap <leader>t :tabnext<CR>
nnoremap <leader>T :tabprevious<CR>

" Список вкладок
nnoremap <leader>tl :tabs<CR>

nnoremap <leader>tn :tabnew<CR>
nnoremap <leader>tc :tabclose<CR>
nnoremap <leader>to :tabonly<CR>
nnoremap <leader>tm :tabmove<CR>

" Редактировать файл в новой вкладке
nnoremap <leader>te :tabedit |

" Выбор вкладки
nnoremap <leader>1 1gt
nnoremap <leader>2 2gt
nnoremap <leader>3 3gt
nnoremap <leader>4 4gt
nnoremap <leader>5 5gt
nnoremap <leader>6 6gt
nnoremap <leader>7 7gt
nnoremap <leader>8 8gt
nnoremap <leader>9 9gt
nnoremap <leader>0 :tablast<CR>

" Разбиение окон
nnoremap <leader>s :split<CR>
nnoremap <leader>v :vsplit<CR>

" Выбор окна
nnoremap <C-h> <C-w>h
nnoremap <C-j> <C-w>j
nnoremap <C-k> <C-w>k
nnoremap <C-l> <C-w>l

" Сделать окна одного размера
nnoremap <leader>= <C-w>=

" Переключения между буферами
nnoremap <leader>b :bnext<CR>
nnoremap <leader>B :bprevious<CR>
nnoremap <leader>l :ls<CR>
nnoremap <leader>d :bd<CR>

" Скрыть/раскрыть блок кода
nnoremap <leader>z za

" Добавление и удаление отступов
nnoremap > >>
nnoremap < <<
vnoremap < <gv
vnoremap > >gv

" Сохранение и закрытие
nnoremap <leader>w :w<CR>
nnoremap <leader>q :q<CR>

" Сохранить файл с sudo
" https://stackoverflow.com/questions/2600783/how-does-the-vim-write-with-sudo-trick-work
cmap w!! w !sudo tee > /dev/null %

" Редактирование конфига
nnoremap <leader>ev :tabedit $MYVIMRC<CR>

" Применить конфиг
nnoremap <leader>sv :so $MYVIMRC<CR>

Справку по настройкам можно прочитать тут либо посмотреть ее прямо из Vim:

" Справка по всем настройкам
:help options

" Можно посмотреть конкретные
:help number

В help встречаются имена файлов со справкой, которые можно просматривать. Переместите курсор на имя файла, введите :help и нажмите <C-r>, <C-w>, так можно вставить имя файла под курсором и посмотреть справку.

Чтобы узнать значение настройки, используйте:

set clipboard?

В данном конфиге в качестве leader был задан пробел. По умолчанию leader является \. leader используется в пользовательских сочетаниях клавиш (мэппингов).

" посмотреть значение
:echo mapleader

" задать альтернативное
let g:mapleader = ","

Чтобы посмотреть сочетания:

:map

Если хочется увидеть где заданы «мэппинги»:

:verbose map

Для конкретного сочетания клавиш:

:verbose map <C-v>

Для просмотра клавиш различных режимов используйте префиксы (:imap, :vmap и т.п.).

В командах *map комментарии обрабатывается несколько иначе:

let answer = 42  " Это комментарий

inoremap <C-h> <Left>  " Это часть команды, а не комментарий!

В последнем случае при нажатии на Ctrl-h в режиме редактирования будет вставлен текст. Комментарии справа от *map лучше не использовать. Если очень нужно, то можно использовать конструкции типа nnoremap ...| " Описание.

Добавим плагины

Используемые плагины:

  1. scrooloose/nerdtree — Файловый менеджер для Vim, который позволяет просматривать структуру файлов и каталогов в виде дерева.
  2. junegunn/fzf.vim — Fuzzy finder для Vim, который позволяет быстро находить файлы, строки и другие элементы в проекте.
  3. jiangmiao/auto-pairs — Автоматическое закрытие пар символов в Vim
  4. tpope/vim-surround — Плагин для добавления, изменения и удаления скобок, кавычек и других символов вокруг текста.
  5. ervandew/supertab — Плагин для автодополнения с использованием клавиши <Tab>, упрощающий набор кода.
  6. tpope/vim-commentary — Плагин для быстрого комментирования и раскомментирования строк кода.
  7. airblade/vim-gitgutter — Плагин, который показывает изменения в Git в виде значков в сайдбаре.
  8. neoclide/coc.nvim — Плагин для автодополнения и языковой поддержки, основанный на LSP (Language Server Protocol).
  9. dense-analysis/ale — Плагин для линтинга и форматирования кода, поддерживающий множество языков программирования.
  10. puremourning/vimspector — Плагин для отладки кода, который поддерживает множество языков программирования и позволяет легко настраивать и использовать отладчик в Vim.
  11. ryanoasis/vim-devicons — Плагин, добавляющий иконки для файлов и папок в Vim, улучшая визуальное восприятие файловой структуры.
  12. nathanaelkane/vim-indent-guides — Плагин для отделения отступов, делающий структуру кода более наглядной.
  13. luochen1990/rainbow — Плагин для разноцветной подсветки скобок, упрощающий понимание вложенности кода.
  14. vim-airline/vim-airline — Плагин для улучшения статус-бара Vim, добавляющий дополнительную информацию и улучшающий визуальный вид.
  15. vim-airline/vim-airline-themes — Коллекция тем для плагина vim-airline, позволяющая настроить внешний вид статус-бара.
  16. joshdick/onedark.vim — Тема для Vim, основанная на популярной теме One Dark для Visual Studio Code.
  17. editorconfig/editorconfig-vim — Плагин для поддержки .editorconfig.

Для примера я добавлю настройки именно для Python, потому что я его использую. Как настроить ale, coc и viminspector для работы с другими языками нагуглите сами, на худой конец спросите у ChatGPT.

А теперь добавим плагины:

Plug 'scrooloose/nerdtree' " Файловый менеджер
" Плагин может установить fzf, если того нет
"Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }
Plug 'junegunn/fzf.vim' " Нечеткий поиск строк
Plug 'jiangmiao/auto-pairs' " Автоматическое закрытие скобок и кавычек
Plug 'tpope/vim-surround' " Добавляет, изменяет, удаляет закрывающие скобки, кавычки и тд
Plug 'ervandew/supertab' " Автодополнение с использованием <Tab>
Plug 'tpope/vim-commentary' " Комментирование строк кода
Plug 'airblade/vim-gitgutter' " Показываем изменения в Git
Plug 'neoclide/coc.nvim', {'branch': 'release'} " Автодополнение и языковая поддержка
Plug 'dense-analysis/ale' " Линтинг и форматирование
Plug 'puremourning/vimspector' " Дебаггер
Plug 'ryanoasis/vim-devicons' " Иконки для файлов и папок
Plug 'nathanaelkane/vim-indent-guides' " Визуальное отделение отступов
Plug 'luochen1990/rainbow' " Разноцветная подсветка скобок
Plug 'vim-airline/vim-airline' " Airline status bar
Plug 'vim-airline/vim-airline-themes' " Airline themes
Plug 'joshdick/onedark.vim' " One Dark theme
Plug 'editorconfig/editorconfig-vim' # Editor Config Support

Настройка плагинов

Для начала установим зависимости:

# Fuzzy Search
# Если в вашем дистрибутиве нет такого пакета, он будет скачен
yay -S fzf ripgrep

# Зависимости coc, который ставит свои расширения через npm
yay -S nodejs

# Зависимости Python
yay -S ruff pyright python-{black,isort,debugpy}

# бубунтята могут поставить пакеты так
pipx install black isort ruff pyright debugpy

# Если пишите на Go, то поставьте gopls и тд

Для отображения значков и спецсимволов нужен какой-нибудь Nerd-шрифт:

yay -S ttf-jetbrains-mono-nerd

В настройках терминала сделайте его используемым.

Дописываем в конфиг эти настройки:

" Настройки для NERDTree
nnoremap <C-n> :NERDTreeToggle<CR>

" Настройка fzf.vim
" yay -S fzf ripgrep
let g:fzf_layout = { 'window': { 'width': 0.8, 'height': 0.6 } }

nnoremap <leader>f :Rg<CR> " Поиск файлов по содержимому
nnoremap <leader>ff :Files<CR> " Поиск файлов
nnoremap <leader>fl :Lines<CR> " Поиск строк в файлах
nnoremap <leader>fb :Buffers<CR> " Поиск буферов


" Настройки для vim-gitgutter
set updatetime=100

" Функция для переключения vim-gutter
function! ToggleGitGutter()
  if exists('g:gitgutter_enabled') && g:gitgutter_enabled
    GitGutterDisable
  else
    GitGutterEnable
  endif
endfunction

" Назначение сочетания клавиш для переключения vim-gutter
nnoremap <leader>gg :call ToggleGitGutter()<CR>
nmap ]h <Plug>(GitGutterNextHunk)
nmap [h <Plug>(GitGutterPrevHunk)


" Настройки для vim-devicons
let g:webdevicons_enable = 1
let g:webdevicons_enable_nerdtree = 1
let g:webdevicons_enable_airline_tabline = 1
let g:webdevicons_enable_airline_statusline = 1

" Настройки для отступов
let g:indent_guides_enable_on_vim_startup = 1

" Настройки для разноцветной подсветки скобок
let g:rainbow_active = 1

" Настройки для vim-airline
let g:airline#extensions#tabline#enabled = 1
let g:airline#extensions#tabline#buffer_nr_show = 1
let g:airline#extensions#tabline#formatter = 'unique_tail'
let g:airline_powerline_fonts = 1
let g:airline_theme = 'onedark'

" Настройки для темы
set termguicolors
set background=dark
color onedark

Учтем что некоторые языки используют 4 отступа вместо 2:

autocmd FileType python setlocal tabstop=4 shiftwidth=4

Coc

coc — это сервер, написанный на Node.js с использованием TypeScript, который необходим для автодополнения кода. Он работает через расширения и сам их ставит при необходимости через npm. Vimscript в этом плагине нужен лишь как запускалка ноды и выполнения запросов.

Следует отметить, что некоторые средства разработки могут быть поставлены вместе с расширением

" Список расширений
let g:coc_global_extensions = [
    \ 'coc-pyright',
    \ 'coc-tsserver',
    \ 'coc-json',
    \ 'coc-html',
    \ 'coc-css',
    \ 'coc-go'
    \ ]

" Настройки автодополнения, необходимые для плагина
set completeopt=menu,menuone,noselect

" Включение подсказок при наведении
let g:coc_enable_hover = 1

" Подтверждение выбора в автодополнении
inoremap <silent><expr> <CR> coc#pum#visible() ? coc#pum#confirm()
                              \: "\<C-g>u\<CR>\<c-r>=coc#on_enter()\<CR>"

" Навигация по списку автодополнения
inoremap <silent><expr> <C-n> coc#pum#next(1)
inoremap <silent><expr> <C-p> coc#pum#prev(1)

" Вызов всплывающей справки
nmap <silent> K :call CocAction('doHover')<CR>

" История изменений
nmap <silent> cc <Plug>(coc-codelens-action)

" Форматирование
nmap <silent> cf <Plug>(coc-format)

" Переименование
nmap <silent> cr <Plug>(coc-rename)

" Переходы по коду
nmap <silent> gd <Plug>(coc-definition)
nmap <silent> gy <Plug>(coc-type-definition)
nmap <silent> gi <Plug>(coc-implementation)
nmap <silent> gr <Plug>(coc-references)

" Тоже самое только отображается в новом "окне" (экран разбивается)
nmap <silent> <leader>gd :call CocAction('jumpDefinition', 'split')<CR>
nmap <silent> <leader>gy :call CocAction('jumpTypeDefinition', 'split')<CR>
nmap <silent> <leader>gi :call CocAction('jumpImplementation', 'split')<CR>
nmap <silent> <leader>gr :call CocAction('jumpReferences', 'split')<CR>

Если в нормальном режиме навести курсор, например, на функцию и нажать на K (Shift + k), то будет показана ее сигнатура. Если набрать <Leader>gd, то экран будет разбит на две части, и в новой части отобразится объявление функции. Можете добавить еще это в конфиг, если не устраивает как происходит разбиение экрана:

set splitbelow " Разбиение экрана вниз по умолчанию
set splitright " Разбиение экрана вправо по умолчанию

Сам coc так же настраивается через coc-settings.json который лежит в каталоге с настройками vim. Его можно открыть, выполнив:

:CocConfig

Например, можно в co-pyright отключить надоедливую подстановку инлайновых тайп-хинтов:

{
  "pyright.inlayHints.functionReturnTypes": false,
  "pyright.inlayHints.variableTypes": false,
  "pyright.inlayHints.parameterTypes": false
}

Расширения coc хранятся в ~/.config/coc. Стоит отметить, что плагин использует расширения… от vscode.

ALE

Asynchronous Lint Engine выполняет проверку синтаксиса и форматирует код.

let g:ale_linters = {
\   'python': ['ruff'],
\   'javascript': ['eslint', 'tsserver'],
\   'json': ['jsonlint'],
\   'html': ['htmlhint'],
\   'css': ['stylelint'],
\   'go': ['gopls', 'golangci-lint'],
\}

" у меня ruff не форматирует файл, поэтому укажем что-то другое
let g:ale_fixers = {
\   'python': ['isort', 'black'],
\   'javascript': ['eslint', 'prettier'],
\   'json': ['prettier'],
\   'html': ['prettier'],
\   'css': ['stylelint', 'prettier'],
\   'go': ['gofmt', 'goimports'],
\}

" Автоматическое исправление при сохранении
let g:ale_fix_on_save = 1

" ale не читает никакие конфиги, их нужно задавать через аргументы, писать
" функции чтобы те искали их и подставляли как аргумент
let g:ale_python_black_options = '--line-length 80'

let g:ale_go_golangci_lint_options = ''
let g:ale_go_golangci_lint_package = 1

Чтобы посмотреть отладочную информацию выполните:

:ALEInfo

Прочтите справку:

:help ale_linters
:help ale_fixers

VimSpector

Его настройки описаны тут.

Нам нужно указать минимум одну, потому как по умолчанию используются сочетания для рептилоидов:

let g:vimspector_enable_mappings = 'HUMAN'

Чтобы запустить код, нужно создать конфиг .vimspector.json в корне проекта типа этого:

{
  "configurations": {
    "Run Current File": {
      "adapter": "debugpy",
      "configuration": {
        "type": "python",
        "request": "launch",
        "program": "${file}",
        "console": "integratedTerminal"
      },
      "breakpoints": {
        "exception": {
          "raised": "",
          "uncaught": "Y",
          "userUnhandled": "N"
        }
      }
    }
  }
}

Обратите внимание на свойство breakpoints.exception. vimspector если эти значения не заданы спрашивает uncaught: ...Break on Uncaught Exceptions и предлагает ввести N или Y либо использовать значение по умолчанию. Чтобы постоянно при запуске дебаггера не отвечать на одни и те же вопросы, ответы на них можно прописать. uncaught — имя настройки (они все до :), которой задаем значение. Пустая строка тут — это значение, которое и предлагается по умолчанию, т.е. все три можно оставить пустыми.

Многие, наверное, заметили, что конфиг что-то подозрительно напоминает… — Да, это еще один подарок ненужноэлектронщикам от разработчиков VS Code (там в основе дебаггер от него).

Прочитать про настройку можно тут.

Работает дебаггер так: перемещаемся к нужной строке, нажимаем <F9> и ставим breakpoint, потом нажимаем <F5> для старта отладки, и в новой вкладке запускается отладчик, где экран разит на много окошечек, и даже есть примитивный TUI с кнопочками. Если клавишу нажать еще раз, то отладчик перейдет к следующему шагу, и <F3> можно использовать для ее завершения.

EditorConfig

С помощью конфигурационного файла .editorconfig, расположенного в корне проекта (с root = true), можно задать правила форматирования кода, не прибегая к редактированию конфига vim, а так же избежать использования потенциально опасного modeline (комментарии типа # vim: ts=4 sw=4 et). Это крайне необходимо для совместной работы.

По умомлчанию расширению не требуются сторонние утилиты, но если те имеются, то можно указать в настройках путь до команды:

let g:EditorConfig_core_mode = 'external_command'

" Указывать нужно полный путь, который можно получить так
let g:EditorConfig_exec_path = exepath('editorconfig')

Для глобальных настроек используйте ~/.editorconfig или ~/.config/.editorconfig. Это зависит от настроек и используемой утилиты, некоторые из них поддерживают переменную $EDITORCONFIG в отличии от нативной реализации.

Пример универсального конфига:

# EditorConfig is awesome: https://EditorConfig.org

# Применять эти настройки ко всем вложенным файлам
root = true

# Стиль применяемый ко всем файлам
[*]
end_of_line = lf  # Стиль переноса строк
insert_final_newline = true  # Финальный перенос
charset = utf-8  # Кодировка по умолчанию
trim_trailing_whitespace = true  # Удаление пробелов в конце строк
indent_style = space  # Стиль отступов
indent_size = 2  # Размер отступа по умолчанию
max_line_length = 80  # Максимальная длина строки

# Для питона
[*.py]
indent_size = 4

# Для Go
[*.go]
# indent_size игнорируется, если indent_style установлен в tab
indent_style = tab

Это как минимум решит проблемы с пробелами в конце строк и отстутствием завершающего переноса строки в файле. В этом конфиге так же описаны все возможные настройки EditorConfig.

Тестирование сборки

Теперь протестируем нашу сборку.

Vim позволяет открывать как файлы так и каталоги:

# Открыть текущий каталог
vim .

Будет выведена ошибка:

...
E185: Cannot find color scheme 'onedark'
Press ENTER or type command to continue

Жмем ENTER. Начнется установка плагинов и расширений для coc. Ждем завершения установки. С помощью :q можно позакрывать окна с сообщениями об установке.

У вас в итоге должно отобразиться содержимое каталога. Выберите любой файл, и он откроется на весь экран. Чтобы отобразить дерево файлов сбоку, нажмите Ctrl-n. Если нажать это сочетание ещё раз, оно скроется. Можно попробовать создать файл, потренироваться в редактировании.

Можно ли это назвать IDE?

— Да. Есть не очень умные люди, которые IDE считают только то, что в названии имеет оное слово. Вопросы терминологии всегда являются предметом ожесточенных срачей с переходом на личночти и угрозами вычислить по ip. Камнем претконевения тут является слово интегрированная, т.е. нужна среда разработки, которая может заставить совместно работать различные сторонние средства разработки вместе на благо партии и народа. Но данное определение не является полным.

Текстовый редактор от блокнота отличают наличие автодополнения и подсветки синтаксиса. IDE тоже умеет в подсветку синтаксиса и автодополнение. Среду разработки от текстового редактора отличает следующее:

  • Автодополнение осуществляется с использованием синтаксического анализа, а не просто всех встречающихся слов в тексте.
  • Исходный код проверяется на синтаксические ошибки, а так же осуществляется проверка стилистики и возможных проблем в коде (линтинг).
  • Есть форматирование кода. Правила форматирования должны как-то задаваться, чтобы код могла разрабатывать команда.
  • Отладка кода. Без нее в принципе невозможна разработка чего-либо серьезного (у фанатов Столярова другое мнение).
  • Поддержка VCS (систему контроля версий) таких как Git (другие сейчас не применяются).
  • И все это должно быть интегрировано в IDE, те запускаться не через :!, а самим редактором как раз таки через плагины/расширения.

Vim с помощью используемых плагинов вполне себе элегантно превращается в IDE.

Что можно еще добавить/изменить?

Многое в конфиге можно и нужно улучшить!

Можно добавить какие-нибудь попсовые плагины типа этого:

Plug 'terryma/vim-multiple-cursors'

Так же можно поставить вместо fzf.vim (некоторых не устраивает, что тот игнорирует тему):

Plug 'ctrlpvim/ctrlp.vim'

С помощью liuchengxu/vim-which-key можно подсматривать сочетания клавиш:

" При нажатии на <leader> подсказывает доступные сочетания с пробелом
nnoremap <silent> <leader> :WhichKey '<Space>'<CR>

" Так выведет все сочетания
nnoremap <silent> <leader>? :WhichKey ''<CR>

" Уменьшаем задержку для сочетаний
set timeoutlen=500

Альтернативой coc является vim-lsp. Он так же как и первый работает через языковой протокол LSP. Его настройка несколько сложнее: coc ставит расширения автоматически с языковыми серверами, которые у них указаны в зависимостях.

С использованием vim-lsp языковые сервера нужно ставить самостоятельно:

npm install -g pyright

И пример настройки:

call plug#begin('$VIMHOME/plugged')

" ...
Plug 'prabirshrestha/vim-lsp'
" ...

call plug#end()

if executable('pyright-langserver')
    au User lsp_setup call lsp#register_server({
        \ 'name': 'pyright',
        \ 'cmd': {server_info->['pyright-langserver', '--stdio']},
        \ 'whitelist': ['python'],
        \ })
endif

" Настройка автодополнения
set completeopt=menu,menuone,noselect

" Настройка сочетаний клавиш для LSP
nnoremap <silent> gd :LspDefinition<CR>
nnoremap <silent> gr :LspReferences<CR>
nnoremap <silent> gi :LspImplementation<CR>
nnoremap <silent> gt :LspTypeDefinition<CR>
nnoremap <silent> <leader>rn :LspRename<CR>
nnoremap <silent> K :LspHover<CR>
nnoremap <silent> <leader>ca :LspCodeAction<CR>
nnoremap <silent> <leader>fmt :LspDocumentFormat<CR>

Ну и можно интегрировать vim с ChatGPT через madox2/vim-ai (в теории плагин может работать с каким угодно провайдером через OpenAI API) чтобы вместо выдумывания каверзных вопросов Гуголу с хождением по ссылкам, получать куски кода сразу прямиком с SO.

Дополнения

Создание своих тем для Vim

Если вам нравится какая-то тема, но ее нет на Vim Awesome либо она как тамошняя Solarized Dark выглядит как УГ, то вы можете создать свою. Есть, конечно, специализорованные сервисы, но можно об одолжении попросить какую генеративную нейросеточку.

Подготовка:

# Создадим каталог для тем
mpkdir -p $VIMHOME/colors

Теперь откроем $VIMHOME/colors/solarzed_dark.vim и вставим:

" Solarized Dark Truecolor Theme for Vim
" Based on the Solarized palette
" https://ethanschoonover.com/solarized/

set background=dark
hi clear

if exists("syntax_on")
  syntax reset
endif

let g:colors_name = "solarized_dark"

" Solarized base colors
let s:base03  = "#002b36"
let s:base02  = "#073642"
let s:base01  = "#586e75"
let s:base00  = "#657b83"
let s:base0   = "#839496"
let s:base1   = "#93a1a1"
let s:base2   = "#eee8d5"
let s:base3   = "#fdf6e3"
let s:yellow  = "#b58900"
let s:orange  = "#cb4b16"
let s:red     = "#dc322f"
let s:magenta = "#d33682"
let s:violet  = "#6c71c4"
let s:blue    = "#268bd2"
let s:cyan    = "#2aa198"
let s:green   = "#859900"

" Normal text and background
exe "hi Normal guifg=".s:base0." guibg=".s:base03

" Comments
exe "hi Comment guifg=".s:base01." gui=italic"

" Constants
exe "hi Constant guifg=".s:cyan

" Identifiers
exe "hi Identifier guifg=".s:blue

" Statements (keywords like 'if', 'for', etc.)
exe "hi Statement guifg=".s:green

" PreProc (macros, includes)
exe "hi PreProc guifg=".s:orange

" Type (int, char, etc.)
exe "hi Type guifg=".s:yellow

" Special (special characters, like function names)
exe "hi Special guifg=".s:red

" Underlined text
exe "hi Underlined guifg=".s:violet." gui=underline"

" Error messages
exe "hi Error guifg=".s:red." guibg=".s:base03

" Visual mode selection
exe "hi Visual guibg=".s:base02

" Line numbers
exe "hi LineNr guifg=".s:base01

" Cursor line number
exe "hi CursorLineNr guifg=".s:yellow

" Search highlighting
exe "hi Search guifg=".s:base03." guibg=".s:yellow

" MatchParen (matching parenthesis)
exe "hi MatchParen guifg=".s:base03." guibg=".s:blue

" Status line
exe "hi StatusLine guifg=".s:base0." guibg=".s:base02
exe "hi StatusLineNC guifg=".s:base01." guibg=".s:base02

" Popup menu for autocomplete
exe "hi Pmenu guifg=".s:base0." guibg=".s:base02
exe "hi PmenuSel guifg=".s:base03." guibg=".s:blue

" Tabs
exe "hi TabLine guifg=".s:base0." guibg=".s:base02
exe "hi TabLineSel guifg=".s:base03." guibg=".s:blue
exe "hi TabLineFill guibg=".s:base02

Тут представлены классические цвета.

Остается только в конфиг прописать тему:

" Настройки для темы
set background=dark

color solarized_dark

" Мне не нравится красные вертикальные границы
hi ColorColumn ctermbg=lightgrey guibg=lightgrey

" Сделаем чтобы границы были на 80, 100 и 110 символов
set cc+=+21,+31

Alacritty + Zellij

Vim удобнее всего использовать в связке Alacritty и Zellij.

Alacritty — это терминал, написанный на Rust, но не стоит его недооценивать из-за этого. Он имеет небольшой размер ~9 MiB, поддерживает аппаратное ускорение через GPU и поддерживает юникод. Однако, у него есть некоторые ограничения: отсутствие поддержки табов, вкладок, вывода изображений и лигатур (которые в htop только мешают).

Установка Alacritty:

yay -S alacritty

Zellij — это современный терминальный мультиплексор, который позволяет управлять несколькими терминальными сессиями в одном окне. Помимо управления сессиями, он дает возможность управлять вкладками и панелями. Для Linux уже есть другие мультиплексоры, такие как GNU Screen и Tmux. Первый — анохронизм в наши дни, а Tmux, хоть и «популярный», имеет ужасный интерфейс. Можно сказать, что его нет, и вам помимо заучивания кучи сочетаний для Vim нужно будет заучить еще и его сочетания. В Zellij почти все доступные режимы и сочетания для них отображаются на экране.

Установка Zellij:

yay -S zellij

Для начала работы с Zellij, создадим конфигурационный файл, который будет содержать настройки по умолчанию.

mkdir -p ~/.config/zellij
zellij setup --dump-config > ~/.config/zellij/config.kdl

Откроем созданный конфигурационный файл и установим режим по умолчанию на locked:

vim ~/.config/zellij/config.kdl
default_mode "locked"

Использование этого режима при старте терминала позвляет избежать конфликта сочетаний клавиш.

Чтобы Alacritty запускал Zellij при старте, добавим соответствующую настройку в конфигурационный файл Alacritty.

~/.config/alacritty/alacritty.toml:

[terminal.shell]
program = "zellij"
args = [ ]

Как с ним работать?

  • Запустите терминал.
  • Нажмите Ctrl-g для выхода из режима блокировки интерфейса.
  • Смотрите подсказки внизу: с Alt можно создавать панели, перемещаться по ним и изменять их размер, сворачивать; с клавишей Ctrl доступно переключение в различные режимы. Например, если нажать Ctrl-p, а потом x, то панель будет закрыта. Esc — это отмена режима.
  • В подсказках указаны не все доступные сочетания, например, такое полезное как Ctrl-p (войти в режим изменения панелей), d — для разбиения панелей по горизонтали. Все доступные сочетания можно посмотреть в сгенерированном в конфиге.
  • Если зажать Shift, то ссылки станут кликабельными.
  • Заблокируйте интерфейс с помощью Ctrl-g.

Полный конфиг Alacritty:

[keyboard]
bindings = [
  {key='q', mods='Control|Shift', action='Quit'},
  {key='n', mods='Control|Shift', action='CreateNewWindow'},
]

[font]
size = 12

  [font.normal]
  family = "JetBrainsMono Nerd Font Mono"
  style = "Regular"

  [font.bold]
  family = "JetBrainsMono Nerd Font Mono"
  style = "Bold"

  [font.italic]
  family = "JetBrainsMono Nerd Font Mono"
  style = "Italic"

  [font.bold_italic]
  family = "JetBrainsMono Nerd Font Mono"
  style = "Bold Italic"

[window]
opacity = 0.95
blur = true

  [window.padding]
  x = 3
  y = 3

[colors]
transparent_background_colors = true

  [colors.primary]
  background = "0x282c34"
  foreground = "0xabb2bf"

  [colors.cursor]
  text = "0x282c34"
  cursor = "0xabb2bf"

  [colors.normal]
  black = "0x282c34"
  red = "0xe06c75"
  green = "0x98c379"
  yellow = "0xd19a66"
  blue = "0x61afef"
  magenta = "0xc678dd"
  cyan = "0x56b6c2"
  white = "0xabb2bf"

  [colors.bright]
  black = "0x5c6370"
  red = "0xe06c75"
  green = "0x98c379"
  yellow = "0xd19a66"
  blue = "0x61afef"
  magenta = "0xc678dd"
  cyan = "0x56b6c2"
  white = "0xffffff"

  [colors.selection]
  text = "0x282c34"
  background = "0xabb2bf"

[cursor]
blink_interval = 800
blink_timeout = 0

  [cursor.style]
  shape = "Beam"
  blinking = "Always"

[scrolling]
history = 10000

# По умолчанию запускаем мультиплексер
[terminal.shell]
program = "zellij"
args = [ ]

В качестве менее популярной альтернативы Alacritty (в качестве минималистичного эмулятора терминала) можно попробовать Contour, написанный на C++ и поддерживающий лигатуры.

Установка и настройка wezterm — современного терминала с поддержкой лигатур

Если в Vim не хватает лигатур, то это попроавимо!

WezTerm — это современный, быстрый эмулятор терминала с поддержкой табов (в отличии от того же alacritty) и лигатур (их поддерживает считанное количество эмуляторов). Конкуренцию ему может составить разве, что Kitty, но он проигрывает по ряду особенностей, которые мне тупо лень перечислять.

Установка:

yay -S wezterm

Конфиги для wezterm пишутся на Lua, что значительно упрощает его настроку.

Пример конфига:

~/.config/wezterm/wezterm.lua

-- Настройки шрифта
local wezterm = require 'wezterm'

wezterm.on('update-right-status', function(window, pane)
  local date = wezterm.strftime('%Y-%m-%d %H:%M:%S')
  window:set_right_status(wezterm.format({
    {Text = ' ' .. date .. ' '},
  }))
end)

return {
  -- Шрифт
  font = wezterm.font('JetBrainsMono Nerd Font Mono', {weight = 'Regular'}),
  font_size = 12.0,

  -- Цветовая схема
  color_scheme = 'Dracula',

  -- Размер окна
  window_padding = {
    left = 10,
    right = 10,
    top = 10,
    bottom = 10,
  },

  -- Поведение терминала
  scrollback_lines = 100000,
  enable_scroll_bar = true,

  -- Настройки клавиатуры
  keys = {
    {key = 'v', mods = 'CTRL|SHIFT', action = wezterm.action{PasteFrom = 'Clipboard'}},
    {key = 'c', mods = 'CTRL|SHIFT', action = wezterm.action{CopyTo = 'Clipboard'}},
    {key = 'q', mods = 'CTRL', action = 'QuitApplication'},
    {key = '=', mods = 'CTRL', action = wezterm.action.IncreaseFontSize},
    {key = '-', mods = 'CTRL', action = wezterm.action.DecreaseFontSize},
  },

  -- Поддержка лигатур
  enable_kitty_graphics = true,
  enable_wayland = true,

  -- Другие настройки
  default_cursor_style = 'BlinkingBar',
  cursor_blink_rate = 800,
  cursor_blink_ease_in = 'Constant',
  cursor_blink_ease_out = 'Constant',

  -- Настройки окна
  window_background_opacity = 0.95,
  text_background_opacity = 1.0,
  window_close_confirmation = 'NeverPrompt',
}

>>> Конфиг полностью здесь <<<

Заключение

Как видим, настройка Vim довольно таки сложна и представляет собой особый вид специальной олимпиады. Любители обмазаться vim шарят свои конфиги, делают скрины и показывают их друг другу.

Насколько оправдано использование vim сегодня? — тут свой вывод может сделать каждый. У него есть и современные альтернативы типа kakoune или сборки как spacevim для тех, кто не желает возиться с настройками. Альтернативы хоть и имеют сторонников, но те малочисленны. Сборки же я не советую использовать, так как, не имея опыта в настройке редактора, вы не сможете начать программировать как шестирукий Шива — верховное божество вимеров, даже с ними. Кстати, одна такая с плагином YouCompleteMe когда-то давно у меня выжрала гигабайт при старте, что не меньше чем подставь название любой IDE из коробки. Так же существуют расширения для того же VS Code, которые позволяют ломать пальцы о сочетания клавиш, но зачем они когда можно просто настроить vim, написав каких-то 500 строк кода на марсианском языке?

Кому зайдет Vim:

  • фанатам тайлов;
  • людям, которые много работают из терминала;
  • бекенд-разработчикам;
  • обладателям слабых компьютеров/ноутбуков, где VS Code и упаси, г-де, PyCharm безбожно тормозят.

Что радует:

  • мгновенный запуск;
  • отзывчивый интерфейс;
  • возможность все перенастроить под себя;
  • не надо вылазить из терминала. В VS Code, например, интегрированный терминал очень часто падает при долгой работе, хотя у меня есть на борту 32GB RAM (тупо утечки памяти в JS, которых сложно добиться, но для разрабов VS Code нет ничего невозможного).

Что может разочаровать:

  • На компьютерах уровня 2 ядра, 2 гига, игровая видеокарта vim с используемыми плагинами уже не взлетит. Я помню как в 2009 запускал Netbeans IDE на своем одноядерном Атлоне с 512 мегабайтами, и он ел меньше чем coc в связке с Ale, но, правда, и не обладал тем функционалом, что дают последнее. Годы летят, пухнут библиотеки, и из-за этого голый vim давно жрет больше чем гуишный Notepad++ конца нулевых.

Можно еще кинуть камень в огород вимеров. Не даром сей текст с первых абзацев начинался со стеба над их пафосом. Я часто от них вижу какую-то критику самокатчиков и смузихлебов за то, что те пишут хипсторские приложения из 100 строчек. Но я захожу на гитхаб, смотрю исходники любого популярного плагина для vim, и вижу там все те же 100 строчек… За 20 с лишним лет вимеры не смогли родить никаких средств для разработки, единственное что они осилили сделать — это прикрутить ноду и поставить расширения от VS Code. Я не вижу в этом ничего плохого, но хейт-спич в сторону JavaScript и любителей соевого молока от них не одобряю. Да, и такую кодовую базу сложно реализовать силами одного человека и даже небольшой команды, а непризнанные гении как правило работают в одиночку, что не дает надежды на замену «ненужно-скрипта» быстрым как гепард, обожравшийся стероидов, кодом на C++ или на Rust (эти пока все стандартные утилиты на крабе не перепишут, таким «нужным делом» не займутся).

Что можно сказать точно, так это то, что vim жив и продолжает развиваться. Для меня vim примечателен как явление, и я им иногда пользуюсь, потому что на нем «удобно редактировать» конфиги на серверах в осутствии альтернатив кроме убогого nano, хотя и без этих настроек, которые из него делают что-то большее, чем необычный текстовый редактор для терминала. А настроить его я решил, только чтобы написать статью, главным образом для тех, кто никогда не заморачивался с его настройкой.

Ссылки

На сайт проекта Vim ссылку дать не могу, так как он содержит какие-то политические призывы, которые товарищ майор может приравнять к оправданию терроризма.

★★

Проверено: hobbit ()
Последнее исправление: rtxtxtrx (всего исправлений: 96)
Ответ на: комментарий от rebforce

Подсветка нужна только новичкам и только в тех ЯП

Вот, сразу видно профессионала! Главное для начала громко заявить какую-нибудь потрясающую безаппеляционную чушь, типа «настоящие пацаны сигареты с фильтром не курят», и вот ты без лишних усилий причислил себя к настоящим пацанам и морально опустил этих лохов курящих с фильтром.

FishHook
()
Ответ на: комментарий от qulinxao3

Некоторые материалы есть в этой статье, остальное как-то влом дописывать. Суть в поднятии .inputrc конкретно применимо к эду.

rebforce
()
Ответ на: комментарий от rebforce

цвет в colorForth решал вполне сносно компрактность кода

автодополнение провоцирует удлинение идентификаторов

при том что автодополнение(а llm это вариант автодополнения) облегает ознакомление

ide это специализация и стремление экономить на универсальном образовании :(

qulinxao3 ★☆
()
Ответ на: комментарий от qulinxao3

Поэтому и говорю, что это всё — вполне себе норм для новичков. Но перепись вечных новичков в этом треде, конечно, доставляет.

rebforce
()
Ответ на: комментарий от rtxtxtrx

писали без гласных ибо говаряли по рязному рузные ляди

qulinxao3 ★☆
()
Ответ на: комментарий от qulinxao3

Не, чисто позиксовый AWK тоже хорош, а вот всякие GAWK уже не туда начали наворачивать. Просто в качестве интерактивного редактора сам awk не особо поюзаешь. Разве что аналог того же ed на нём состряпать… И да, он тоже есть в busybox, пусть и в люто тормозном варианте.

rebforce
()
Ответ на: комментарий от rebforce

зависит от задач и инструментов

плохо когда «полезная приправа» становится сначала обязательным а потом и основным ингридиентом :(

в истории чтения от античности до наших дней

хорошо показано(это не основное в том сборнике) как книгопечатанье обрушило уровень грамотности среди могущих в буквы

ибо раньше кто мог в буквы мог и в много более сложные ...

qulinxao3 ★☆
()
Ответ на: комментарий от wonit

Из Micro IDE не сделать. Там дебаггер не прикрутить. Хоть он и может в автодополнение через lsp и в линтинг

rtxtxtrx ★★
() автор топика
Ответ на: комментарий от rtxtxtrx

на лишпе. Который не язык, а буквальная запись обратной польской нотации.

Lisp это Абстраct Syntax Tree, AST которое используют компиляторы языков. Обычно ещё нужно преобразование AST в Concrete Syntax Tree, в Lisp это не нужно бо всё оптимально.

жаваскриптеры…

tp_for_my_bunghole
()
Ответ на: комментарий от tp_for_my_bunghole

скриптобоги, подарившие пещерным людям, не знающим ни о дебаггере, ни о линтерах, «огонь»

rtxtxtrx ★★
() автор топика
Ответ на: комментарий от FishHook

Вот, сразу видно профессионала! Главное для начала громко заявить какую-нибудь потрясающую безаппеляционную чушь, типа «настоящие пацаны сигареты с фильтром не курят», и вот ты без лишних усилий причислил себя к настоящим пацанам и морально опустил этих лохов курящих с фильтром.

Всё правильно. Подсветка очень опасна. Были проведены исследования и если подсветка не поддерживает все конструкции языка, пиши пропало. А ЯП выходят как грибы. И теперь разбором занимается treesitter. А он не всегда успевает.

Так что всё правильно он говорит. Но! Это с точки зрения профи, который работает не с 1 ЯП. А новичок любит блестящее.

Eulenspiegel
()
Ответ на: комментарий от Eulenspiegel

Правильно! Все беды от подсветки синтаксиса исходят. Слышали недавно винда по всему миру сбойнула? А почему? Дык из-за подсветки синтаксиса в вижуал студии. Это очевидно! Очень опасная тварь. Вообще, были исследования, что самые талантливые и продуктивные программисты - дальтоники. А так же есть инфа, что в подразделении Эппл разрабатывающем ядро настрого запрещены цветные мониторы. Это еще дедушка Джобс внедрил. А еще, говорят, что цветной текст вызывает приступы у шизофреников. Насмотревшись на подсвеченный код, они идут на форумы и несут дикую чушь, но это ерунда всё. Один программист из Оренбурга недавно свою бабушку убил и съел в черносливом. Есть сведенья, что у него триситтер был включен в виме.

FishHook
()
Ответ на: комментарий от rebforce

REPL — не особенно удобный интерфейс, пришедший к нам со времён телетайпов. (И от которого vi не избавился, на что указывает любая команда, начинающаяся с “:” в visual mode.)

А есть где-то опубликованные результаты? Интересно посмотреть.

kaldeon
()
Ответ на: комментарий от kaldeon

repl c tee - когда есть (3 :) ленты(терминала tail -обновление конца:) ) input. , input+output , output - c например сквозной нумерацие али как в ipython In[] Out[] OIunt[] для общей навигации на трёх лентах

у МакКарни ( который М-expressions) был Эллифант A Programming Language Based on Speech Acts

ps. llm говорили они ... новое лучше старого говорили они ...

qulinxao3 ★☆
()
Ответ на: комментарий от kaldeon

Результаты я скидывал камраду qulinxao, там много букв, но всё сводится к установке rlwrap и оборачиванию в алиасы, а также кастомизации .inputrc под ed, как-то:

$if ed
set bind-tty-special-chars off
set convert-meta on
Meta-SPC: "\n.\n"
Control-w: "\n.\nw\n"
"\e[Z": "\C-v\t"
TAB: "  "
$endif

Это, конечно, не предел, но наворотить там можно прилично на этой основе.

rebforce
()
Последнее исправление: rebforce (всего исправлений: 1)

Но зачем?! Сейчас практически в любой IDE можно устаносить и настроить vim mode.

Aurum
()

Люблю vim, но превращать его в IDE нет никакого желания. Гораздно проще поставить в свою IDEA vim-плагин, и иметь тяжелое окружение для больших боевых проектов, а vim использовать для редактирования конфигов и прочего текста.

Он тогда не будет тяжеловестным, не будет тормозить, а все плюсы vim-навигации в коде я получу через плагин. Хотя IDE на базе vim/nvim выглядят интересно, может когда-нибудь и попробую на базе vscode, но уж точно сделаю так чтобы весь функционал ide включался по желанию при запуске с специальным ключом

Ну и традиционный совет, что сначала нужно изучить стандартные возможности vim, а потом уже обмазываться плагинами и прочим.

Fizzika ★★
()
Ответ на: комментарий от Fizzika

А что тебе мешает вим без плагинов со специальным ключом --clean запускать, а без него что-то как белые люди разрабатывать опять же в виме?

rtxtxtrx ★★
() автор топика

@js12411 хотелось бы чтобы по поводу своей оценки статьи высказался «админ» дебиана с 15-летним стажем

rtxtxtrx ★★
() автор топика
Ответ на: комментарий от Fizzika

Ну и традиционный совет, что сначала нужно изучить стандартные возможности vim, а потом уже обмазываться плагинами и прочим

Кроме собственно редактора там всё на пещерном уровне по удобству. Тот же ctrlp или fzf значительно повышает уровень жизни вимера. По хорошему нормальный поиск должен быть из коробки и на всех уровнях: дополнение в ком.строке, в режиме вставки, везде. Но только в vim9 произошли подвижки в эту сторону, а раньше дедам это было всё не нужно. Или взять работу с тегами ctags, вроде есть поддержка из коробки, но насколько же топорная и неудобная. Опять нужны плагины. И так во всем. Даже совсем ядреная функциональность как-то работа с деревом undo или с kill ring, без плагинов это полная шляпа.

bread
()
Ответ на: комментарий от bread

Хотя я согласен с общим посылом, хочу дополнить детали.

По хорошему нормальный поиск должен быть из коробки и на всех уровнях

Имеется ввиду поиск по именам файлов или содержимому? Если так, то традиционный метод - сперва r !ls, потом !}grep kernel.c для поиска по файлам и !}grep '^main' $(cat) для поиска по содержимому. Да, неудобно, но и текстовый редактор задумывался, когда телетайпы были в моде и постоянный ввод команд считался нормой (на что указывает примитивный ввод команд в :).

Первым таким костылём, я думаю, можно считать ctags. Хотя современник Vi, он является скорее отклонением от базового дизайна. Он заменяет обобщённый поиск чего угодно на переход к символу, одновременно отказываясь от стандартных утилит (ls, grep), усложняя задачу (теперь необходим генератор и есть стейт), и всё равно справляется только с глобальными символами.

Unix предоставил мощные инструменты для работы с текстом, но Vi не смог реализовать их потенциал, кроме кучи весёлых команд для перемещения курсора.

Да и концептуальных улучшений, вроде бы, Vi не получал, кроме того же Vim, который, похоже, намеревался закрыть недостатки Vi современными методами: накатить побольше фич поверх существующих. Поэтому, к сожалению, Vi интересен скорее археологам, а Vim сам задал тенденцию копировать другие редакторы.

дополнение в ком.строке

Для ком. строки не обязательно нужно дополнение. Vim частично исправляет проблему, позволяя работать с командной строкой почти как с нормальным буфером, но всё ещё не дотягивает до того, чтобы полностью сделать её нормальным буфером.

(Здесь могу соврать, т.к. опыт с Vim у меня ограниченный.)

kaldeon
()
Ответ на: комментарий от kaldeon

Учитывая то, что Vi стоит в одном ряду с программируемыми редакторами, ругать дефолты, хотя важно, не всегда правильно. В частности, исполнение команд можно повесить на дружелюбное сочетание клавиш.

map  ^A^A  :w !sh^M
map  ^A}   }mx``:,'xw !sh^M
map  ^Ax   !!sh^M
map  ^Ax}  !}sh^M
  1. ^A^A исполняет текущую строку, ^A} от текущей строки до конца параграфа, по аналогии с }.
  2. В качестве префикса взят ^A по аналогии со screen
  3. Эти команды не исчерпывающие. Я ещё пользовался захватом не только до следующего параграфа (}), но до конца here-doc (традиционно EOF в sh).
  4. Почему именно шелл? Потому что это оболочка, через неё доступны все остальные средства ОС.

Ну и возможность исполнить текущую строку как команду Vi, чтобы использовать нормальные буферы, а не кастрированный ::

map  ^A:  0"xy$:@x^M

И, менее важное, но в том же духе - возможность написания макросов в нормальном буфере:

map  ^A@  ^"xy$@x^M

Это всё, что мне нужно было для разработки бэкенда для современного веба. Даже отсутствие возможности открыть более двух файлов не тревожило, потому что всегда можно вернуться к предыдущему файлу (^6), в котором уже ждут команды e! для открытия других файлов.

kaldeon
()
Ответ на: комментарий от rtxtxtrx

Потому что есть ряд плагинов, которые нужны вне IDE сценария

Fizzika ★★
()
Ответ на: комментарий от bread

Кроме собственно редактора там всё на пещерном уровне по удобству

Ну я собственно про сам редактор и говорю, в остальном понятно что боль.

Банально научится уверенно портить текст, менеджить окна/буфера, применить какие-нибудь макросы.

Fizzika ★★
()
Ответ на: комментарий от devl547

Проблема что вимов, что емаксов — в полном отсутствии адекватной конфигурации по умолчанию. В результате пользоваться ими, внезапно, могут только те, кто уже пользовался ими десятилетиями и сделали под себя конфетку. Потому что для любого человека со стороны первый же запуск превращается в бесконечную боль и подбор удачных настроек втечение многих недель.

thunar ★★★★★
()
Ответ на: комментарий от thunar

я не пользовался им десятилетиями я просто за вечер посмотрел популярные плагины и попытался вспомнить что раньше в настройки пихал

rtxtxtrx ★★
() автор топика

К слову, больше всего в vim мне не хватает мультиоконности.

У меня несколько мониторов (с разным разрешением, если это важно) - хотелось бы использовать один редактор сразу на двух или трёх мониторах.

Harliff ★★★★★
()

Потратить часы (а именно столько надо чтоб понять как устроена реальная конфигурация если не слепая копипаста), шоб получить нечто хреновее по функциональности чем code, красиво.

mkeee
()
Ответ на: комментарий от thunar

За «десятилетия» у меня выработался .vimrc на 18 строчек, остальное считаю вполне юзабельным и по дефолту.

И да, начинается этот .vimrc с syntax off.

rebforce
()
Ответ на: комментарий от keeper_b

ему скорее всего не нужно править исходники. он лишь конфиги правит на всякой экзотике, где и так посдветки синтаксиса нет

rtxtxtrx ★★
() автор топика
Ответ на: комментарий от keeper_b

Я принципиальный сторонник бритвы Оккама. Подсветка — костыли для нубов, функциональности не добавляющие. С определённого момента (когда перестаёшь быть нубом и при этом не «эволюционируешь» до ламера вроде ТС) от этих костылей необходимо начинать отвыкать, иначе в непривычном окружении окажешься вообще в полной слепоте. Тем более с хорошими ЯП и без подсветки всё должно быть читаемо и понятно.

rebforce
()
Последнее исправление: rebforce (всего исправлений: 1)
Ответ на: комментарий от rtxtxtrx

А ламерам только фоточки с видосиками подавай, ага.

syntax off
set encoding=utf-8
set backspace=indent,eol,start
set autoindent
set copyindent
set noswapfile
set nobackup
set tabstop=2
set shiftwidth=2
set softtabstop=2
set expandtab
set wrap
set ignorecase
set ruler
set magic
set scrolloff=4
set smartindent
set shiftround
rebforce
()
Ответ на: комментарий от rebforce

Ясно просто не осилил настроить. А подсветку синтаксиса, возможно, не любишь из-за дальтонизма. У тебя и ава черно-белая. Опровергай гипотезу

rtxtxtrx ★★
() автор топика
Ответ на: комментарий от rtxtxtrx

У тебя и ава черно-белая.

А у тебя вообще домен уродским транслитом.

Короче, со школоламерами, говнокодерами и демагогами диалогов не веду.

rebforce
()
Последнее исправление: rebforce (всего исправлений: 1)
Ответ на: комментарий от rebforce

За подсветку глаз цепляется, особенно если она семантическая а не как в дедовской нашлепке на ed. Ну и подсвечивает базовые ошибки, например строку забыл закрыть, сразу видно.

иначе в непривычном окружении окажешься вообще в полной слепоте

Странное мышление, пока есть возможность пользоваться благами, я буду это делать. А привыкнуть к плохому я всегда успею. К тому же Vim довольно жирная программа, переходи на ed, тогда сможешь говорить про минимализм.

MOPKOBKA ★★★★★
()
Последнее исправление: MOPKOBKA (всего исправлений: 1)
Ответ на: комментарий от MOPKOBKA

Сразу видно админа локалхоста, у которого ещё и вим умудряется тормозить.

Ну не знаю, если наворотить всё предложенное ТС-ом, может, он и у меня тормозить начнёт. Но когда-то я и неовим пробовал, и всякие плагины семантической подсветки, и прочую дичь, которая со временем просто отпала за ненадобностью. Остался нетормозящий редактор с 18 строк .vimrc, которые будут адекватно работать на любом устройстве, которое в принципе способно запустить вим, в том числе и eink-читалках. А на тех, которые неспособны, имеется busybox/toybox vi, который тоже советую всем освоить, чтбы понять, что реально критичных улучшений у вима по сравнению с ними не так уж и много. Меньше десятка по сути.

И да, вот мой .exrc для busybox vi:

set autoindent
set tabstop=2
set expandtab
set ignorecase
set showmatch
rebforce
()
Последнее исправление: rebforce (всего исправлений: 1)
Для того чтобы оставить комментарий войдите или зарегистрируйтесь.