]> git.eshelyaron.com Git - emacs.git/commitdiff
(doc-view-pdf/ps->png): Make sure we a have a valid cwd.
authorStefan Monnier <monnier@iro.umontreal.ca>
Fri, 18 Jan 2008 20:09:26 +0000 (20:09 +0000)
committerStefan Monnier <monnier@iro.umontreal.ca>
Fri, 18 Jan 2008 20:09:26 +0000 (20:09 +0000)
(doc-view-insert-image): Do something if the image is missing.
(doc-view-mode): Don't use file-remote-p.

lisp/ChangeLog
lisp/doc-view.el

index 3cb8779df67856d5c23bd7ac7b683f27c49e25d7..182812f2c7a3b05294d3f8408f1af263819d37bc 100644 (file)
@@ -1,28 +1,33 @@
+2008-01-18  Stefan Monnier  <monnier@iro.umontreal.ca>
+
+       * doc-view.el (doc-view-pdf/ps->png): Make sure we a have a valid cwd.
+       (doc-view-insert-image): Do something if the image is missing.
+       (doc-view-mode): Don't use file-remote-p.
+
 2008-01-18  Bastien Guerry  <Bastien.Guerry@ens.fr>
 
-       * textmodes/org-export-latex.el (org-export-latex-cleaned-string):
-       Fixed.
-        (org-export-latex-special-chars): Convert "..." in \ldots
+       * textmodes/org-export-latex.el (org-export-latex-cleaned-string): Fix.
+       (org-export-latex-special-chars): Convert "..." in \ldots
        and skip tables.
-        (org-export-latex-fontify-headline): Changed parameter name.
-        (org-export-as-latex): Handle export of subtrees.
+       (org-export-latex-fontify-headline): Change parameter name.
+       (org-export-as-latex): Handle export of subtrees.
        (org-export-latex-make-header): New argument TITLE.
        (org-export-latex-content): New argument EXCLUDE-LIST.
        (org-list-parse-list): New name for org-export-latex-parse-list.
-        (org-export-latex-make-header): New name for
+       (org-export-latex-make-header): New name for
        org-export-latex-make-preamble.
        (org-list-to-generic): New name of org-export-list-to-generic.
        (org-list-to-latex): New name of org-export-list-to-latex.
        (org-list-item-begin, org-list-end, org-list-insert-radio-list)
        (org-list-send-list, org-list-to-texinfo)
        (org-list-to-html): New functions.
-        (org-export-latex-tables-column-borders)
+       (org-export-latex-tables-column-borders)
        (org-export-latex-default-class, org-export-latex-classes)
        (org-export-latex-classes-sectioning)
        (org-list-radio-list-templates): New options.
-        (org-export-latex-header): New variable.
+       (org-export-latex-header): New variable.
        (org-latex-entities): New constant.
-        (org-export-latex-default-sectioning, org-export-latex-preamble)
+       (org-export-latex-default-sectioning, org-export-latex-preamble)
        (org-export-latex-prepare-text-option)
        (org-export-latex-get-sectioning): Remove.
 
        (org-export-html-convert-special-strings): New function.
        (org-html-do-expand): `org-export-html-convert-special-strings'
        added to the list of conversion.
-       (org-infile-export-plist, org-get-current-options): Added support
+       (org-infile-export-plist, org-get-current-options): Add support
        for "-" in the #+OPTION line to let user switch on/off special
        strings conversion.
        (org-export-plist-vars): New :html-table-tag property.
        (org-export-as-html, org-format-org-table-html)
        (org-format-table-table-html) Use the :html-table-tag property
        instead of the `org-export-html-table-tag' global value.
-       (org-additional-option-like-keywords): Added "TBLFM".
+       (org-additional-option-like-keywords): Add "TBLFM".
        (org-entry-properties): Include the CLOCKSUM special property.
        (org-columns-edit-value): Do not allow to edit the special
        CLOCKSUM property.
@@ -88,7 +93,7 @@
        (org-agenda-restriction-lock): New face.
        (org-agenda-restriction-lock-overlay)
        (org-speedbar-restriction-lock-overlay): New variables.
-       (org-open-at-point): Removed obsolete way to do redirection in
+       (org-open-at-point): Remove obsolete way to do redirection in
        shell links.
        (org-imenu-and-speedbar): New customization group.
        (org-entry-properties): Return keyword-less time strings.
        (org-verbatim-re): New variable.
        (org-hide-emphasis-markers): New option.
        (org-additional-option-like-keywords): Add new keywords.
