Как добиться эффекта сворачивания кода в Emacs?
какой лучший способ достичь чего-то вроде сворачивания кода или типа цикла, который использует org-mode. Каким было бы лучшее решение в elisp для создания такого типа поведения?
изменить: Мне жаль, что я не был ясен. Я хочу запрограммировать что-то в elisp, что делает вещи, очень похожие на сворачивание кода, или на самом деле больше всего похоже на org-mode с иерархией, которую можно расширить. Мне интересно, как лучше всего достичь этого эффекта. Я думаю, что слышал, что оверлеи emacs-это хорошо решение, но я не знаю.
Что касается складывания, я просто использую встроенный набор-selective-display
ИЗМЕНИТЬ НОМЕР 2:
Спасибо за ответы, но я думаю, что я задаю неправильный вопрос, поэтому позвольте мне попытаться быть более ясным о том, что я пытаюсь сделать. Я хотел бы создать следующее
когда вы ставите свою точку на функцию и вызываете эту функцию elisp, она будет помещать определение функции из любого места (я думаю просто использовать find-tag для этого) и разверните его в текущем буфере. Идея заключается в том, что если вам нужно перейти к другому буферу, чтобы прочитать определение функции, я чувствую, что его контекст переключается на другой файл. Поэтому я хотел бы, чтобы он вел себя как сворачивание кода, только он втягивает внешний код из буфера. Это представляет некоторые проблемы, поскольку он не может остро вставить код в буфер или если кто-то сохранит его, он сохранит вытащенный код. Поэтому мне интересно, есть ли способ создать область внутри буфера, которая также не является частью буфера. Я думаю, что это имеет смысл.
12 ответов:
сворачивание обычно не требуется с emacs, так как у него есть инструменты, которые явно реализуют действия, которые люди делают вручную при сворачивании кода.
большинство людей имеют хороший успех с помощью простых инкрементных поисков. См." foo", упомянутый где-то? Типа C-s
foo
, найдите определение, нажмите enter, прочитайте его, а затем нажмите C-xC-x вернуться туда, где вы были. Просто и очень полезно.поддержка большинства режимов imenu. M-x
imenu
позволит вам перейти к определению функции (и т. д.) по фамилии. Вы также можете привязать его к щелчку мыши, чтобы получить меню функций (или добавить его в меню; см. страницу информации для получения более подробной информации). Он предоставляет данные для which-function-mode, которые позволят вам увидеть, какая функция в настоящее время находится внутри в модельной линии. (Почему ваши функции так долго, правда?)есть еще панель быстрого доступа, который отображает imenu информация (и другие вещи) графически.
Если вы хотите получить обзор вашего файла, попробовать M-x
occur
". Учитывая регулярное выражение, он будет создавать новый буфер с каждым совпадением в текущем буфере. Вы можете найти "(defun", чтобы получить обзор функций, реализуемых текущим файлом. Нажатие на результат переместит вас в эту позицию в файле.так или иначе, подумайте о том, чего вы действительно хотите достичь, и Emacs, вероятно, реализует это. Не боритесь с несовершенными инструментами, которые заставляют вас складывать и разворачивать вещи постоянно.
режим скрытого показа (
hs-minor-mode
) с привязкой клавиш по умолчаниюC-c @ C-M-h
для запуска складывания (hs-hide-all
)
еще один способ освежевать кошку:
как это происходит, вам не нужен какой-либо пакет или дополнительная конфигурация для что. Просто зайдите в любой исходный файл, типа
M-1 C-x $ и происходит волшебство!
как обычно, это белая магия: C-x $ вернет ваш код обратно.
мы можем использовать справочную систему Emacs, чтобы узнать, что происходит: C-h k C-x $ говорит нам, что приведенная выше комбинация клавиш вызывает set-selective-display, функцию, которая принимает один числовой аргумент (префикс M-1 передает 1 Как значение этого аргумента) и, неудивительно, что устанавливает переменную selective-display в значение этот аргумент.
просто для полноты: M-3 C-x $ покажет более глубокий вложенный код и так далее.
чистки рядов я сегодня сделал крошечный помощник, основанный на чем-л. найдено здесь так что F5 переключает сворачивание кода на основе текущего положения курсора:
(global-set-key (kbd "<f5>") 'set-selective-display-dlw) (defun set-selective-display-dlw (&optional level) "Fold text indented same of more than the cursor. If level is set, set the indent level to LEVEL. If 'selective-display' is already set to LEVEL, clicking F5 again will unset 'selective-display' by setting it to 0." (interactive "P") (if (eq selective-display (1+ (current-column))) (set-selective-display 0) (set-selective-display (or level (1+ (current-column))))))
Я использую режим outline minor, чтобы свернуть мой код python. Вместо того, чтобы размещать {{{ и }}} как в режиме складывания, он использует, где определен блок.
http://www.gnu.org/software/emacs/manual/html_node/emacs/Outline-Mode.html http://www.emacswiki.org/emacs/OutlineMinorMode
я почти уверен, что он поставляется с emacs. Затем я добавляю это к моему .emacs
;;======= Code folding ======= (add-hook 'python-mode-hook 'my-python-outline-hook) ; this gets called by outline to deteremine the level. Just use the length of the whitespace (defun py-outline-level () (let (buffer-invisibility-spec) (save-excursion (skip-chars-forward " ") (current-column)))) ; this get called after python mode is enabled (defun my-python-outline-hook () ; outline uses this regexp to find headers. I match lines with no indent and indented "class" ; and "def" lines. (setq outline-regexp "[^ \t]\|[ \t]*\(def\|class\) ") ; enable our level computation (setq outline-level 'py-outline-level) ; do not use their \C-c@ prefix, too hard to type. Note this overides some bindings. (setq outline-minor-mode-prefix "\C-t") ; turn on outline mode (outline-minor-mode t) ; initially hide all but the headers ;(hide-body) ; make paren matches visible (show-paren-mode 1) )
вы также можете получить сворачивание кода с помощью CEDET со следующим кодом в файле init:
(global-semantic-folding-mode t)
после оценки этого кода маленький треугольник появится в области fringle, поэтому вы сможете сложить и развернуть код, используя его. Этот метод является более точным, так как он использует синтаксическую информацию, извлеченную из исходного кода
hs-minor-mode прекрасно работает.
Он работает еще более красиво, когда в паре с fold-dwim (делать то, что я имею в виду). Тогда есть fold-dwim-org, который обеспечивает org-mode как привязки клавиш для сворачивания кода! Оба могут быть установлены через мармелад (и я думаю, elpa).
vimish-fold
тоже хорошее и простое решение.https://github.com/mrkkrp/vimish-fold.
на главной странице:
это пакет для выполнения сворачивания текста, как в Vim. Он имеет следующие особенности:
- складывание активных областей;
- хорошая визуальная обратная связь: очевидно, какая часть текста складывается;
- сохраняемость по умолчанию: при закрытии файла ваши складки не исчезай;
- персистентность масштабируется хорошо, вы можете работать на сотнях файлов с большим количеством складок без побочных эффектов;
- он не ломает отступ или что-то;
- складки могут быть переключены из сложенного состояния в развернутое и обратно очень легко;
- быстрая навигация между существующими складок;
- вы можете использовать мышь, чтобы развернуть складки (хорошо для начинающих, а не только для них);
- для любителей avy пакет: вы можете использовать патчи чтобы сложить текст с минимальным количеством клавиш!
на
use-package
Я устанавливаю и активирую его с помощью этого фрагмента в моей конфигурации:(use-package vimish-fold :ensure t :config (vimish-fold-global-mode t))
emacs поставляется с hs-minor-mode, который увлекает сворачивание кода между сбалансированными выражениями http://www.emacswiki.org/emacs/HideShow
Я считаю, что ваше сравнение вашего" проекта " со складыванием не совсем хорошо, потому что складывание связано с изменением внешнего вида при сохранении содержимого буфера нетронутым (текст). Ваш проект будет включать в себя отображение дополнительного текста, сохраняя содержимое буфера нетронутым, AFAIU. Так. он не может быть реализован как композиция вставки и сворачивания текста (тогда содержимое буфера будет изменено).
но, возможно, это действительно возможно с тем же механизмом, что и складывание сделано с ... "накладки"... Рассмотрим "перед строкой" и "после строки" свойства оверлея; возможно, вы могли бы поместить свои определения функций в эти строки, принадлежащие наложению нулевой длины в точке. Посмотри на контур-флаг-регион функция, чтобы увидеть, как наложения используются в режиме контура.