summaryrefslogtreecommitdiff
path: root/misc/ruby-additional.el
blob: 152067e48e9f8e594b46074e3e63438014e05d12 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
;; missing functions in Emacs 24.

(eval-after-load "\\(\\`\\|/\\)ruby-mode\\.elc?\\(\\.gz\\)?\\'"
  (progn
    (define-key ruby-mode-map "\C-c\C-e" 'ruby-insert-end)
    (define-key ruby-mode-map "\C-c{" 'ruby-toggle-block)

    (defun ruby-insert-end ()
      (interactive)
      (if (eq (char-syntax (char-before)) ?w)
	  (insert " "))
      (insert "end")
      (save-excursion
	(if (eq (char-syntax (char-after)) ?w)
	    (insert " "))
	(ruby-indent-line t)
	(end-of-line)))

    (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")
	    (when (looking-at "\\sw\\||")
	      (insert " ")
	      (backward-char))
	    t))))

    (defun ruby-do-end-to-brace ()
      (when (and (or (bolp)
		     (not (memq (char-syntax (char-before)) '(?w ?_))))
		 (looking-at "\\<do\\(\\s \\|$\\)"))
	(let ((orig (point)) (end (progn (ruby-forward-sexp) (point))))
	  (backward-char 3)
	  (when (looking-at ruby-block-end-re)
	    (delete-char 3)
	    (insert "}")
	    (goto-char orig)
	    (delete-char 2)
	    (insert "{")
	    (if (looking-at "\\s +|")
		(delete-char (- (match-end 0) (match-beginning 0) 1)))
	    t))))

    (defun ruby-toggle-block ()
      (interactive)
      (or (ruby-brace-to-do-end)
	  (ruby-do-end-to-brace)))

    (defun ruby-mode-set-encoding ()
      "Insert a magic comment header with the proper encoding always.
Now encoding needs to be set always explicitly actually."
      (save-excursion
	(let ((coding-system))
	  (widen)
	  (goto-char (point-min))
	  (if (re-search-forward "[^\0-\177]" nil t)
	      (progn
		(goto-char (point-min))
		(setq coding-system
                      (or coding-system-for-write
                          buffer-file-coding-system))
		(if coding-system
		    (setq coding-system
			  (or (coding-system-get coding-system 'mime-charset)
			      (coding-system-change-eol-conversion coding-system nil))))
		(setq coding-system
		      (if coding-system
			  (symbol-name
			   (or (and ruby-use-encoding-map
				    (cdr (assq coding-system ruby-encoding-map)))
			       coding-system))
			"ascii-8bit")))
	    (setq coding-system "us-ascii"))
	  (if (looking-at "^#!") (beginning-of-line 2))
	  (cond ((looking-at "\\s *#.*-\*-\\s *\\(en\\)?coding\\s *:\\s *\\([-a-z0-9_]*\\)\\s *\\(;\\|-\*-\\)")
		 (unless (string= (match-string 2) coding-system)
		   (goto-char (match-beginning 2))
		   (delete-region (point) (match-end 2))
		   (and (looking-at "-\*-")
			(let ((n (skip-chars-backward " ")))
			  (cond ((= n 0) (insert "  ") (backward-char))
				((= n -1) (insert " "))
				((forward-char)))))
		   (insert coding-system)))
		((looking-at "\\s *#.*coding\\s *[:=]"))
		(t (when ruby-insert-encoding-magic-comment
		     (insert "# -*- coding: " coding-system " -*-\n")))))))

    ))