В vim существует возможность подсвечивать найденные поиском слова командой :hlsearch. Но иногда удобно подсвечивать в логах многострочные блоки текста что бы их было видно невооруженным взглядом в огромном логе.
Но проблема в том что в регулярных выражениях точка . обозначает "любой символ кроме перевода каретки" (в отличии от например sed или perl где это действительно "любой символ"). К тому же * как обычно "жадный", что обозначает что если применять его, то будет найдена первая строка первого блока текста и последняя строка последнего блока текста, и подсвечен весь текст между ними. А нам нужно подсвечивать каждый блок в отдельности.
О том как это реализовывается на регулярных выражениях vim и есть этот типс Ж:-)
Как всегда лучше всего разобраться на примере. Допустим нам надо выделять блоки текста в которых первая строчка
содержит слова "RECV signal" или "SEND signal" и заканчиваются строчкой которая содержит "------".
Результат должен выглядеть так:

Белым цветом выделен только что найденый блок текста, желтым - все остальные найденные блоки.
Такого можно добиться командой:
/\(RECV\|SEND\) sig\_.\{-}------.*
Разберем ее по порядку слева на право:
- / - соответственно команда поиска в vim Ж:-)
- \(RECV\|SEND\) sig - ищем в строке или "RECV sig" или "SEND sig"
\(\) служат для группировки, \| для выбора вариантов, "или"
- \_. - вот это самое интересное Ж:-) эта последовательность обозначает "любой символ включая перевод каретки".
- \{-} - это реализация "не жадных" регулярных выражений в vim. в perl это аналог *?. Если вместо
этого поставить банальный * то vim будет искать самое последнее вхождение последующих символов.
- ------ - это мы ищем в последующих строках строку "------".
Итого \_.\{-}------ обозначает "пропустить любое кол-во символов (включая перевод каретки) до тех пор пока первый раз не найдем строку ------"
- .* - тут нужен что бы посветить остатки строки в которой найдена строка "------".
Вот собственно говоря и все Ж:-)
Последние комментарии
5 часов 11 минут назад
5 часов 54 минуты назад
5 часов 58 минут назад
6 часов 23 минуты назад
7 часов 6 минут назад
7 часов 37 минут назад
7 часов 42 минуты назад
1 день 3 часа назад
2 дня 6 часов назад
2 дня 16 часов назад