diff --git a/ChangeLog b/ChangeLog index b0517f6bea..a493391da7 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,4 +1,6 @@ -Wed Mar 30 22:54:24 2011 Nobuyoshi Nakada +Wed Mar 30 22:55:47 2011 Nobuyoshi Nakada + + * misc/ruby-mode.el (ruby-toggle-block): toggle do/end and {}. * misc/ruby-mode.el (ruby-move-to-block): move to opening of block. diff --git a/misc/ruby-mode.el b/misc/ruby-mode.el index 3799541901..48d91836f2 100644 --- a/misc/ruby-mode.el +++ b/misc/ruby-mode.el @@ -172,6 +172,7 @@ (define-key ruby-mode-map "\t" 'ruby-indent-command) (define-key ruby-mode-map "\C-c\C-e" 'ruby-insert-end) (define-key ruby-mode-map "\C-j" 'ruby-reindent-then-newline-and-indent) + (define-key ruby-mode-map "\C-c{" 'ruby-toggle-block) (define-key ruby-mode-map "\C-c\C-u" 'uncomment-region)) (defvar ruby-mode-syntax-table nil @@ -1161,6 +1162,44 @@ balanced expression is found." (if mlist (concat mlist mname) mname) mlist))))) +(defun ruby-brace-to-do-end () + (when (looking-at "{") + (let ((orig (point)) (end (progn (ruby-forward-sexp) (point)))) + (when (eq (char-before) ?\}) + (delete-char -1) + (if (eq (char-syntax (char-before)) ?w) + (insert " ")) + (insert "end") + (if (eq (char-syntax (char-after)) ?w) + (insert " ")) + (goto-char orig) + (delete-char 1) + (if (eq (char-syntax (char-before)) ?w) + (insert " ")) + (insert "do") + (if (eq (char-syntax (char-after)) ?w) + (insert " ")) + t)))) + +(defun ruby-do-end-to-brace () + (when (and (or (bolp) + (not (memq (char-syntax (char-before)) '(?w ?_)))) + (looking-at "\\