In article <[EMAIL PROTECTED]>, Katsumi Yamaoka <[EMAIL PROTECTED]> writes:

>>>>>> In <[EMAIL PROTECTED]> Kenichi Handa wrote:
> > In article <[EMAIL PROTECTED]>, Chris Moore <[EMAIL PROTECTED]> writes:

>>> Stefan Monnier <[EMAIL PROTECTED]> writes:
>>>>> Which function is it?
>>>> 
>>>> I believe the function "at fault" is uudecode-decode-region

>>> Yes, it's uudecode-decode-region.

> > Ok, I've just installed a fix to make it work on a multibyte
> > buffer.

> I'm sorry for the late response but I noticed that uudecode.el
> bundled with Gnus now doesn't work with Emacs 21 and XEmacs
> because of `string-to-multibyte'.

Ah! :-(

> Since Gnus still supports
> those versions of Emacsen, we have the emulating function for it
> in mm-util.el as follows:

> --8<---------------cut here---------------start------------->8---
> (defalias 'mm-string-to-multibyte
>   (cond
>    ((featurep 'xemacs)
>     'identity)
>    ((fboundp 'string-to-multibyte)
>     'string-to-multibyte)
>    (t
>     (lambda (string)
>       "Return a multibyte string with the same individual chars as string."
>       (mapconcat
>        (lambda (ch) (mm-string-as-multibyte (char-to-string ch)))
>        string "")))))
> --8<---------------cut here---------------end--------------->8---

> Is it possible to add a similar one to uudecode.el?  I've tested
> the attached patch with Gnus v5.10.8 (aka v5.11).

Yes.  Please install your change.

---
Kenichi Handa
[EMAIL PROTECTED]

> --8<---------------cut here---------------start------------->8---
> *** uudecode.el~      Sun Jan 21 21:53:53 2007
> --- uudecode.el       Wed Jan 24 08:15:57 2007
> ***************
> *** 128,133 ****
> --- 128,147 ----
>         (message "Can not uudecode")))
>         (ignore-errors (or file-name (delete-file tempfile))))))
  
> + (eval-and-compile
> +   (defalias 'uudecode-string-to-multibyte
> +     (cond
> +      ((featurep 'xemacs)
> +       'identity)
> +      ((fboundp 'string-to-multibyte)
> +       'string-to-multibyte)
> +      (t
> +       (lambda (string)
> +     "Return a multibyte string with the same individual chars as string."
> +     (mapconcat
> +      (lambda (ch) (string-as-multibyte (char-to-string ch)))
> +      string ""))))))
> + 
>   ;;;###autoload
>   (defun uudecode-decode-region-internal (start end &optional file-name)
>     "Uudecode region between START and END without using an external program.
> ***************
> *** 206,212 ****
>         (or (markerp end) (setq end (set-marker (make-marker) end)))
>         (goto-char start)
>         (if enable-multibyte-characters
> !           (mapc #'(lambda (x) (insert (string-to-multibyte x)))
>                   (nreverse result))
>           (insert (apply 'concat (nreverse result))))
>         (delete-region (point) end))))))
> --- 220,226 ----
>         (or (markerp end) (setq end (set-marker (make-marker) end)))
>         (goto-char start)
>         (if enable-multibyte-characters
> !           (mapc #'(lambda (x) (insert (uudecode-string-to-multibyte x)))
>                   (nreverse result))
>           (insert (apply 'concat (nreverse result))))
>         (delete-region (point) end))))))
> --8<---------------cut here---------------end--------------->8---



_______________________________________________
emacs-pretest-bug mailing list
[email protected]
http://lists.gnu.org/mailman/listinfo/emacs-pretest-bug

Reply via email to