Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nivekuil/corral
Quickly surround text with delimiters in emacs
https://github.com/nivekuil/corral
emacs productivity
Last synced: 4 months ago
JSON representation
Quickly surround text with delimiters in emacs
- Host: GitHub
- URL: https://github.com/nivekuil/corral
- Owner: nivekuil
- Created: 2015-05-17T15:44:16.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2021-10-12T19:34:04.000Z (over 3 years ago)
- Last Synced: 2024-08-05T06:06:22.192Z (6 months ago)
- Topics: emacs, productivity
- Language: Emacs Lisp
- Homepage:
- Size: 16.1 MB
- Stars: 93
- Watchers: 2
- Forks: 5
- Open Issues: 3
-
Metadata Files:
- Readme: README.org
Awesome Lists containing this project
README
[[http://melpa.org/#/corral][file:http://melpa.org/packages/corral-badge.svg]]
[[http://stable.melpa.org/#/corral][file:http://stable.melpa.org/packages/corral-badge.svg]]
* Corral
Corral is a lightweight package that lets you quickly wrap parentheses and other delimiters around text, intuitively surrounding what you want it to using just two commands.** Examples
[[./corral-example-c.gif]]
[[./corral-example-js.gif]]
[[./corral-example-el.gif]]These examples are shown with the built-in =electric-pair-mode= enabled.
** Installation
Corral can be found on melpa, and should be installed from there. To install it manually instead, save corral.el to your computer and add this to your init file:
#+BEGIN_SRC emacs-lisp
(add-to-list 'load-path "/path/to/corral/directory/")
(require 'corral)
#+END_SRC** Usage
Call a command once to wrap delimiters around the sexp at point. Repeated calls of the same command, backward or forward, will shift the delimiters in the respective direction, corralling more text.To use these commands, just bind them to keys of your choosing. Here are some example keybindings:
#+BEGIN_SRC emacs-lisp
(global-set-key (kbd "M-9") 'corral-parentheses-backward)
(global-set-key (kbd "M-0") 'corral-parentheses-forward)
(global-set-key (kbd "M-[") 'corral-brackets-backward)
(global-set-key (kbd "M-]") 'corral-brackets-forward)
(global-set-key (kbd "M-{") 'corral-braces-backward)
(global-set-key (kbd "M-}") 'corral-braces-forward)
(global-set-key (kbd "M-\"") 'corral-double-quotes-backward)
#+END_SRCThe wrapping algorithm tries to follow these rules:
- If the point is over a word, it will always wrap around that word.
- Otherwise, =backward= and =forward= commands should have different effects.You can tweak how the wrapping works by modifying the syntax table through =corral-syntax-entries= (see [[https://github.com/nivekuil/corral#configure-how-corral-handles-punctuationsymbols][Settings]]).
** Settings
*** Keep point position instead of following delimiters
This is controlled by the variable =corral-preserve-point=, which can be set manually or through customize.
#+BEGIN_SRC emacs-lisp
(setq corral-preserve-point t)
#+END_SRC
*** Configure how corral handles punctuation/symbols
Corral can be configured to use special syntax rules, which are set through the variable =corral-syntax-entries=. This variable is a list of syntax entries and follows the same syntax as =modify-syntax-entry=.For example, if you want to have =#= and =*= be treated as symbols so that they are wrapped as part of the word:
#+BEGIN_SRC emacs-lisp
(setq corral-syntax-entries '((?# "_")
(?* "_")))
#+END_SRC