Add patch to execute-extended-command for old versions of emacs and smex.
This commit is contained in:
parent
9ef2df938e
commit
0040b4cb3e
10
init.el
10
init.el
@ -25,23 +25,24 @@
|
|||||||
(add-to-list 'custom-theme-load-path "~/.emacs.d/themes/")
|
(add-to-list 'custom-theme-load-path "~/.emacs.d/themes/")
|
||||||
(add-to-list 'custom-theme-load-path "~/.emacs.d/elpa/")
|
(add-to-list 'custom-theme-load-path "~/.emacs.d/elpa/")
|
||||||
(load-theme 'zenburn t)
|
(load-theme 'zenburn t)
|
||||||
|
(require 'patches)
|
||||||
|
|
||||||
;; =============================================================================
|
;; =============================================================================
|
||||||
;; ELPA
|
;; ELPA
|
||||||
;; =============================================================================
|
;; =============================================================================
|
||||||
|
|
||||||
(require 'package)
|
(require 'package)
|
||||||
(add-to-list 'package-archives
|
|
||||||
'("marmalade" . "http://marmalade-repo.org/packages/"))
|
|
||||||
(add-to-list 'package-archives
|
(add-to-list 'package-archives
|
||||||
'("melpa" . "http://melpa.milkbox.net/packages/") t)
|
'("melpa" . "http://melpa.milkbox.net/packages/") t)
|
||||||
|
(add-to-list 'package-archives
|
||||||
|
'("marmalade" . "http://marmalade-repo.org/packages/"))
|
||||||
(package-initialize)
|
(package-initialize)
|
||||||
|
|
||||||
(defvar my-packages '(color-theme ctags ctags-update evil flymake mo-git-blame
|
(defvar my-packages '(color-theme ctags ctags-update evil flymake mo-git-blame
|
||||||
multiple-cursors no-easy-keys starter-kit-bindings
|
multiple-cursors no-easy-keys starter-kit-bindings
|
||||||
starter-kit-ruby starter-kit magit ido-ubiquitous
|
starter-kit-ruby starter-kit magit ido-ubiquitous
|
||||||
find-file-in-project idle-highlight-mode paredit
|
find-file-in-project idle-highlight-mode paredit
|
||||||
inf-ruby undo-tree rainbow-delimiters smex)
|
inf-ruby undo-tree rainbow-delimiters package-filter smex)
|
||||||
"Packages that must be installed at launch.")
|
"Packages that must be installed at launch.")
|
||||||
|
|
||||||
(defun ensure-package-installed (packages)
|
(defun ensure-package-installed (packages)
|
||||||
@ -225,8 +226,6 @@ Return a list of installed packages or nil for every package not installed."
|
|||||||
(global-set-key (kbd "C-c C-t") 'testify-run-case)
|
(global-set-key (kbd "C-c C-t") 'testify-run-case)
|
||||||
(global-set-key (kbd "C-x C-c") 'kill-emacs)
|
(global-set-key (kbd "C-x C-c") 'kill-emacs)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
;; Something will occasionally override this binding.
|
;; Something will occasionally override this binding.
|
||||||
(global-set-key "\C-cg" 'rope-goto-definition)
|
(global-set-key "\C-cg" 'rope-goto-definition)
|
||||||
|
|
||||||
@ -300,3 +299,4 @@ Return a list of installed packages or nil for every package not installed."
|
|||||||
;; Your init file should contain only one such instance.
|
;; Your init file should contain only one such instance.
|
||||||
;; If there is more than one, they won't work right.
|
;; If there is more than one, they won't work right.
|
||||||
'(safe-local-variable-values (quote ((python-indent . 4) (whitespace-line-column . 80) (lexical-binding . t)))))
|
'(safe-local-variable-values (quote ((python-indent . 4) (whitespace-line-column . 80) (lexical-binding . t)))))
|
||||||
|
|
||||||
|
263
lisp/line-num.el
263
lisp/line-num.el
@ -1,263 +0,0 @@
|
|||||||
;;; line-num.el --- Display line numbers in left-margin of buffer.
|
|
||||||
;;
|
|
||||||
;; Filename: line-num.el
|
|
||||||
;; Description: Display line numbers in left-margin of buffer.
|
|
||||||
;; Author: (Darryl Okahata) darrylo@hpsrdmo, Drew Adams
|
|
||||||
;; Maintainer: Drew Adams
|
|
||||||
;; Copyright (C) 1999-2013, Drew Adams, all rights reserved.
|
|
||||||
;; Copyright (C) 1989, Hewlett-Packard, all rights reserved.
|
|
||||||
;; Created: Wed Mar 31 16:18:24 1999
|
|
||||||
;; Version: 21.0
|
|
||||||
;; Last-Updated: Fri Dec 28 10:06:21 2012 (-0800)
|
|
||||||
;; By: dradams
|
|
||||||
;; Update #: 214
|
|
||||||
;; URL: http://www.emacswiki.org/line-num.el
|
|
||||||
;; Doc URL: http://emacswiki.org/LineNumbers
|
|
||||||
;; Keywords: local
|
|
||||||
;; Compatibility: GNU Emacs: 20.x, 21.x, 22.x, 23.x, 24.x
|
|
||||||
;;
|
|
||||||
;; Features that might be required by this library:
|
|
||||||
;;
|
|
||||||
;; None
|
|
||||||
;;
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;
|
|
||||||
;;; Commentary:
|
|
||||||
;;
|
|
||||||
;; Display line numbers in left-margin of buffer.
|
|
||||||
;;
|
|
||||||
;; New functions defined here:
|
|
||||||
;;
|
|
||||||
;; `display-line-numbers', `toggle-line-numbers-display',
|
|
||||||
;; `turn-on-line-numbers-display', `turn-off-line-numbers-display'.
|
|
||||||
;;
|
|
||||||
;; NOTE: `setnu.el' now provides similar, but generally better,
|
|
||||||
;; functionality.
|
|
||||||
;;
|
|
||||||
;; Original author was Darryl Okahata darrylo@hpsrdmo: The copy on
|
|
||||||
;; which the current (Adams) modifications were made was obtained from
|
|
||||||
;; Rick Kunin (rickk@sperdk).
|
|
||||||
;;
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;
|
|
||||||
;;; Change Log:
|
|
||||||
;;
|
|
||||||
;; 2004/11/26 dadams
|
|
||||||
;; Replaced decf with setq...1+.
|
|
||||||
;; turn-off-line-numbers-display: Error if not displaying line #s.
|
|
||||||
;; Removed calls to `fit-frame' (and require of fit-frame.el).
|
|
||||||
;; 2000/11/01 dadams
|
|
||||||
;; 1. Added: toggle-line-numbers-display, turn-on-line-numbers-display,
|
|
||||||
;; turn-off-line-numbers-display.
|
|
||||||
;; 2. Added global vars: displaying-line-numbers-p,
|
|
||||||
;; display-line-numbers-format-string, display-line-numbers-first-line,
|
|
||||||
;; display-line-numbers-count, display-line-numbers-buffer-name,
|
|
||||||
;; display-line-numbers-modified-p.
|
|
||||||
;; 1999/04/14 dadams
|
|
||||||
;; Commented out assignment to unused free var: insert-end.
|
|
||||||
;;
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;
|
|
||||||
;; This program 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 2, or (at your option)
|
|
||||||
;; any later version.
|
|
||||||
|
|
||||||
;; This program 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; see the file COPYING. If not, write to
|
|
||||||
;; the Free Software Foundation, Inc., 51 Franklin Street, Fifth
|
|
||||||
;; Floor, Boston, MA 02110-1301, USA.
|
|
||||||
;;
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;
|
|
||||||
;;; Code:
|
|
||||||
|
|
||||||
;;>> Problem: Tabs at beginning of lines
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;
|
|
||||||
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defun display-line-numbers ()
|
|
||||||
"Temporarily display line numbers in left margin of current buffer."
|
|
||||||
(interactive)
|
|
||||||
(or (eq (current-buffer) (window-buffer (selected-window)))
|
|
||||||
(error "Current buffer, %s, is not the selected window's buffer"
|
|
||||||
(buffer-name)))
|
|
||||||
(let ((buffer-read-only nil)
|
|
||||||
(modified (buffer-modified-p))
|
|
||||||
(name buffer-file-name)
|
|
||||||
(point (point-marker))
|
|
||||||
format-string
|
|
||||||
line-number
|
|
||||||
(count 0)
|
|
||||||
nlines
|
|
||||||
first-line)
|
|
||||||
(save-restriction
|
|
||||||
(widen)
|
|
||||||
(save-excursion
|
|
||||||
(setq first-line (window-start (selected-window)))
|
|
||||||
(goto-char first-line)
|
|
||||||
(setq line-number (1+ (count-lines (point-min) (point))))
|
|
||||||
(move-to-window-line -1)
|
|
||||||
(beginning-of-line)
|
|
||||||
(setq nlines (count-lines first-line (point)))
|
|
||||||
(let ((max (+ line-number nlines)))
|
|
||||||
(setq format-string (cond ((< max 100) "%2d ")
|
|
||||||
((< max 1000) "%3d ")
|
|
||||||
((< max 10000) "%4d ")
|
|
||||||
(t "%7d "))))))
|
|
||||||
(save-excursion
|
|
||||||
(unwind-protect
|
|
||||||
(progn
|
|
||||||
(goto-char first-line)
|
|
||||||
;; defeat file locking... don't try this at home, kids!
|
|
||||||
(setq buffer-file-name nil)
|
|
||||||
(while (<= count nlines)
|
|
||||||
(insert-before-markers (format format-string line-number))
|
|
||||||
;;;(setq insert-end (point)) THIS VAR IS FREE - AND UNUSED!
|
|
||||||
(setq line-number (1+ line-number))
|
|
||||||
(setq count (1+ count))
|
|
||||||
(forward-line 1))
|
|
||||||
(set-window-start (selected-window) first-line)
|
|
||||||
(goto-char point)
|
|
||||||
(set-buffer-modified-p modified)
|
|
||||||
(message "<<< Press SPACE to continue >>>")
|
|
||||||
(let ((char (read-char)))
|
|
||||||
(or (eql char ?\ )
|
|
||||||
(setq unread-command-events (list char))))
|
|
||||||
)
|
|
||||||
(goto-char first-line)
|
|
||||||
(let ((n (1+ (- (aref format-string 1) ?0))))
|
|
||||||
(while (> count 0)
|
|
||||||
(setq count (1- count))
|
|
||||||
(delete-char n)
|
|
||||||
(forward-line 1)))
|
|
||||||
(setq buffer-file-name name)
|
|
||||||
(set-buffer-modified-p modified)))))
|
|
||||||
|
|
||||||
;;;-----------------------------------------------------------------
|
|
||||||
|
|
||||||
(defvar displaying-line-numbers-p nil)
|
|
||||||
(make-variable-buffer-local 'displaying-line-numbers-p)
|
|
||||||
(defvar display-line-numbers-format-string nil)
|
|
||||||
(make-variable-buffer-local 'display-line-numbers-format-string)
|
|
||||||
(defvar display-line-numbers-first-line nil)
|
|
||||||
(make-variable-buffer-local 'display-line-numbers-first-line)
|
|
||||||
(defvar display-line-numbers-count 0)
|
|
||||||
(make-variable-buffer-local 'display-line-numbers-count)
|
|
||||||
(defvar display-line-numbers-buffer-name nil)
|
|
||||||
(make-variable-buffer-local 'display-line-numbers-buffer-name)
|
|
||||||
(defvar display-line-numbers-modified-p nil)
|
|
||||||
(make-variable-buffer-local 'display-line-numbers-modified-p)
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defun toggle-line-numbers-display (arg)
|
|
||||||
"Display/clear line numbers in left margin of current buffer.
|
|
||||||
With prefix ARG, just number lines in current window, not all lines in
|
|
||||||
buffer."
|
|
||||||
(interactive "P")
|
|
||||||
(if displaying-line-numbers-p
|
|
||||||
(turn-off-line-numbers-display)
|
|
||||||
(turn-on-line-numbers-display arg)))
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defun turn-on-line-numbers-display (arg)
|
|
||||||
"Display line numbers in left margin of current buffer.
|
|
||||||
With prefix ARG, just number lines in current window, not all lines in
|
|
||||||
buffer."
|
|
||||||
(interactive "P")
|
|
||||||
(or (eq (current-buffer) (window-buffer (selected-window)))
|
|
||||||
(error "Current buffer, %s, is not the selected window's buffer"
|
|
||||||
(buffer-name)))
|
|
||||||
(let ((buffer-read-only nil)
|
|
||||||
(point (point-marker))
|
|
||||||
line-number
|
|
||||||
nlines)
|
|
||||||
(setq display-line-numbers-buffer-name buffer-file-name)
|
|
||||||
(setq display-line-numbers-modified-p (buffer-modified-p))
|
|
||||||
(save-restriction
|
|
||||||
(widen)
|
|
||||||
(save-excursion
|
|
||||||
(setq display-line-numbers-first-line
|
|
||||||
(if arg
|
|
||||||
(window-start (selected-window))
|
|
||||||
(point-min)))
|
|
||||||
(goto-char display-line-numbers-first-line)
|
|
||||||
(setq line-number (1+ (count-lines (point-min) (point))))
|
|
||||||
(if arg
|
|
||||||
(move-to-window-line -1)
|
|
||||||
(goto-char (point-max)))
|
|
||||||
(beginning-of-line)
|
|
||||||
(setq nlines (count-lines display-line-numbers-first-line (point)))
|
|
||||||
(let ((max (+ line-number nlines)))
|
|
||||||
(setq display-line-numbers-format-string (cond ((< max 100) "%2d ")
|
|
||||||
((< max 1000) "%3d ")
|
|
||||||
((< max 10000) "%4d ")
|
|
||||||
(t "%7d "))))))
|
|
||||||
(save-excursion
|
|
||||||
(condition-case nil
|
|
||||||
(progn
|
|
||||||
(goto-char display-line-numbers-first-line)
|
|
||||||
(setq buffer-file-name nil) ; To prevent saving with line numbers etc.
|
|
||||||
(setq displaying-line-numbers-p t)
|
|
||||||
(while (<= display-line-numbers-count nlines)
|
|
||||||
(insert-before-markers
|
|
||||||
(format display-line-numbers-format-string line-number))
|
|
||||||
(setq line-number (1+ line-number))
|
|
||||||
(setq display-line-numbers-count (1+ display-line-numbers-count))
|
|
||||||
(forward-line 1))
|
|
||||||
(when arg
|
|
||||||
(set-window-start (selected-window) display-line-numbers-first-line))
|
|
||||||
(goto-char point)
|
|
||||||
(set-buffer-modified-p display-line-numbers-modified-p))
|
|
||||||
(error
|
|
||||||
(progn
|
|
||||||
(goto-char display-line-numbers-first-line)
|
|
||||||
(let ((n (1+ (- (aref display-line-numbers-format-string 1) ?0))))
|
|
||||||
(while (> display-line-numbers-count 0)
|
|
||||||
(setq display-line-numbers-count (1- display-line-numbers-count))
|
|
||||||
(delete-char n)
|
|
||||||
(forward-line 1)))
|
|
||||||
(setq buffer-file-name display-line-numbers-buffer-name)
|
|
||||||
(set-buffer-modified-p display-line-numbers-modified-p)
|
|
||||||
(setq displaying-line-numbers-p nil))))))
|
|
||||||
(let ((curr-line (count-lines (window-start) (point))))
|
|
||||||
(when (> curr-line 0) (setq curr-line (1+ curr-line)))
|
|
||||||
(recenter curr-line)))
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defun turn-off-line-numbers-display ()
|
|
||||||
"Clear displayed line numbers from left margin of current buffer."
|
|
||||||
(interactive)
|
|
||||||
(unless (eq (current-buffer) (window-buffer (selected-window)))
|
|
||||||
(error "Current buffer, `%s', is not the selected window's buffer"
|
|
||||||
(buffer-name)))
|
|
||||||
(unless displaying-line-numbers-p
|
|
||||||
(error "Not displaying line numbers in buffer `%s'" (buffer-name)))
|
|
||||||
(let ((buffer-read-only nil))
|
|
||||||
(save-excursion
|
|
||||||
(when (boundp 'display-line-numbers-buffer-name)
|
|
||||||
(setq buffer-file-name display-line-numbers-buffer-name))
|
|
||||||
(goto-char display-line-numbers-first-line)
|
|
||||||
(let ((n (1+ (- (aref display-line-numbers-format-string 1) ?0))))
|
|
||||||
(while (> display-line-numbers-count 0)
|
|
||||||
(setq display-line-numbers-count (1- display-line-numbers-count))
|
|
||||||
(delete-char n)
|
|
||||||
(forward-line 1)))
|
|
||||||
(when (boundp 'display-line-numbers-modified-p)
|
|
||||||
(set-buffer-modified-p display-line-numbers-modified-p))
|
|
||||||
(setq displaying-line-numbers-p nil))))
|
|
||||||
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
|
|
||||||
(provide 'line-num)
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
||||||
;;; line-num.el ends here
|
|
51
lisp/misc/patches.el
Normal file
51
lisp/misc/patches.el
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
(if (equal (cons 1 1)
|
||||||
|
(ignore-errors
|
||||||
|
(subr-arity (symbol-function 'execute-extended-command))))
|
||||||
|
(progn (message "Patching execute-extended-command")
|
||||||
|
(defun execute-extended-command (prefixarg &optional command-name)
|
||||||
|
;; Based on Fexecute_extended_command in keyboard.c of Emacs.
|
||||||
|
;; Aaron S. Hawley <aaron.s.hawley(at)gmail.com> 2009-08-24
|
||||||
|
"Read a command name, then read the arguments and call the command.
|
||||||
|
Interactively, to pass a prefix argument to the command you are
|
||||||
|
invoking, give a prefix argument to `execute-extended-command'.
|
||||||
|
Noninteractively, the argument PREFIXARG is the prefix argument to
|
||||||
|
give to the command you invoke."
|
||||||
|
(interactive (list current-prefix-arg (read-extended-command)))
|
||||||
|
;; Emacs<24 calling-convention was with a single `prefixarg' argument.
|
||||||
|
(if (null command-name)
|
||||||
|
(setq command-name (let ((current-prefix-arg prefixarg)) ; for prompt
|
||||||
|
(read-extended-command))))
|
||||||
|
(let* ((function (and (stringp command-name) (intern-soft command-name)))
|
||||||
|
(binding (and suggest-key-bindings
|
||||||
|
(not executing-kbd-macro)
|
||||||
|
(where-is-internal function overriding-local-map t))))
|
||||||
|
(unless (commandp function)
|
||||||
|
(error "`%s' is not a valid command name" command-name))
|
||||||
|
(setq this-command function)
|
||||||
|
;; Normally `real-this-command' should never be changed, but here we really
|
||||||
|
;; want to pretend that M-x <cmd> RET is nothing more than a "key
|
||||||
|
;; binding" for <cmd>, so the command the user really wanted to run is
|
||||||
|
;; `function' and not `execute-extended-command'. The difference is
|
||||||
|
;; visible in cases such as M-x <cmd> RET and then C-x z (bug#11506).
|
||||||
|
(setq real-this-command function)
|
||||||
|
(let ((prefix-arg prefixarg))
|
||||||
|
(command-execute function 'record))
|
||||||
|
;; If enabled, show which key runs this command.
|
||||||
|
(when binding
|
||||||
|
;; But first wait, and skip the message if there is input.
|
||||||
|
(let* ((waited
|
||||||
|
;; If this command displayed something in the echo area;
|
||||||
|
;; wait a few seconds, then display our suggestion message.
|
||||||
|
(sit-for (cond
|
||||||
|
((zerop (length (current-message))) 0)
|
||||||
|
((numberp suggest-key-bindings) suggest-key-bindings)
|
||||||
|
(t 2)))))
|
||||||
|
(when (and waited (not (consp unread-command-events)))
|
||||||
|
(with-temp-message
|
||||||
|
(format "You can run the command `%s' with %s"
|
||||||
|
function (key-description binding))
|
||||||
|
(sit-for (if (numberp suggest-key-bindings)
|
||||||
|
suggest-key-bindings
|
||||||
|
2))))))))) (message "Not patching execute-extended-command"))
|
||||||
|
|
||||||
|
(provide 'patches)
|
Loading…
Reference in New Issue
Block a user