-       (org-get-entry): Renamed from `org-get-cleaned-entry'.
+       (org-get-entry): Rename from `org-get-cleaned-entry'.
        (org-icalendar-cleanup-string): New function for quoting icalendar text.
        (org-agenda-skip-scheduled-if-done): New option.
        (org-agenda-get-scheduled, org-agenda-get-blocks):
        (org-entry-properties): Add CATEGORY as a special property.
        (org-use-property-inheritance): Allow a list of properties as a value.
        (org-eval-in-calendar): No longer update the prompt.
-       (org-read-date-popup-calendar): Renamed from
+       (org-read-date-popup-calendar): Rename from
        `org-popup-calendar-for-date-prompt'.
        (org-read-date-display-live): New variable.
        (org-read-date-display): New function.
index 23bf4096e9338d2554cdd5d829b314529b61085c..ba4aadb1e6b312671846c072f91f134a48a2ccec 100644 (file)
 ;;; Todo:
 
 ;; - better menu.
-;; - don't use `find-file'.
 ;; - Bind slicing to a drag event.
 ;; - doc-view-fit-doc-to-window and doc-view-fit-window-to-doc.
-;; - zoom the region around the cursor (like xdvi).
+;; - zoom the region around the cursor (like xdvi).
 ;; - get rid of the silly arrow in the fringe.
 ;; - improve anti-aliasing (pdf-utils gets it better).
 
@@ -558,13 +557,16 @@ Should be invoked when the cached images aren't up-to-date."
 (defun doc-view-pdf/ps->png (pdf-ps png)
   "Convert PDF-PS to PNG asynchronously."
   (setq doc-view-current-converter-process
-       (apply 'start-process
-              (append (list "pdf/ps->png" doc-view-conversion-buffer
-                            doc-view-ghostscript-program)
-                      doc-view-ghostscript-options
-                       (list (format "-r%d" (round doc-view-resolution)))
-                      (list (concat "-sOutputFile=" png))
-                      (list pdf-ps)))
+        ;; Make sure the process is started in an existing directory,
+        ;; (rather than some file-name-handler-managed dir, for example).
+        (let ((default-directory (file-name-directory pdf-ps)))
+          (apply 'start-process
+                 (append (list "pdf/ps->png" doc-view-conversion-buffer
+                               doc-view-ghostscript-program)
+                         doc-view-ghostscript-options
+                         (list (format "-r%d" (round doc-view-resolution)))
+                         (list (concat "-sOutputFile=" png))
+                         (list pdf-ps))))
        mode-line-process (list (format ":%s" doc-view-current-converter-process)))
   (process-put doc-view-current-converter-process
               'buffer (current-buffer))
@@ -705,13 +707,23 @@ ARGS is a list of image descriptors."
   (when doc-view-pending-cache-flush
     (clear-image-cache)
     (setq doc-view-pending-cache-flush nil))
-  (let ((image (apply 'create-image file 'png nil args)))
-    (setq doc-view-current-image image)
-    (move-overlay doc-view-current-overlay (point-min) (point-max))
-    (overlay-put doc-view-current-overlay 'display
-                 (if doc-view-current-slice
-                     (list (cons 'slice doc-view-current-slice) image)
-                   image))))
+  (if (null file)
+      ;; We're trying to display a page that doesn't exist.  Typically happens
+      ;; if the conversion process somehow failed.  Better not signal an
+      ;; error here because it could prevent a subsequent reconversion from
+      ;; fixing the problem.
+      (progn
+        (setq doc-view-current-image nil)
+        (move-overlay doc-view-current-overlay (point-min) (point-max))
+        (overlay-put doc-view-current-overlay 'display
+                     "Cannot display this page!  Probably a conversion failure!"))
+    (let ((image (apply 'create-image file 'png nil args)))
+      (setq doc-view-current-image image)
+      (move-overlay doc-view-current-overlay (point-min) (point-max))
+      (overlay-put doc-view-current-overlay 'display
+                   (if doc-view-current-slice
+                       (list (cons 'slice doc-view-current-slice) image)
+                     image)))))
 
 (defun doc-view-sort (a b)
   "Return non-nil if A should be sorted before B.
@@ -952,9 +964,12 @@ toggle between displaying the document or editing it as text."
          (file-name-nondirectory
           (file-name-sans-extension buffer-file-name))
          doc-view-cache-directory))
-       ((or
-         (not (file-exists-p buffer-file-name))
-         (file-remote-p buffer-file-name))
+        ;; Is the file readable by local processes?
+        ;; We used to use `file-remote-p' but it's unclear what it's
+        ;; supposed to return nil for things like local files accessed via
+        ;; `su' or via file://...
+       ((let ((file-name-handler-alist nil))
+           (not (file-readable-p buffer-file-name)))
         (expand-file-name
          (file-name-nondirectory buffer-file-name)
          doc-view-cache-directory))