[climacs-cvs] CVS climacs

thenriksen thenriksen at common-lisp.net
Sun May 18 09:05:11 UTC 2008


Update of /project/climacs/cvsroot/climacs
In directory clnet:/tmp/cvs-serv17643

Modified Files:
	core.lisp 
Log Message:
Handle file-errors when finding files.


--- /project/climacs/cvsroot/climacs/core.lisp	2008/01/27 08:13:54	1.25
+++ /project/climacs/cvsroot/climacs/core.lisp	2008/05/18 09:05:11	1.26
@@ -323,40 +323,37 @@
 	 (display-message "~A is a directory name." filepath)
 	 (beep))
         (t
-         (let ((existing-view (find-view-with-pathname filepath)))
-           (if (and existing-view (if readonlyp (read-only-p (buffer existing-view)) t))
-               (switch-to-view (current-window) existing-view)
-             (progn
-               (when readonlyp
-                 (unless (probe-file filepath)
-                   (beep)
-                   (display-message "No such file: ~A" filepath)
-                   (return-from find-file-impl nil)))
-               (let* ((newp (not (probe-file filepath)))
-                      (buffer (if newp
-                                  (make-new-buffer)
-                                  (with-open-file (stream filepath :direction :input)
-                                    (make-buffer-from-stream stream))))
-                      (view (make-new-view-for-climacs
-                             *esa-instance* 'textual-drei-syntax-view
-                             :name (filepath-filename filepath)
-                             :buffer buffer)))
-                 (unless (buffer-pane-p (current-window))
-                   (other-window (or (find-if #'(lambda (window)
-                                                  (typep window 'climacs-pane))
-                                              (windows *esa-instance*))
-                                     (split-window t))))
-                 (setf (offset (point buffer)) (offset (point view))
-                       (syntax view) (make-syntax-for-view view (syntax-class-name-for-filepath filepath))
-                       (file-write-time buffer) (if newp (get-universal-time) (file-write-date filepath))
-                       (needs-saving buffer) nil
-                       (name buffer) (filepath-filename filepath))
-                 (setf (current-view (current-window)) view)
-                 (evaluate-attribute-line view)
-                 (setf (filepath buffer) (pathname filepath)
-                       (read-only-p buffer) readonlyp)
-                 (beginning-of-buffer (point view))
-                 buffer)))))))
+         (handler-case
+             (let ((existing-view (find-view-with-pathname filepath)))
+               (if (and existing-view (if readonlyp (read-only-p (buffer existing-view)) t))
+                   (switch-to-view (current-window) existing-view)
+                   (let* ((newp (not (probe-file filepath)))
+                          (buffer (if (and newp (not readonlyp))
+                                      (make-new-buffer)
+                                      (with-open-file (stream filepath :direction :input)
+                                        (make-buffer-from-stream stream))))
+                          (view (make-new-view-for-climacs
+                                 *esa-instance* 'textual-drei-syntax-view
+                                 :name (filepath-filename filepath)
+                                 :buffer buffer)))
+                     (unless (buffer-pane-p (current-window))
+                       (other-window (or (find-if #'(lambda (window)
+                                                      (typep window 'climacs-pane))
+                                                  (windows *esa-instance*))
+                                         (split-window t))))
+                     (setf (offset (point buffer)) (offset (point view))
+                           (syntax view) (make-syntax-for-view view (syntax-class-name-for-filepath filepath))
+                           (file-write-time buffer) (if newp (get-universal-time) (file-write-date filepath))
+                           (needs-saving buffer) nil
+                           (name buffer) (filepath-filename filepath))
+                     (setf (current-view (current-window)) view)
+                     (evaluate-attribute-line view)
+                     (setf (filepath buffer) (pathname filepath)
+                           (read-only-p buffer) readonlyp)
+                     (beginning-of-buffer (point view))
+                     buffer)))
+           (file-error (c)
+             (display-message "~A" c))))))
 
 (defmethod frame-find-file ((application-frame climacs) filepath)
   (find-file-impl filepath nil))




More information about the Climacs-cvs mailing list