summaryrefslogtreecommitdiff
path: root/.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el
diff options
context:
space:
mode:
Diffstat (limited to '.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el')
-rw-r--r--.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el706
1 files changed, 706 insertions, 0 deletions
diff --git a/.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el b/.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el
new file mode 100644
index 0000000..51f7568
--- /dev/null
+++ b/.emacs.d/elpa/evil-nerd-commenter-20171206.441/evil-nerd-commenter.el
@@ -0,0 +1,706 @@
+;;; evil-nerd-commenter.el --- Comment/uncomment lines efficiently. Like Nerd Commenter in Vim
+
+;; Copyright (C) 2013-2017, Chen Bin
+
+;; Author: Chen Bin <chenbin.sh@gmail.com>
+;; URL: http://github.com/redguardtoo/evil-nerd-commenter
+;; Version: 3.1.3
+;; Keywords: commenter vim line evil
+;;
+;; This file is not part of GNU Emacs.
+
+;;; Credits:
+
+;; - Lally Oppenheimer added the support for text-object in Evil
+;; - Tom Willemse provided the fix to make Emacs 24.4 work
+
+;;; License:
+
+;; This file is part of evil-nerd-commenter
+;;
+;; evil-nerd-commenter is free software: you can redistribute it and/or
+;; modify it under the terms of the GNU General Public License as published
+;; by the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+;;
+;; evil-nerd-commenter is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+;;
+;; You should have received a copy of the GNU General Public License
+;; along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+;;; Commentary:
+
+;;
+;; This program emulates nerd-commenter.vim by Marty Grenfell.
+;;
+;; It helps you comment/uncomment multiple lines without selecting them.
+;;
+;; `M-x evilnc-default-hotkeys` assigns hotkey `M-;` to
+;; `evilnc-comment-or-uncomment-lines'
+;;
+;; `M-x evilnc-comment-or-uncomment-lines` comment or uncomment lines.
+;;
+;; `M-x evilnc-quick-comment-or-uncomment-to-the-line` will comment/uncomment
+;; from current line to specified line.
+;; The last digit(s) of line number is parameter of the command.
+;;
+;; For example, `C-u 9 evilnc-quick-comment-or-uncomment-to-the-line` comments
+;; code from current line to line 99 if you current line is 91.
+;;
+;; Though this program could be used *independently*, though I highly recommend
+;; using it with Evil (https://bitbucket.org/lyro/evil/)
+;;
+;; Evil makes you take advantage of power of Vi to comment lines.
+;; For example, you can press key `99,ci` to comment out 99 lines.
+;;
+;; Setup:
+;;
+;; If comma is your leader key, as most Vim users do, setup is one liner,
+;; (evilnc-default-hotkeys)
+;;
+;; If you use evil-leader and its default leader key,
+;; insert below setup into your ~/.emacs instead,
+;;
+;; (global-set-key (kbd "M-;") 'evilnc-comment-or-uncomment-lines)
+;;
+;; (require 'evil-leader)
+;; (global-evil-leader-mode)
+;; (evil-leader/set-key
+;; "ci" 'evilnc-comment-or-uncomment-lines
+;; "cl" 'evilnc-quick-comment-or-uncomment-to-the-line
+;; "ll" 'evilnc-quick-comment-or-uncomment-to-the-line
+;; ;; Or use `evilnc-comment-and-kill-ring-save' instead
+;; "cc" 'evilnc-copy-and-comment-lines
+;; "cp" 'evilnc-comment-or-uncomment-paragraphs
+;; "cr" 'comment-or-uncomment-region
+;; "cv" 'evilnc-toggle-invert-comment-line-by-line
+;; "." 'evilnc-copy-and-comment-operator
+;; "\\" 'evilnc-comment-operator)
+;;
+;; You can setup `evilnc-original-above-comment-when-copy-and-comment'
+;; to decide which style to use when `evilnc-copy-and-comment-lines'
+;; or `evilnc-copy-and-comment-operator',
+;; - Place the commented out text above original text
+;; - Or place the original text above commented out text
+;;
+;; We defined comment text object "c" which can have multi-lines.
+;; Press "vac" to select outer object (comment with limiters).
+;; Press "vic" to select inner object (comment without limiter).
+;;
+;; You can assign other key instead of "c" to the text object by
+;; customizing `evilnc-comment-text-object'.
+
+;; For certain major modes, you need manual setup to override its original
+;; keybindings,
+;;
+;; (defun matlab-mode-hook-config ()
+;; (local-set-key (kbd "M-;") 'evilnc-comment-or-uncomment-lines))
+;; (add-hook 'matlab-mode-hook 'matlab-mode-hook-config)
+;;
+;; See https://github.com/redguardtoo/evil-nerd-commenter for detail.
+;;
+;;; Code:
+
+(require 'evil-nerd-commenter-sdk)
+
+(autoload 'count-lines "simple")
+
+(defvar evilnc-original-above-comment-when-copy-and-comment nil
+ "Keep the original text above the commented copy, when using either:
+`evilnc-copy-and-comment-lines' or `evilnc-copy-and-comment-operator'.")
+
+(defvar evilnc-invert-comment-line-by-line nil
+ "If t then invert region comment status line by line.
+Please note it has NOT effect on evil text object!")
+
+(defvar evilnc-comment-both-snippet-html nil
+ "Comment both embedded snippet and HTML tag if they are mixed in one line.
+`web-mode' required.")
+
+(defvar evilnc-comment-text-object "c"
+ "The comment object.
+`vic` to select inner object.
+`vac` to select outer object.")
+
+(defun evilnc--count-lines (beg end)
+ "Assume BEG is less than END."
+ (let* ((rlt (count-lines beg end)))
+ (save-excursion
+ (goto-char beg)
+ (if (> beg (line-beginning-position))
+ (setq rlt (1+ rlt))))
+ rlt))
+
+(defun evilnc--goto-line (line-num)
+ "Shamelessly copied from `goto-line'. Goto line with LINE-NUM."
+ (save-restriction
+ (widen)
+ (goto-char (point-min))
+ (if (eq selective-display t)
+ (re-search-forward "[\n\C-m]" nil 'end (1- line-num))
+ (forward-line (1- line-num)))))
+
+(defun evilnc--fix-buggy-major-modes ()
+ "Fix major modes whose comment regex is buggy.
+See http://lists.gnu.org/archive/html/bug-gnu-emacs/2013-03/msg00891.html."
+ (cond
+ ((eq major-mode 'autoconf-mode)
+ ;; since comment-use-syntax is nil in autoconf.el, the comment-start-skip need
+ ;; make sure its first parenthesized expression match the string exactly before
+ ;; the "dnl", check the comment-start-skip in lisp-mode for sample.
+ ;; See code in (defun comment-search-forward) from emacs 24.2:
+ ;; (if (not comment-use-syntax)
+ ;; (if (re-search-forward comment-start-skip limit noerror)
+ ;; (or (match-end 1) (match-beginning 0)))
+ ;; (do-something))
+ ;; My regex makes sure (match-end 1) return the position of comment starter
+ (if (and (boundp 'comment-use-syntax) (not comment-use-syntax))
+ ;; Maybe autoconf.el will (setq comment-use-syntax t) in the future?
+ (setq comment-start-skip "^\\(\\s*\\)\\(dnl\\|#\\) +"))
+ )
+ ((eq major-mode 'haml-mode)
+ (setq comment-use-syntax nil)
+ (setq comment-start "-# ")
+ (setq comment-start-skip "-##*[ \t]*"))))
+
+(defun evilnc--operation-on-lines-or-region (fn &optional num)
+ "Apply FN on NUM lines or selected region."
+ (cond
+ ;; NO region is selected
+ ((not (region-active-p))
+ (let* ((b (line-beginning-position)) e)
+ (save-excursion
+ (forward-line (- num 1))
+ (setq e (line-end-position)))
+ (funcall fn b e)))
+
+ ;; Select region inside ONE line
+ ((and (<= (line-beginning-position) (region-beginning))
+ (<= (region-end) (line-end-position)))
+ (cond
+ ;; Well, looks current comment syntax is NOT fit for comment out a region.
+ ;; So we also need hack the comment-start and comment-end
+ ((and (string= "" comment-end)
+ (member major-mode '(java-mode
+ javascript-mode
+ js-mode
+ js2-mode
+ js3-mode
+ rjsx-mode
+ c++-mode
+ objc-mode)))
+ (let* ((comment-start-old comment-start)
+ (comment-end-old comment-end)
+ (comment-start-skip-old comment-start-skip)
+ (comment-end-skip-old comment-end-skip))
+
+ ;; use C comment syntax temporarily
+ (setq comment-start "/* ")
+ (setq comment-end " */")
+ (setq comment-start-skip "\\(//+\\|/\\*+\\)\\s *")
+ (setq comment-end-skip "[ ]*\\(\\s>\\|\\*+/\\)")
+
+ (funcall fn (region-beginning) (region-end))
+
+ ;; Restore the original comment syntax
+ (setq comment-start comment-start-old)
+ (setq comment-end comment-end-old)
+ (setq comment-start-skip comment-start-skip-old)
+ (setq comment-end-skip comment-end-skip-old)))
+ ;; just comment out the region
+ (t (funcall fn (region-beginning) (region-end)))))
+
+ ;; Select more than one line
+ (t
+ ;; selected region spans MORE than one line
+ (save-excursion
+ (let* ((b (region-beginning))
+ (e (region-end)))
+ ;; Another work around for evil-visual-line bug:
+ ;; In evil-mode, if we use hotkey V or `M-x evil-visual-line` to select line,
+ ;; the (line-beginning-position) of the line which is after the last selected
+ ;; line is always (region-end)! Don't know why.
+ (if (and (> e b)
+ (save-excursion (goto-char e) (= e (line-beginning-position)))
+ (boundp 'evil-state) (eq evil-state 'visual))
+ (setq e (1- e)))
+
+ (goto-char b)
+ (setq b (line-beginning-position))
+ (goto-char e)
+ (setq e (line-end-position))
+ (funcall fn b e))))))
+
+(defun evilnc--get-one-paragraph-region ()
+ "Select a paragraph which has NO empty line."
+ (let* (b e)
+ (save-excursion
+ (if (setq b (re-search-backward "^[ \t]*$" nil t))
+ (progn
+ (forward-line)
+ (setq b (line-beginning-position)))
+ (setq b 1)))
+ (save-excursion
+ (if (setq e (re-search-forward "^[ \t]*$" nil t))
+ (progn
+ (forward-line -1)
+ (setq e (line-end-position)))
+ (setq e (point-max))))
+ (list b e)))
+
+(defun evilnc--invert-comment (beg end)
+ "Scan the region from BEG to END line by line, invert its comment status."
+ (let* (done b e)
+ (save-excursion
+ (goto-char end)
+ (while (not done)
+ (setq b (line-beginning-position))
+ (setq e (line-end-position))
+ (funcall (if (comment-only-p b e)
+ 'uncomment-region 'comment-region)
+ b e)
+
+ (forward-line -1)
+ (if (or (= (line-beginning-position) b)
+ (< (line-end-position) beg))
+ (setq done t))))))
+
+(defvar org-src-lang-modes)
+(declare-function org-show-subtree "org")
+(declare-function outline-up-heading "outline")
+
+(defun evilnc--working-on-region (beg end fn)
+ "Region from BEG to END is applied with operation FN.
+Code snippets embedded in Org-mode is identified and right `major-mode' is used."
+ (let* (pos
+ info
+ lang
+ lang-f
+ old-flag)
+ (when (and (eq major-mode 'org-mode)
+ (fboundp 'org-edit-src-find-region-and-lang))
+ (setq info (org-edit-src-find-region-and-lang)))
+
+ (when info
+ (setq lang (or (cdr (assoc (nth 2 info) org-src-lang-modes))
+ (nth 2 info)))
+ (setq lang (if (symbolp lang) (symbol-name lang) lang))
+ (setq lang-f (intern (concat lang "-mode"))))
+
+ ;; turn on 3rd party language's major-mode temporarily
+ (if lang-f (funcall lang-f))
+
+ (if evilnc-invert-comment-line-by-line
+ (evilnc--invert-comment beg end)
+ (setq pos (point))
+ (funcall fn beg end)
+ (goto-char pos))
+
+ ;; turn off 3rd party language's major-mode temporarily and clean the shit
+ (when lang-f
+ ;; avoid org file automatically collapsed
+ (setq pos (point))
+ (org-mode)
+ ;; just goto the root element
+ (condition-case nil
+ (outline-up-heading 1)
+ (error
+ (message "in the beginning ...")))
+ ;; expand current node because by default (org-mode) will collapse all nodes
+ (org-show-subtree)
+ (goto-char pos))))
+
+(declare-function web-mode-comment-or-uncomment "ext:web-mode")
+(defvar web-mode-engine)
+
+(defun evilnc--warn-on-web-mode (is-comment)
+ "Check certain part of html code IS-COMMENT."
+ (let* ((comment-operation (concat "web-mode-"
+ (if is-comment "comment-" "uncomment-")
+ web-mode-engine
+ "-block")))
+ (unless (intern-soft comment-operation)
+ (message "defun %s NOT implemented in web-mode! Fix it or report to its maintainer."
+ comment-operation))
+ is-comment))
+
+(defun evilnc--web-mode-is-region-comment (beg end)
+ "Is region between BEG and END is comment in web mode?"
+ (let* ((rlt (and (save-excursion
+ (goto-char beg)
+ (goto-char (line-end-position))
+ (re-search-backward "^\\|[^[:space:]]")
+ (evilnc-web-mode-is-comment))
+ (evilnc-web-mode-is-comment (/ (+ beg end) 2))
+ (save-excursion
+ (goto-char end)
+ (back-to-indentation)
+ (evilnc-web-mode-is-comment)))))
+ rlt))
+
+(defun evilnc--web-mode-do-current-line ()
+ "In `web-mode', have to select whole line to comment."
+ (let* (first-char-is-snippet e)
+
+ (save-excursion
+ (goto-char (line-beginning-position))
+ (skip-chars-forward "[:space:]" (line-end-position))
+ (setq first-char-is-snippet (get-text-property (point) 'block-side)))
+
+ ;; comment the snippet block at first
+ (when (and evilnc-comment-both-snippet-html (not first-char-is-snippet))
+ (save-excursion
+ (let* (fired)
+ (goto-char (line-beginning-position))
+ ;; please note (line-beginning-position) is changing in (while)
+ (while (< (point) (line-end-position))
+ (forward-char)
+ (if (get-text-property (point) 'block-side)
+ (when (not fired)
+ (save-excursion
+ (push-mark (1+ (point)) t t)
+ (goto-char (point))
+ (web-mode-comment-or-uncomment))
+ (setq fired t))
+ (setq fired nil))))))
+
+ ;; comment the html line
+ ;; To comment one line ONLY, you need select a line at first,
+ ;; in order to work around web-mode "feature".
+ (push-mark (setq e (line-end-position)) t t)
+ (goto-char (line-beginning-position))
+ (skip-chars-forward "[:space:]" e)
+ (evilnc--warn-on-web-mode (evilnc--web-mode-is-region-comment (point) e))
+ (web-mode-comment-or-uncomment)))
+
+(defun evilnc--web-mode-comment-or-uncomment (beg end)
+ "Comment/uncomment line by line from BEG to END.
+DO-COMMENT decides we comment or uncomment."
+ ;; end will change when you comment line by line
+ (let* (line-cnt tmp)
+ ;; make sure beg <= end
+ (when (> beg end)
+ (setq tmp beg)
+ (setq beg end)
+ (setq end tmp))
+
+ ;; start (un)comment
+ (save-excursion
+ (setq line-cnt (evilnc--count-lines beg end))
+ (goto-char beg)
+ (while (> line-cnt 0)
+ (evilnc--web-mode-do-current-line)
+ (forward-line)
+ (setq line-cnt (1- line-cnt))))))
+
+(defun evilnc--comment-or-uncomment-region (beg end)
+ "Comment or uncommment region from BEG to END."
+ (cond
+ ((eq major-mode 'web-mode)
+ ;; elixir is not supported in web-mode for now
+ (unless (fboundp 'web-mode-comment-elixir-block)
+ (defalias 'web-mode-comment-elixir-block 'web-mode-comment-erb-block)
+ (defalias 'web-mode-uncomment-elixir-block 'web-mode-uncomment-erb-block))
+ (evilnc--web-mode-comment-or-uncomment beg end))
+ (t
+ (evilnc--working-on-region beg end 'comment-or-uncomment-region))))
+
+(defun evilnc--current-line-num ()
+ "Get current line number."
+ (save-restriction
+ (widen)
+ (save-excursion
+ (beginning-of-line)
+ (1+ (count-lines 1 (point))))))
+
+(defun evilnc--find-dst-line-num (UNITS)
+ "Find closet line whose line number ends with digit UNITS.
+Given UNITS as 5, line 5, line 15, and line 25 are good candidates.
+If UNITS is 16, line 16, line 116, and line 216 are good candidates."
+ (let* ((cur-line-num (evilnc--current-line-num))
+ dst-line-num
+ (r 1)
+ (l (length (number-to-string UNITS))))
+ (while (> l 0)
+ (setq r (* r 10))
+ (setq l (- l 1)))
+ (if (>= (mod cur-line-num r) UNITS)
+ (setq UNITS (+ UNITS r)))
+ (setq dst-line-num (+ cur-line-num (- UNITS (mod cur-line-num r))))))
+
+;; ==== below this line are public commands
+
+;;;###autoload
+(defun evilnc-comment-or-uncomment-paragraphs (&optional num)
+ "Comment or uncomment NUM paragraph(s).
+A paragraph is a continuation non-empty lines.
+Paragraphs are separated by empty lines."
+ (interactive "p")
+ (let* ((i 0)
+ rlt
+ (b (point-max))
+ (e 0))
+ (catch 'break
+ (while (< i num)
+ (setq i (1+ i))
+ (setq rlt (evilnc--get-one-paragraph-region))
+ (setq b (if (< (nth 0 rlt) b) (nth 0 rlt) b))
+ (setq e (if (> (nth 1 rlt) e) (nth 1 rlt) e))
+
+ ;; prepare for the next paragraph
+ (if (and rlt (< i num))
+ (progn
+ ;; e should be the end of last non-empty line
+ (goto-char e)
+
+ ;; move to an empty line
+ (forward-line)
+
+ ;; move to next non-empty line
+ (re-search-forward "^[ \t]*[^ \t]" nil t)
+
+ (if (<= (line-beginning-position) e)
+ (throw 'break i)))
+ (throw 'break i))))
+
+ (when (<= b e)
+ (save-excursion
+ (evilnc--fix-buggy-major-modes)
+ (evilnc--comment-or-uncomment-region b e)))))
+
+;;;###autoload
+(defun evilnc-comment-or-uncomment-to-the-line (&optional LINENUM)
+ "Comment or uncomment from current line to LINENUM line."
+ (interactive "nLine: ")
+ (if (not (region-active-p))
+ (let* ((b (line-beginning-position))
+ (e (line-end-position)))
+ (save-excursion
+ (evilnc--goto-line LINENUM)
+ (if (< (line-beginning-position) b)
+ (setq b (line-beginning-position)))
+ (if (> (line-end-position) e)
+ (setq e (line-end-position)))
+ (evilnc--fix-buggy-major-modes)
+ (evilnc--comment-or-uncomment-region b e)
+ ))))
+
+;;;###autoload
+(defun evilnc-quick-comment-or-uncomment-to-the-line (&optional units)
+ "Comment/uncomment to line number by last digit(s) whose value is UNITS.
+For exmaple, you can use either \
+\\<M-53>\\[evilnc-quick-comment-or-uncomment-to-the-line] \
+or \\<M-3>\\[evilnc-quick-comment-or-uncomment-to-the-line] \
+to comment to the line 6453"
+ (interactive "p")
+ (let* ((dst-line-num (evilnc--find-dst-line-num units)))
+ (evilnc-comment-or-uncomment-to-the-line dst-line-num)
+ (evilnc--goto-line (+ 1 dst-line-num))))
+
+;;;###autoload
+(defun evilnc-toggle-invert-comment-line-by-line ()
+ "Please note this command may NOT work on complex evil text objects."
+ (interactive)
+ (if evilnc-invert-comment-line-by-line
+ (setq evilnc-invert-comment-line-by-line nil)
+ (setq evilnc-invert-comment-line-by-line t))
+ (message (if evilnc-invert-comment-line-by-line
+ "Each line's comment status will be inverted"
+ "Each line's comment status will NOT be inverted")))
+
+;;;###autoload
+(defun evilnc-toggle-comment-empty-lines ()
+ "Toggle the flag which decide wether empty line will be commented."
+ (interactive)
+ (if comment-empty-lines
+ (setq comment-empty-lines nil)
+ (setq comment-empty-lines t))
+ (message (if comment-empty-lines
+ "Empty line(s) will be commented"
+ "Empty line(s) will NOT be commented")))
+
+;;;###autoload
+(defun evilnc-comment-or-uncomment-lines (&optional num)
+ "Comment or uncomment NUM lines. NUM could be negative.
+
+Case 1: If no region selected, comment/uncomment on current line.
+If NUM>1, comment/uncomment extra N-1 lines from next line.
+
+Case 2: Selected region is expanded to make it contain whole lines.
+Then we comment/uncomment the expanded region. NUM is ignored.
+
+Case 3: If a region inside of ONE line is selected,
+we comment/uncomment that region.
+CORRECT comment syntax will be used for C++/Java/Javascript."
+ (interactive "p")
+ ;; donot move the cursor
+ ;; support negative number
+ (cond
+ ((and (= 1 num) (string-match "^[ \t]*$" (buffer-substring-no-properties (line-beginning-position) (line-end-position))))
+ ;; comment on current empty line
+ (comment-dwim nil))
+ (t
+ (save-excursion
+ (when (< num 0)
+ (forward-line (1+ num))
+ (setq num (- 0 num)))
+ (evilnc--operation-on-lines-or-region '(lambda (b e)
+ (evilnc--fix-buggy-major-modes)
+ (evilnc--comment-or-uncomment-region b e))
+ num)))))
+
+;;;###autoload
+(defun evilnc-copy-and-comment-lines (&optional num)
+ "Copy&paste NUM lines and comment out original lines.
+NUM could be negative.
+
+Case 1: If no region selected, operate on current line.
+if NUM>1, comment/uncomment extra N-1 lines from next line
+
+Case 2: Selected region is expanded to make it contain whole lines.
+Then we operate the expanded region. NUM is ignored."
+ (interactive "p")
+ ;; support negative number
+ (when (< num 0)
+ (forward-line (1+ num))
+ (setq num (- 0 num)))
+
+ (let* ((original-column (current-column)))
+ (evilnc--operation-on-lines-or-region
+ '(lambda (beg end)
+ (evilnc--fix-buggy-major-modes)
+ (let* ((str (buffer-substring-no-properties beg end)))
+ (cond
+ (evilnc-original-above-comment-when-copy-and-comment
+ (let* ((p (point)))
+ (comment-region beg end)
+ (goto-char beg)
+ (insert-before-markers (concat str "\n"))
+ (goto-char p)))
+ (t
+ (goto-char end)
+ (newline 1)
+ (insert-before-markers str)
+ (comment-region beg end)))))
+ num)
+ ;; Go to original column after evilnc-copy-and-comment-lines
+ ;; @see https://github.com/redguardtoo/evil-nerd-commenter/issues/79
+ ;; Thanks for Kevin Brubeck (AKA unhammer) for idea/implementation
+ (move-to-column original-column)))
+
+;;;###autoload
+(defun evilnc-comment-and-kill-ring-save (&optional num)
+ "Comment lines save origin lines into `kill-ring'.
+NUM could be negative.
+
+Case 1: If no region selected, operate on current line.
+;; if NUM>1, comment/uncomment extra N-1 lines from next line
+
+Case 2: Selected region is expanded to make it contain whole lines.
+Then we operate the expanded region. NUM is ignored."
+ (interactive "p")
+ ;; support negative number
+ (when (< num 0)
+ (forward-line (1+ num))
+ (setq num (- 0 num)))
+
+ (evilnc--operation-on-lines-or-region
+ '(lambda (beg end)
+ (evilnc--fix-buggy-major-modes)
+ (kill-new (buffer-substring-no-properties beg end))
+ (comment-region beg end))
+ num))
+
+;; {{ for non-evil user only
+;;;###autoload
+(defun evilnc-copy-to-line (&optional LINENUM)
+ "Copy from current line to LINENUM line. For non-evil user only."
+ (interactive "nCopy to line: ")
+ (if (not (region-active-p))
+ (let* ((b (line-beginning-position))
+ (e (line-end-position)))
+ (save-excursion
+ (evilnc--goto-line LINENUM)
+ (if (< (line-beginning-position) b)
+ (setq b (line-beginning-position)))
+ (if (> (line-end-position) e)
+ (setq e (line-end-position)))
+ (kill-new (buffer-substring-no-properties b e))))))
+
+;;;###autoload
+(defun evilnc-kill-to-line (&optional linenum)
+ "Kill from the current line to the LINENUM line. For non-evil user only."
+ (interactive "NKill to line: ")
+ (if (not (region-active-p))
+ (let* ((b (line-beginning-position))
+ (e (line-end-position)))
+ (save-excursion
+ (evilnc--goto-line linenum)
+ (if (< (line-beginning-position) b)
+ (setq b (line-beginning-position)))
+ (if (> (line-end-position) e)
+ (setq e (line-end-position)))
+ ;; +1 because we need remove the CR
+ (setq e (+ 1 e))
+ (if (> e (point-max)) (setq e (point-max)))
+ (kill-region b e)))))
+;; }}
+
+;;;###autoload
+(defun evilnc-version ()
+ "The version number."
+ (interactive)
+ (message "3.1.3"))
+
+(defvar evil-normal-state-map)
+(defvar evil-visual-state-map)
+(defvar evil-inner-text-objects-map)
+(defvar evil-outer-text-objects-map)
+;;;###autoload
+(defun evilnc-default-hotkeys (&optional no-evil-keybindings)
+ "Setup the key bindings of evil-nerd-comment.
+If NO-EVIL-KEYBINDINGS is t, we don't define keybindings in EVIL."
+ (interactive)
+ ;; Install hotkeys for Emacs mode
+ (global-set-key (kbd "M-;") 'evilnc-comment-or-uncomment-lines)
+ (global-set-key (kbd "C-c l") 'evilnc-quick-comment-or-uncomment-to-the-line)
+ (global-set-key (kbd "C-c c") 'evilnc-copy-and-comment-lines)
+ (global-set-key (kbd "C-c p") 'evilnc-comment-or-uncomment-paragraphs)
+
+ ;; Install key bindings for evil
+ (unless no-evil-keybindings
+ (eval-after-load 'evil
+ '(progn
+ (define-key evil-normal-state-map ",ci" 'evilnc-comment-or-uncomment-lines)
+ (define-key evil-visual-state-map ",ci" 'evilnc-comment-or-uncomment-lines)
+ (define-key evil-normal-state-map ",cl" 'evilnc-quick-comment-or-uncomment-to-the-line)
+ (define-key evil-normal-state-map ",ll" 'evilnc-quick-comment-or-uncomment-to-the-line)
+ (define-key evil-normal-state-map ",cc" 'evilnc-copy-and-comment-lines)
+ (define-key evil-visual-state-map ",cc" 'evilnc-copy-and-comment-lines)
+ (define-key evil-normal-state-map ",cp" 'evilnc-comment-or-uncomment-paragraphs)
+ (define-key evil-normal-state-map ",cr" 'comment-or-uncomment-region)
+ (define-key evil-normal-state-map ",cv" 'evilnc-toggle-invert-comment-line-by-line)))
+
+ ;; Install operator for evil text objects
+ (eval-after-load 'evil-nerd-commenter-operator
+ '(progn
+ ;; operator to comment at text objects
+ (define-key evil-normal-state-map ",." 'evilnc-copy-and-comment-operator)
+ (define-key evil-visual-state-map ",." 'evilnc-copy-and-comment-operator)
+ (define-key evil-normal-state-map ",," 'evilnc-comment-operator)
+ (define-key evil-visual-state-map ",," 'evilnc-comment-operator)
+
+ ;; comment itself is text object
+ (define-key evil-inner-text-objects-map evilnc-comment-text-object 'evilnc-inner-comment)
+ (define-key evil-outer-text-objects-map evilnc-comment-text-object 'evilnc-outer-commenter)))))
+
+;; Attempt to define the operator on first load.
+;; Will only work if evil has been loaded
+(eval-after-load 'evil
+ '(require 'evil-nerd-commenter-operator))
+
+(provide 'evil-nerd-commenter)
+;;; evil-nerd-commenter.el ends here