[slime-cvs] CVS update: slime/slime.el 
    Luke Gorrie 
    lgorrie at common-lisp.net
       
    Mon Jan 19 20:28:46 UTC 2004
    
    
  
Update of /project/slime/cvsroot/slime
In directory common-lisp.net:/tmp/cvs-serv11968
Modified Files:
	slime.el 
Log Message:
(slime-close-all-sexp): New command to close all unmatched parens in
the current defun. Bound to `C-c C-]'. With prefix argument, only
operate in the region (for closing subforms).
(Patch from Michael Weber).
Date: Mon Jan 19 15:28:46 2004
Author: lgorrie
Index: slime/slime.el
diff -u slime/slime.el:1.188 slime/slime.el:1.189
--- slime/slime.el:1.188	Mon Jan 19 15:14:03 2004
+++ slime/slime.el	Mon Jan 19 15:28:45 2004
@@ -440,6 +440,7 @@
     (">" slime-list-callees :prefixed t :inferior t :sldb t)
     ;; "Other"
     ("\I"  slime-inspect :prefixed t :inferior t :sldb t)
+    ("\C-]" slime-close-all-sexp :prefixed t :inferior t :sldb t)
     ("\C-xt" slime-thread-control-panel :prefixed t :inferior t :sldb t)))
 
 ;; Maybe a good idea, maybe not..
@@ -4701,6 +4702,60 @@
         finally (error "Can't find unshown buffer in %S" mode)))
 
 
+;;; Editing commands
+
+(defvar *slime-comment-start-regexp*
+  "\\(\\(^\\|[^\n\\\\]\\)\\([\\\\][\\\\]\\)*\\);+[ \t]*"
+  "Regexp to match the start of a comment.")
+
+(defun slime-beginning-of-comment ()
+  "Move point to beginning of comment.
+If point is inside a comment move to beginning of comment and return point.
+Otherwise leave point unchanged and return NIL."
+  (let ((boundary (point)))
+    (beginning-of-line)
+    (cond ((re-search-forward *slime-comment-start-regexp* boundary t)
+           (point))
+          (t (goto-char boundary) 
+             nil))))
+
+(defun slime-close-all-sexp (&optional region)
+  "Balance parentheses of open s-expressions at point.
+Insert enough right parentheses to balance unmatched left parentheses.
+Delete extra left parentheses.  Reformat trailing parentheses 
+Lisp-stylishly.
+
+If REGION is true, operate on the region. Otherwise operate on
+the top-level sexp before point."
+  (interactive "P")
+  (message "region = %S" region)
+  (let ((sexp-level 0)
+        point)
+    (save-excursion
+      (save-restriction
+        (when region
+          (narrow-to-region (region-beginning) (region-end))
+          (goto-char (point-max)))
+        ;; skip over closing parens, but not into comment
+        (skip-chars-backward ") \t\n")
+        (when (slime-beginning-of-comment)
+          (forward-line)
+          (skip-chars-forward " \t"))
+        (setq point (point))
+        ;; count sexps until either '(' or comment is found at first column
+        (while (and (not (looking-at "^[(;]"))
+                  (ignore-errors (backward-up-list 1) t))
+          (incf sexp-level))))
+    (when (> sexp-level 0)
+      ;; insert correct number of right parens
+      (goto-char point)
+      (dotimes (i sexp-level) (insert ")"))
+      ;; delete extra right parens
+      (setq point (point))
+      (skip-chars-forward " \t\n)")
+      (skip-chars-backward " \t\n")
+      (delete-region point (point)))))
+
 ;;; Test suite
 
 (defvar slime-tests '()
    
    
More information about the slime-cvs
mailing list