unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error
@ 2014-07-10 12:26 Stephen Berman
  2014-07-28  9:10 ` Tassilo Horn
  0 siblings, 1 reply; 5+ messages in thread
From: Stephen Berman @ 2014-07-10 12:26 UTC (permalink / raw)
  To: 17985

If I'm using Gnus to read mail with an attachment, I can type `c' on the
attachment to view it in another buffer, and if the attachment is
something that Doc View can handle, I can type `C-c C-c' in the buffer
to view the rendered image of the attachment.  But if I then type `C-c
C-t' (doc-view-open-text) to view the ascii text of the attachment, I
get this error:

Debugger entered--Lisp error: (wrong-type-argument stringp nil)
  file-name-nondirectory(nil)
  doc-view-open-text()
  call-interactively(doc-view-open-text nil nil)
  command-execute(doc-view-open-text)

The reason is that Doc View expects the buffer to be visiting a file.
But with an mail attachment, that does not have to be the case (when I
type `C-c C-c', Doc View says: "The buffer has been modified.  Save the
changes? (y or n)", but if I answer "n", it still renders the image).
The following patch lets me view the ascii text whether or not the
buffer containing the document is visiting a file.  (The patch is
against emacs-24; the error also happens in trunk.)

Steve Berman

In GNU Emacs 24.3.92.7 (x86_64-suse-linux-gnu, GTK+ Version 3.10.4)
 of 2014-07-10 on rosalinde
Repository revision: 117368 monnier@iro.umontreal.ca-20140709185406-m0q0fjepl42pcrqx
Windowing system distributor `The X.Org Foundation', version 11.0.11403901
System Description:	openSUSE 13.1 (Bottle) (x86_64)

Configured using:
 `configure --without-toolkit-scroll-bars CFLAGS=-g3'

Important settings:
  value of $LANG: en_US.UTF-8
  value of $XMODIFIERS: @im=ibus
  locale-coding-system: utf-8-unix


=== modified file 'lisp/doc-view.el'
*** lisp/doc-view.el	2014-04-04 17:42:55 +0000
--- lisp/doc-view.el	2014-07-10 11:54:18 +0000
***************
*** 1402,1412 ****
    (interactive)
    (if doc-view--current-converter-processes
        (message "DocView: please wait till conversion finished.")
!     (let ((txt (expand-file-name "doc.txt" (doc-view--current-cache-dir))))
        (if (file-readable-p txt)
  	  (let ((name (concat "Text contents of "
! 			      (file-name-nondirectory buffer-file-name)))
! 		(dir (file-name-directory buffer-file-name)))
  	    (with-current-buffer (find-file txt)
  	      (rename-buffer name)
  	      (setq default-directory dir)))
--- 1402,1413 ----
    (interactive)
    (if doc-view--current-converter-processes
        (message "DocView: please wait till conversion finished.")
!     (let ((txt (expand-file-name "doc.txt" (doc-view--current-cache-dir)))
! 	  (bname (or buffer-file-name (buffer-name))))
        (if (file-readable-p txt)
  	  (let ((name (concat "Text contents of "
! 			      (file-name-nondirectory bname)))
! 		(dir (or (file-name-directory bname) default-directory)))
  	    (with-current-buffer (find-file txt)
  	      (rename-buffer name)
  	      (setq default-directory dir)))






^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error
  2014-07-10 12:26 bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error Stephen Berman
@ 2014-07-28  9:10 ` Tassilo Horn
  2014-07-28  9:21   ` Eli Zaretskii
  0 siblings, 1 reply; 5+ messages in thread
From: Tassilo Horn @ 2014-07-28  9:10 UTC (permalink / raw)
  To: Stephen Berman; +Cc: 17985-close

Stephen Berman <stephen.berman@gmx.net> writes:

> If I'm using Gnus to read mail with an attachment, I can type `c' on
> the attachment to view it in another buffer, and if the attachment is
> something that Doc View can handle, I can type `C-c C-c' in the buffer
> to view the rendered image of the attachment.  But if I then type `C-c
> C-t' (doc-view-open-text) to view the ascii text of the attachment, I
> get this error:
>
> Debugger entered--Lisp error: (wrong-type-argument stringp nil)
>   file-name-nondirectory(nil)
>   doc-view-open-text()
>   call-interactively(doc-view-open-text nil nil)
>   command-execute(doc-view-open-text)
>
> The reason is that Doc View expects the buffer to be visiting a file.
> But with an mail attachment, that does not have to be the case (when I
> type `C-c C-c', Doc View says: "The buffer has been modified.  Save the
> changes? (y or n)", but if I answer "n", it still renders the image).
> The following patch lets me view the ascii text whether or not the
> buffer containing the document is visiting a file.  (The patch is
> against emacs-24; the error also happens in trunk.)

Thanks, I've committed it on the trunk.  (As it's not a regression, I
don't think it should go in emacs-24.)

,----
| revno: 117599
| author: Stephen Berman  <stephen.berman@gmx.net>
| committer: Tassilo Horn <tsdh@gnu.org>
| branch nick: trunk
| timestamp: Mon 2014-07-28 11:07:56 +0200
| message:
|   Open doc text also if it's not saved to a file.
|   
|   * doc-view.el (doc-view-open-text): Don't require that the
|   document is saved in a file (e.g., email attachment).
`----

Bye,
Tassilo





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error
  2014-07-28  9:10 ` Tassilo Horn
@ 2014-07-28  9:21   ` Eli Zaretskii
  2014-07-28  9:33     ` Tassilo Horn
  0 siblings, 1 reply; 5+ messages in thread
From: Eli Zaretskii @ 2014-07-28  9:21 UTC (permalink / raw)
  To: Tassilo Horn; +Cc: stephen.berman, 17985, tsdh

> From: Tassilo Horn <tsdh@gnu.org>
> Date: Mon, 28 Jul 2014 11:10:06 +0200
> Cc: 17985-close@debbugs.gnu.org
> 
> Thanks, I've committed it on the trunk.  (As it's not a regression, I
> don't think it should go in emacs-24.)

IMO, as the bug is quite an annoyance, and the fix is so simple and
obviously correct, it should go to emacs-24.





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error
  2014-07-28  9:21   ` Eli Zaretskii
@ 2014-07-28  9:33     ` Tassilo Horn
  2014-07-28 10:07       ` Stephen Berman
  0 siblings, 1 reply; 5+ messages in thread
From: Tassilo Horn @ 2014-07-28  9:33 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: stephen.berman, 17985

Eli Zaretskii <eliz@gnu.org> writes:

>> Thanks, I've committed it on the trunk.  (As it's not a regression, I
>> don't think it should go in emacs-24.)
>
> IMO, as the bug is quite an annoyance, and the fix is so simple and
> obviously correct, it should go to emacs-24.

Ok, done.

Bye,
Tassilo





^ permalink raw reply	[flat|nested] 5+ messages in thread

* bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error
  2014-07-28  9:33     ` Tassilo Horn
@ 2014-07-28 10:07       ` Stephen Berman
  0 siblings, 0 replies; 5+ messages in thread
From: Stephen Berman @ 2014-07-28 10:07 UTC (permalink / raw)
  To: Tassilo Horn; +Cc: 17985

On Mon, 28 Jul 2014 11:33:32 +0200 Tassilo Horn <tsdh@gnu.org> wrote:

> Eli Zaretskii <eliz@gnu.org> writes:
>
>>> Thanks, I've committed it on the trunk.  (As it's not a regression, I
>>> don't think it should go in emacs-24.)
>>
>> IMO, as the bug is quite an annoyance, and the fix is so simple and
>> obviously correct, it should go to emacs-24.
>
> Ok, done.

Thanks.

Steve Berman





^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2014-07-28 10:07 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-07-10 12:26 bug#17985: 24.3.92; doc-view-open-text raises wrong-type-argument error Stephen Berman
2014-07-28  9:10 ` Tassilo Horn
2014-07-28  9:21   ` Eli Zaretskii
2014-07-28  9:33     ` Tassilo Horn
2014-07-28 10:07       ` Stephen Berman

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).