bug-gnu-emacs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#7711: Patch for bug #7687


From: Flo
Subject: bug#7711: Patch for bug #7687
Date: Wed, 22 Dec 2010 20:00:51 +0100

What problem is solved by this patch
===========================================

GNU bug report #7687
23.1.50; shell-quote-argument does not correctly quote newlines

A copy of that bug report is at the end of this Email


Why does the patch solve the probem
===================================

Before shell-quote-argument quoted everything except POSIX
filename characters with a leading backslash. The result of
shell-quote-argument was that a new line in the input was
'quoted' with a backslash. A backslashed followed by a
newline however means line continuation to POSIX shells. It
is discarded by the shell. So the result after the shell was
the empty string. The new version of shell-quote-argument
treats newlines specially. They are quoted with single
quotes.


Same information again put differently:

old version:

input to shell-quote-argument: a newline

output of shell-quote-argument = input to the shell:
backslash followed by a newline

result of shell's quoting mechanism: the emtpy string (due
to line continuation)


new version:

input to shell-quote-argument: a newline

output of shell-quote-argument = input to the shell: newline
in single quotes

result of shell's quoting mechanism: a newline



Change Log
===========
subr.el does not yet have a change log, so I put it here

shell-quote-argument now correctly quotes newlines for POSIX
shells


Effect on other systems
========================

shell-quote-argument already distinguishes between different
system types using system-type. I only changed the part that
is concerned about POSIX shells.



diff: old version (23.1.50) first, new version second
=====================================================

$ gunzip /usr/share/emacs/23.1.50/lisp/subr.el.gz -c | diff -c -
/home/emp8118035/.emacs.d/patches/subr.el
*** STDIN Wed Dec 22 19:27:58 2010
--- /home/emp8118035/.emacs.d/patches/subr.el Mon Dec 20 17:28:30 2010
***************
*** 2391,2403 ****
        (concat "\"" result (substring argument start) "\""))
      (if (equal argument "")
          "''"
!       ;; Quote everything except POSIX filename characters.
!       ;; This should be safe enough even for really weird shells.
!       (let ((result "") (start 0) end)
          (while (string-match "[^-0-9a-zA-Z_./]" argument start)
            (setq end (match-beginning 0)
                  result (concat result (substring argument start end)
!                                "\\" (substring argument end (1+ end)))
                  start (1+ end)))
          (concat result (substring argument start))))))

--- 2391,2407 ----
        (concat "\"" result (substring argument start) "\""))
      (if (equal argument "")
          "''"
!       ;; Quote everything except POSIX filename characters. This
should be safe
!       ;; enough even for really weird shells. Quoting is done with backslash,
!       ;; except for newlines, which are quoted with single quotes; a
!       ;; backslash-newline sequence is interpreted as line-continuation by the
!       ;; shell and thus effectivly being ignored.
!       (let ((result "") (start 0) end ch)
          (while (string-match "[^-0-9a-zA-Z_./]" argument start)
            (setq end (match-beginning 0)
+                 ch (substring argument end (1+ end))
                  result (concat result (substring argument start end)
!                                (if (string= ch "\n") "'\n'" (concat "\\" ch)))
                  start (1+ end)))
          (concat result (substring argument start))))))




Copy of the bug report
===========================================

GNU bug report logs - #7687
23.1.50; shell-quote-argument does not correctly quote newlines


Please write in English if possible, because the Emacs maintainers
usually do not have translators to read other languages for them.

Your bug report will be posted to the emacs-pretest-bug <at> gnu.org
mailing list.

Please describe exactly what actions triggered the bug
and the precise symptoms of the bug:

When I run the following script:

----------------------------------
#!/bin/bash
emacs -Q --batch eval='(shell-command (concat "echo "
(shell-quote-argument "line1\nline2") " >tmpfile"))'
cat tmpfile
----------------------------------

I expect the following content within 'tmpfile', i.e. exactly the
string I passed to shell-quote-argument.

-------------
line1
line2
-------------

Instead I get this:

-------------
line1line2
-------------


I have not made any modification to Emacs.

I made a patch and will send it as described in the Emacs manual in
chapter 'Sending Patches for GNU Emacs'.


If Emacs crashed, and you have the Emacs process in the gdb debugger,
please include the output from the following gdb commands:
    `bt full' and `xbacktrace'.
If you would like to further debug the crash, please read the file
/usr/share/emacs/23.1.50/etc/DEBUG for instructions.


In GNU Emacs 23.1.50.1 (i486-pc-linux-gnu, GTK+ Version 2.18.0)
 of 2009-09-27 on palmer, modified by Debian
 (emacs-snapshot package, version 1:20090909-1)
Windowing system distributor `The X.Org Foundation', version 11.0.10706000
configured using `configure  '--build' 'i486-linux-gnu' '--host'
'i486-linux-gnu' '--prefix=/usr' '--sharedstatedir=/var/lib'
'--libexecdir=/usr/lib' '--localstatedir=/var'
'--infodir=/usr/share/info' '--mandir=/usr/share/man' '--with-pop=yes'
'--enable-locallisppath=/etc/emacs-snapshot:/etc/emacs:/usr/local/share/emacs/23.1.50/site-lisp:/usr/local/share/emacs/site-lisp:/usr/share/emacs/23.1.50/site-lisp:/usr/share/emacs/site-lisp'
'--with-x=yes' '--with-x-toolkit=gtk' 'build_alias=i486-linux-gnu'
'host_alias=i486-linux-gnu' 'CFLAGS=-DDEBIAN
-DSITELOAD_PURESIZE_EXTRA=5000 -g -O2' 'LDFLAGS=-g -Wl,--as-needed'
'CPPFLAGS=''

Important settings:
  value of $LC_ALL: nil
  value of $LC_COLLATE: nil
  value of $LC_CTYPE: nil
  value of $LC_MESSAGES: nil
  value of $LC_MONETARY: nil
  value of $LC_NUMERIC: nil
  value of $LC_TIME: nil
  value of $LANG: en_US.utf8
  value of $XMODIFIERS: nil
  locale-coding-system: utf-8-unix
  default enable-multibyte-characters: t

Major mode: Info

Minor modes in effect:
  tooltip-mode: t
  tool-bar-mode: t
  mouse-wheel-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  global-auto-composition-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t
  transient-mark-mode: t

Recent input:
M-x b u g - r e p o <tab> C-g C-h i C-h r C-s b u g
C-s <return> <return> 2 C-v SPC M-x r e p o r t - e
m a c s - b u <tab> <return>

Recent messages:
uncompressing emacs-6.gz...done
uncompressing emacs-7.gz...done
uncompressing emacs-8.gz...done
Mark saved where search started
uncompressing emacs.gz...done
uncompressing emacs-6.gz...done
uncompressing emacs.gz...done
uncompressing emacs-6.gz...done
uncompressing emacs.gz...done
uncompressing emacs-6.gz...done

Load-path shadows:
/usr/share/emacs/23.1.50/site-lisp/debian-startup hides
/usr/share/emacs/site-lisp/debian-startup
/usr/share/emacs/site-lisp/rst hides /usr/share/emacs/23.1.50/lisp/textmodes/rst





reply via email to

[Prev in Thread] Current Thread [Next in Thread]