LINUX.ORG.RU

Делаем из Vim IDE

 ,

Делаем из Vim IDE

17

4

В стародавние времена когда деревья были большими, трава зеленее, а мороженное стоило по 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

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

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 number

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

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

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

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

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

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

Plug 'scrooloose/nerdtree' " Файловый менеджер
" Плагин может установить fzf, если того нет
"Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }
Plug 'junegunn/fzf.vim' " Нечеткий поиск строк
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 тоже умеет в подсветку синтаксиса и автодополнение. Среду разработки от текстового редактора отличает следующее:

  • Автодополнение осуществляется с использованием синтаксического анализа, а не просто всех встречающихся слов в тексте.
  • Исходный код проверяется на синтаксические ошибки, а так же осуществляется проверка стилистики и возможных проблем в коде (линтинг).
  • Есть форматирование кода. Правила форматирования должны как-то задаваться, чтобы код могла разрабатывать команда.
  • Отладка кода. Без нее в принципе невозможна разработка чего-либо серьезного (у фанатов Столярова другое мнение).
  • И все это должно быть интегрировано в 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

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

Бонус: создание своих тем

Если вам нравится какая-то тема, но ее нет на 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

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

Заключение

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

Насколько оправдано использование vim сегодня? — тут свой вывод может сделать каждый. У него есть и современные альтернативы типа kakoune или сборки как spacevim для тех, кто не желает возиться с настройками. Альтернативы хоть и имеют сторонников, но те малочисленны, сборки же я не советую использовать, т.к. не имея опыта в настройке редактора, вы не сможете начать программировать аки бог (вимеры молются шестирукому Шиве) даже с ними. Кстати, одна такая когда-то давно у меня выжрала гигабайт при старте, что не меньше чем подставь название любой 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 (всего исправлений: 86)

Ответ на: комментарий от ox55ff

Твой тезис «Блокнот с разношёрстными плагинами от васянов не может никаким образом считаться integrated» содержит пресуппозицию, что «разношёрстный» и «интегрированный» — это конкретные вещи, а не расплывчатые понятия, которые можно удобно подгонять под контекст. А это неправда. Поэтому я у тебя и попросил обоснования. Вместо этого ты накинулся на меня с обвинениями и клоунадой, успел приписать меня к вимерам, хотя я даже не знаю, как из него выйти нормально.

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

А, я понял, тебе нужно xnoremap p "_dP. В виме удаление никогда не стирает текст безвозвратно, такое поведение нужно явно указывать. Не знаю уж насколько это «через жопу», по-моему как раз адекватно.

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

Вим сделал один, поддержку LSP - другой, языковой сервер сделал третий.

Вот они и интегрируются через вимскрипт и общие механизмы IPC. Для тебя IDE это какой-то турбопаскаль монолитный? Это устаревшая концепция. Сейчас вон все на vscode педалят, который столь же разношерстно васянский.

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

У меня нет никаких нулевых регистров.

При чем тут ты? У тебя и vim нет. Ты спросил как это делается в vim. Тебе ответили. Кто виноват, что в vim это делается по другому, не так как ты привык? Ты и только ты, потому что ответ не подходит под твои хотелки. И вообще, тут технический ресурс, инструкции читать надо.

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

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

Да, это можно представить и в таком виде, как ты написал. Потому что это абстрактные понятия. ox55ff, это хороший пример описанного мной выше:

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

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

отож. Для какого-нибудь QtCreator не делают плагины не потому что он IDE в отличие от вимов с вскодами, а потому что его внутренняя архитектура - это нестабильная лапша и шляпа без документации, под которую в принципе невозможно что-то разрабатывать сторонним людям.

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

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

Возможно, я в своё время разрабатывал. Но постоянно что-то ломалось и надо было переделывать. Потом начиная с 3.х они обещали делать гарантии стабильности апи, типа что в пределах мажорной версии плагины ломаться не должны. Но я уже к тому моменту забил на свои плагины.

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

И там, кстати, есть неплохая (не уровня Qt, конечно, но неплохая) документация на API. Плюс тогда была возможность с любым разработчиком поболтать в IRC.

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

+ posixbit Что бы они интегрировались, нужно что бы интеграция такая была. Могут они видеть определения друг друга? js сервер видит определения html сервера? При просмотре git diff в это окно интегрируются lsp серверы?

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

У Vim есть особый ореол причастности к программистской элите.

Замечу, что пользователи nano или mcedit подобной манией величия не страдают почему-то.

grem ★★★★★
()

За простыню — зачОт.

...самым популярным вопросом является «Как выйти из Vim?»...

Вот ведь лошары! 😁😂

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

Могут они видеть определения друг друга? js сервер видит определения html сервера? При просмотре git diff в это окно интегрируются lsp серверы?

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

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

