[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[elpa] master 6ec1443 19/21: Merge branch 'master' of github.com:bgamari
From: |
Stefan Monnier |
Subject: |
[elpa] master 6ec1443 19/21: Merge branch 'master' of github.com:bgamari/dts-mode |
Date: |
Tue, 18 Aug 2015 14:59:07 +0000 |
branch: master
commit 6ec1443ead16105234765f9b48df9b4aca562e61
Merge: 42ed276 a5d6412
Author: Ben Gamari <address@hidden>
Commit: Ben Gamari <address@hidden>
Merge branch 'master' of github.com:bgamari/dts-mode
---
dts-mode.el | 31 +++++++++++++++++++++++++++++--
1 files changed, 29 insertions(+), 2 deletions(-)
diff --git a/dts-mode.el b/dts-mode.el
index 1d26151..2ee2f44 100644
--- a/dts-mode.el
+++ b/dts-mode.el
@@ -67,9 +67,34 @@
table))
+(defun dts--calculate-indentation ()
+ (interactive)
+ (save-excursion
+ (let ((end (point-at-eol))
+ (cnt 0)
+ (initial-point (point)))
+ (goto-char 0)
+ (while (re-search-forward "\\([{}]\\)" end t)
+ (if (string= (match-string-no-properties 0) "{")
+ (setq cnt (1+ cnt))
+ (setq cnt (1- cnt))))
+ ;; subtract one if the current line has an opening brace since we
+ ;; shouldn't add the indentation level until the following line
+ (goto-char initial-point)
+ (beginning-of-line)
+ (when (re-search-forward "{" (point-at-eol) t)
+ (setq cnt (1- cnt)))
+ cnt)))
+
+(defun dts-indent-line ()
+ (interactive)
+ (let ((indent (dts--calculate-indentation)))
+ (indent-line-to (* indent tab-width))))
+
(defalias 'dts-parent-mode
(if (fboundp 'prog-mode) 'prog-mode 'fundamental-mode))
+;;;###autoload
(define-derived-mode dts-mode dts-parent-mode "Devicetree"
"Major mode for editing Devicetrees"
:group 'dts-mode
@@ -80,10 +105,12 @@
(set (make-local-variable 'comment-start) "/* ")
(set (make-local-variable 'comment-end) " */")
- (set (make-local-variable 'indent-tabs-mode) nil)
- (set (make-local-variable 'comment-multi-line) t))
+ (set (make-local-variable 'comment-multi-line) t)
+ (set (make-local-variable 'indent-line-function) 'dts-indent-line))
+;;;###autoload
(add-to-list 'auto-mode-alist '("\\.dts\\'" . dts-mode))
+;;;###autoload
(add-to-list 'auto-mode-alist '("\\.dtsi\\'" . dts-mode))
(provide 'dts-mode)
- [elpa] master c3624e9 06/21: Update README.mkd, (continued)
- [elpa] master c3624e9 06/21: Update README.mkd, Stefan Monnier, 2015/08/18
- [elpa] master 90c6ac3 03/21: More readme, Stefan Monnier, 2015/08/18
- [elpa] master 72e1086 21/21: packages/dts-mode: New major mode, Stefan Monnier, 2015/08/18
- [elpa] master 42ed276 18/21: Spell Device Tree with a space, Stefan Monnier, 2015/08/18
- [elpa] master daab780 20/21: Add 'packages/dts-mode/' from commit '6ec1443ead16105234765f9b48df9b4aca562e61', Stefan Monnier, 2015/08/18
- [elpa] master 4fd4484 10/21: A few fixes, Stefan Monnier, 2015/08/18
- [elpa] master 87eefb3 13/21: Merge pull request #2 from jamienicol/master, Stefan Monnier, 2015/08/18
- [elpa] master 565565e 11/21: Merge pull request #1 from purcell/patch-1, Stefan Monnier, 2015/08/18
- [elpa] master b66e6f9 12/21: Add autoload statements, Stefan Monnier, 2015/08/18
- [elpa] master 7f10920 16/21: respect the user's indent-tabs-mode, Stefan Monnier, 2015/08/18
- [elpa] master 6ec1443 19/21: Merge branch 'master' of github.com:bgamari/dts-mode,
Stefan Monnier <=
- [elpa] master bd9038d 15/21: Merge pull request #3 from mgalgs/indentation, Stefan Monnier, 2015/08/18
- [elpa] master a5d6412 17/21: Merge pull request #4 from mgalgs/tabsplz, Stefan Monnier, 2015/08/18