summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBastien Guerry <bzg@altern.org>2013-02-15 12:12:15 +0100
committerBastien Guerry <bzg@altern.org>2013-02-15 12:12:15 +0100
commit5cdf84ea688f63d27fc24a53c1b04a0993308589 (patch)
tree3fb0725f700529c7d38dda04351b6bc10955cb71
parent7afb487a28c54f21ad233c6b48d34c2bb5808073 (diff)
downloadorg-mode-5cdf84ea688f63d27fc24a53c1b04a0993308589.tar.gz
org.el: New functions `org-drag-line-forward' and `org-drag-line-backward'
* org.el (org-syntax-table, org-transpose-words): Delete. (org-mode): Syntactically Define {} and <> as parentheses. (org-drag-line-forward, org-drag-line-backward): New functions. (org-shiftmetaup, org-shiftmetadown): Fall back on the new functions instead of throwing an error. M-up/down used to drag a line up or down in contexts where it could not do another move. When org-element.el was integrated to core, dragging line by line was not possible anymore since a line is not an "element". This commit reintroduces the ability to drag a line up/down with S-M-<up/down>.
-rw-r--r--lisp/org.el43
1 files changed, 27 insertions, 16 deletions
diff --git a/lisp/org.el b/lisp/org.el
index ace0e69..809cca9 100644
--- a/lisp/org.el
+++ b/lisp/org.el
@@ -4042,13 +4042,6 @@ Use customize to modify this, or restart Emacs after changing it."
(string :tag "HTML end tag")
(option (const verbatim)))))
-(defvar org-syntax-table
- (let ((st (make-syntax-table)))
- (mapc (lambda(c) (modify-syntax-entry
- (string-to-char (car c)) "w p" st))
- org-emphasis-alist)
- st))
-
(defvar org-protecting-blocks
'("src" "example" "latex" "ascii" "html" "ditaa" "dot" "r" "R")
"Blocks that contain text that is quoted, i.e. not processed as Org syntax.
@@ -5189,6 +5182,12 @@ The following commands are available:
(org-set-tag-faces 'org-tag-faces org-tag-faces))
;; Calc embedded
(org-set-local 'calc-embedded-open-mode "# ")
+ (mapc (lambda(c) (modify-syntax-entry (string-to-char (car c)) "w p"))
+ org-emphasis-alist)
+ (modify-syntax-entry ?< "(")
+ (modify-syntax-entry ?> ")")
+ (modify-syntax-entry ?{ "(")
+ (modify-syntax-entry ?} ")")
(modify-syntax-entry ?@ "w")
(modify-syntax-entry ?\" "\"")
(if org-startup-truncated (setq truncate-lines t))
@@ -19166,7 +19165,7 @@ See the individual commands for more information."
((org-at-item-p) (call-interactively 'org-move-item-up))
((org-at-clock-log-p) (let ((org-clock-adjust-closest t))
(call-interactively 'org-timestamp-up)))
- (t (org-modifier-cursor-error))))
+ (t (call-interactively 'org-drag-line-backward))))
(defun org-shiftmetadown (&optional arg)
"Move subtree down or insert table row.
@@ -19181,7 +19180,7 @@ See the individual commands for more information."
((org-at-item-p) (call-interactively 'org-move-item-down))
((org-at-clock-log-p) (let ((org-clock-adjust-closest t))
(call-interactively 'org-timestamp-down)))
- (t (org-modifier-cursor-error))))
+ (t (call-interactively 'org-drag-line-forward))))
(defsubst org-hidden-tree-error ()
(error
@@ -22865,6 +22864,25 @@ Move to the previous element at the same level, when possible."
(org-element-swap-A-B elem next-elem)
(goto-char (+ pos size-next size-blank))))))
+(defun org-drag-line-forward (arg)
+ "Drag the line at point ARG lines forward."
+ (interactive "p")
+ (dotimes (n (abs arg))
+ (let ((c (current-column)))
+ (if (< 0 arg)
+ (progn
+ (beginning-of-line 2)
+ (transpose-lines 1)
+ (beginning-of-line 0))
+ (transpose-lines 1)
+ (beginning-of-line -1))
+ (org-move-to-column c))))
+
+(defun org-drag-line-backward (arg)
+ "Drag the line at point ARG lines backward."
+ (interactive "p")
+ (org-drag-line-forward (- arg)))
+
(defun org-mark-element ()
"Put point at beginning of this element, mark at end.
@@ -22903,13 +22921,6 @@ ones already marked."
(org-element-property :begin elem)
(org-element-property :end elem))))))
-(defun org-transpose-words ()
- "Transpose words, using `org-mode' syntax table."
- (interactive)
- (with-syntax-table org-syntax-table
- (call-interactively 'transpose-words)))
-(org-remap org-mode-map 'transpose-words 'org-transpose-words)
-
(defun org-transpose-element ()
"Transpose current and previous elements, keeping blank lines between.
Point is moved after both elements."