Тут оно четко определенно контекстом, например работает ли семантическая подсветка, проверка ошибок, автодополнение в окне гит слияния? Упростить можно до = работает ли LSP в таком окне?

Не нужно приписывать мне какую-то позицию

Если у тебя есть сомнения в интеграции, то ты не представляешь что скрывается за этим широким словом, и почему пользователи IDE говорят что в vim ее нету. Или тебе просто не нравится использование этого слова? Нужно перечислять конкретно? Тогда нужно конкретно сравнивать на определенных плагинах, языках, но не у всех есть такой сконцентрированный опыт, хочется справедливо обобщить.

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

Или тебе просто не нравится использование этого слова? Нужно перечислять конкретно?

Нет, я не об этом.

Когда абстрактное понятие воспринимается как что-то конкретное, это может вводить людей в заблуждение. Люди начинают спорить о том, что подходит под это понятие, не осознавая, что у самого понятия нет чётких границ и оно подвижно. Это распространено в спорах о технологиях, где термины, такие как «интегрированный», «модульный», «разнородный», часто используются без единого стандарта для всех участников дискуссии.

Абстрактные понятия могут становиться предметом манипуляций и субъективных трактовок. В примере с IDE это очень показательно: поскольку нет единого строгого стандарта для того, что должно включать в себя IDE, люди интерпретируют этот термин по-разному. Одни считают Vim с плагинами полноценной IDE, другие — лишь текстовым редактором. Все это связано с тем, что понятие «интегрированного» само по себе является абстракцией, которую можно по-разному интерпретировать.

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

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

Ты спросил как это делается в vim. Тебе ответили.

Ты написал, что в виме так же как и в ide. На что я тебе ответил, что в IDE не так же. Я тут при том, что у меня IDE и я знаю как там.

Даю переписку в сокращении, вижу что текст для тебя это сложно:

А как это в IDE делается?

Копипастом и выделением заменяемого слова

Тебе же написали, что делается точно так же, копированием, выделением и вставкой нулевого регистра.

У меня нет никаких нулевых регистров. Так что нет, не точно так же

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

Что бы они интегрировались, нужно что бы интеграция такая была. Могут они видеть определения друг друга?

Для этого нужно, чтобы авторы разных плагинов как-то взаимодействовали. Что малореалистично. Уже хорошо если плагины не конфликтуют. Просто интеграция бывает разной глубины. Когда плагин прозрачно связывает редактор с внешней утилитой, как это назвать если не интеграцией?

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

Не видел таких споров, обычно адепты VIM считают что он может быть сконфигурирован до состояния любой IDE, я как пример беру JetBrains IDE, и показываю что не может.

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

Просто интеграция бывает разной глубины

Все так, в JetBrains она довольно глубокая, в Vim/VScode как ты сказал, хорошо если плагины не конфликтуют.

Когда плагин прозрачно связывает редактор с внешней утилитой, как это назвать если не интеграцией?

Хз, но это и не межплагинная интеграция.

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

обычно адепты VIM считают что он может быть сконфигурирован до состояния любой IDE

Значит, мне редко удавалось встретить именно адептов Vim.

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

пресуппозицию

Бабских журналов перечитал? У тебя пресуппозиция, что «разношёрстный» и «интегрированный» это НЕ конкретные вещи.

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

Бабских журналов перечитал?

А ты уже перестал пить коньяк по утрам? Отвечай «да» или «нет».

У тебя пресуппозиция, что «разношёрстный» и «интегрированный» это НЕ конкретные вещи

Да, ведь они такими и являются. И выше я доказал это. А вот у тебя с аргументами до сих пор туго. Ладно, дам тебе последний шанс и максимально подробно разжую эту, казалось бы, простую мысль, чтобы даже до тебя дошло. Не сможешь это осилить снова — я умываю руки.

Сам по себе термин «интегрированный» происходит от латинского слова integratio, что означает «восстановление целого» или «соединение частей в одно целое». Это уже предполагает нечто общее и абстрактное, так как «целое» и «части» могут быть разного рода и смысла. То, что интегрируется, не имеет четких границ или материальных качеств. В то время как, например, термин «стол» имеет конкретное, ощутимое значение (это объект, который можно увидеть, потрогать и использовать), понятие «интегрированный» описывает скорее состояние или отношение частей. Если мы не можем точно указать на один предмет или объект, к которому применимо это понятие во всех контекстах, это указывает на его абстрактность.

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

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

А ты уже перестал пить коньяк по утрам?

Да.

портянка текста

Не читал. Ты же понимаешь, что ты наводишь духоту? Поудаляй из закладок ссылки на эту хрень и сожги всю литературу по философии.

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

вижу что текст для тебя это сложно

Вижу, что для тебя логика сложно, так же как и описать последовательность своих действий.

Копипастом и выделением заменяемого слова

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

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

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

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

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

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

