changeset 100039:d13d583ff5cc

(nnimap-demule-use-string-to-multibyte): New temporary variable for debugging bug#464 and bug#1174. (nnimap-demule): Use it.
author Reiner Steib <Reiner.Steib@gmx.de>
date Sat, 29 Nov 2008 15:26:49 +0000
parents a368e04ccb9a
children 60d9e250ee84
files lisp/gnus/ChangeLog lisp/gnus/nnimap.el
diffstat 2 files changed, 29 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/gnus/ChangeLog	Sat Nov 29 13:47:31 2008 +0000
+++ b/lisp/gnus/ChangeLog	Sat Nov 29 15:26:49 2008 +0000
@@ -1,3 +1,9 @@
+2008-11-29  Reiner Steib  <Reiner.Steib@gmx.de>
+
+	* nnimap.el (nnimap-demule-use-string-to-multibyte): New temporary
+	variable for debugging bug#464 and bug#1174.
+	(nnimap-demule): Use it.
+
 2008-11-21  Stefan Monnier  <monnier@iro.umontreal.ca>
 
 	* message.el (message-send-mail): Just set the buffer to unibyte
--- a/lisp/gnus/nnimap.el	Sat Nov 29 13:47:31 2008 +0000
+++ b/lisp/gnus/nnimap.el	Sat Nov 29 15:26:49 2008 +0000
@@ -901,12 +901,35 @@
   (when (nnimap-possibly-change-server server)
     (nnoo-status-message 'nnimap server)))
 
+(defvar nnimap-demule-use-string-to-multibyte (fboundp 'string-to-multibyte)
+  "Temporary internal debug variable.
+If you have problems (UTF-8 not decoded correctly on IMAP) with
+the default value, please report it as a bug!")
+;; FIXME: Clarify if we need to make this variable conditional on the Emacs
+;; version (Emacs 22 vs. Emacs 23;Emacs 21 doesn't have `string-to-multibyte'
+;; anyhow).  --rsteib
+;;
+;; http://thread.gmane.org/gmane.emacs.gnus.general/67112
+;; (bug#464, reported by James Cloos)
+;; http://thread.gmane.org/gmane.emacs.bugs/21524
+;; (bug#1174, reported by Frank Schmitt)
+
 (defun nnimap-demule (string)
   ;; BEWARE: we used to use string-as-multibyte here which is braindead
   ;; because it will turn accidental emacs-mule-valid byte sequences
   ;; into multibyte chars.  --Stef
   ;; Reverted, braindead got 7.5 out of 10 on imdb, so it can't be
   ;; that bad. --Simon
+  (gnus-message 9 "nnimap-demule-use-string-to-multibyte: %s"
+		nnimap-demule-use-string-to-multibyte)
+  (if nnimap-demule-use-string-to-multibyte
+      ;; Stefan
+      (funcall (if (and (fboundp 'string-to-multibyte)
+			(subrp (symbol-function 'string-to-multibyte)))
+		   'string-to-multibyte
+		 'identity)
+	       (or string "")))
+  ;; Simon
   (funcall (if (and (fboundp 'string-as-multibyte)
 		    (subrp (symbol-function 'string-as-multibyte)))
 	       'string-as-multibyte