Потом попробуй на луне сконфигурировать неовим.

А зачем, neovim спокойно переваривает конфиг от vim

einhander ★★★★★
()

Кажется статья написана хорошо, но я всё таки надеюсь что никому не потребуется.

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

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

Obezyan
()

А есть ли учебник «делаем из vim vim»? Без плюгинов. С полным описанием всех команд. Во всяких «просто о vim» не всё, например ни в одном из таких руководств не нашёл описание команд CTRL-A/CTRL-X

alt-tab-let ★★
()
Ответ на: комментарий от Obezyan

А зачем линупс, когда есть венда, где нет никаких WM, DE, композиторов и прочих дирижеров кроме дефолтных?

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

добавлю / в :-режиме, поиск по /pattern и переключения по найденному по n p, емнип.

etwrq ★★★★★
()

Vim не может go to definition в своём скрипте с которым запустился. Пытаются IDE делать.

:map показывает все маппинги команд в пeйджере как more без возможности поиска. За декады никто не сделал плагин для трансформации этого вывода в удобную форму.

Plug ‘junegunn/fzf.vim’ " Нечеткий поиск строк

Игнорирует цветовую тему в Vim. Плагин CtrlP лучше(если с ripgrep для файлов): https://github.com/ctrlpvim

Универсального маппинга для вывода списка функций или классов в Vim нет.

Coc - сервер на Node.js…

Нет системного подхода какой есть в Emacs.

Но Vim лучше чем Neovim. Для Vimscript встроен какой-то дебаггер, в Neovim прикрутили скотчем Lua не понимая почему Vimsript был сделан в таком специфическом виде.

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

Coc - сервер на Node.js…

И что в этом плохого? Node.js подарила самое лучшее GUI в Linux на электрон! Хожу по интернету и всем советую ставить приложения на электрон, конечно же, через flatpak… И, конечно, же без ноды/электрона не было бы VS Code, без расширений которого не было бы ни cock, ни vimspector, ни кучи утилит, работающих по евонову протоколу LSP, и vim так и оставался бы убогим текстовым редактором

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

Ну и где популярная картинка с буханкой? Здесь же идеальное место, статья как будто под неё писана.

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

Что тебе не нравится? Что единственной жизнеспособной сборкой является та, где используются потрошка от vscode — евоные дебагер и расширения, потому что бимеры (бумер + вимер) ничего не смогли за 20-30 лет придумать лучше чем прикрутить к Vim ноду? Я пару дней назад задумался, а почему бы мне не съесть этих мягких французских було… не использовать vim, ведь V — значить анонимус (c) (маска Гая Фокса не даст соврать). Я вспомнил, что когда-то давно вимер меня убеждал, что вим — это IDE, там все есть для этого, и я решил это проверить. Я открыл конфиг, которым пользовался многие лета:

" auto install plugins on startup
autocmd VimEnter *
  \  if len(filter(values(g:plugs), '!isdirectory(v:val.dir)'))
  \|   PlugInstall --sync | source $MYVIMRC
  \| endif

call plug#begin('~/.vim/plugged')
" PLUGINS GOES HERE
Plug 'tpope/vim-sensible'
call plug#end()

Он был прекрасен и минималистичен! Я тупо взял список плагинов из топа, ведь миллиарды мух, лично расстрелянных Сталиным, не могут ошибаться, выкинул все взаимозаменяемое… И получилась IDE, пусть смузихлеб-edition, но рабочая и жрет мало (я где постил графики с потреблением памяти, они какие-то неправильные, там где-то ошибка в коде) — это хорошая альтернатива VS Code (или упаси, б-же, Pycharm) для тех у кого нет 16 гигов оперативы — минимума для ее полноценного использования

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

Не ври. Например, OSS Code в зависимостях имеет:

yay -Si code
Repository      : extra
Name            : code
Version         : 1.94.2-1
Description     : The Open Source build of Visual Studio Code (vscode) editor
Architecture    : x86_64
URL             : https://github.com/microsoft/vscode
Licenses        : MIT
Groups          : None
Provides        : vscode
Depends On      : electron30 ...

Это в твоем дристре используется сборка с сайта мелкософта с включенным электрон, либо ты сам такую поставил, а теперь делаешь провакационные заявления

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

Что тебе не нравится?

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

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

Это нейросеть нужно попросить сгенерировать, тогда заменю (самому мне лень)

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

Это костыль который позволяет обойти захардкоженное поведение vim и разместить конфиг в любом месте

export VIMINIT=‘source $MYVIMRC’ export VIMHOME=${XDG_CONFIG_HOME:-$HOME}/vim export MYVIMRC=$VIMHOME/vimrc

Уже с 9 версии Vim научился официально держать конфиги в ~/.config

Eulenspiegel
()
Для того чтобы оставить комментарий войдите или зарегистрируйтесь.