This is the mail archive of the
cygwin
mailing list for the Cygwin project.
RE: Command line processing in dcrt0.cc does not match Microsoft parsing rules
- From: "Stephen Provine via cygwin" <cygwin at cygwin dot com>
- To: "cygwin at cygwin dot com" <cygwin at cygwin dot com>
- Date: Thu, 5 Sep 2019 23:45:44 +0000
- Subject: RE: Command line processing in dcrt0.cc does not match Microsoft parsing rules
- Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=microsoft.com; dmarc=pass action=none header.from=microsoft.com; dkim=pass header.d=microsoft.com; arc=none
- Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=EqNj0WYSOM1w6V6rig/xKUm2Xc0gM+xHPcBw0wpmZ60=; b=WnzsID5upW2z7i8l/lGO3huY2Dkb87AfphaqLbQZ+ZkhBDbBSndUUwFw3X/FYQrZ1HCwchpSU5TPuCRhSsBLQMgws6z7t7rqGR++w+76/oZmr9m49ts6FvZhB38uHGEdH7Axq3zw3rD8DAhveu3oUNXEWDTnkZI0KX2YPEEMIKgzMY2JFQy1MvVtJ7BLzdLuDvJRqci29ccKtsvjw/eTYY5FQyF+xgDlMXALRBKOCYrWdfgcUDPdgsvf63/r2NTqqhSUSQBanu1I4VEOSMs6t7HU8kRmIPRDdpZNuI6usaW72qgZa4hlfTL1GQLtwONQRTQLu2YSUAemKf2gp8DwCg==
- Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=RRMQoFUjcJavpYFbEC8vmsRUZy4+zSIsFGL1SOBxO/piKvnym3w6NKW/iw94QNRQ3qtXB6+EpNlel0xHYhAMAA1JAO0XCwH2Qj7dGMeDoR+znS7txIImxZeDXA/4UEB3BwGbIpytcNCGKTWXYBuZ5Ivs2jGwJ/0wUci/Nmld+VRbbGsBnXeIG7pxHskZkSGF7XFmpMm3x11WqHFUGosbPpJWXqS4AtRhZPQaooZbI5FE6+s5dRL1WnAEaF+ZUT+3B0ayAFahzInUupYEbaXLydQ67BPtpFDXkEIk1AnWHqmtzIEtA/S2Sw65F6NfgwJm2V9eOzKvwjmNBMKsDPm2iQ==
- References: <MWHPR21MB08452919F35B1B0C5F0EB4DCB9BD0@MWHPR21MB0845.namprd21.prod.outlook.com> <MWHPR21MB0845F78385792965A94E0CD9B9BD0@MWHPR21MB0845.namprd21.prod.outlook.com> <MWHPR21MB084508155AB621C7AD81309CB9B90@MWHPR21MB0845.namprd21.prod.outlook.com> <MWHPR21MB08456D9F03AF8BD450E6AB2EB9B80@MWHPR21MB0845.namprd21.prod.outlook.com> <MWHPR21MB0845282E7582DC95ADF0F140B9BB0@MWHPR21MB0845.namprd21.prod.outlook.com> <MWHPR21MB084583452E7C41D0792C739EB9BB0@MWHPR21MB0845.namprd21.prod.outlook.com>
- Reply-to: Stephen Provine <stephpr at microsoft dot com>
On 9/5/19 5:46 PM, Eric Blake wrote:
> If you start a cygwin process from Windows, then cygwin1.dll is given
> only a single string, which it must parse into argv according to windows
> conventions (if it does not produce the same argv[] as a windows process
> using CommandLineToArgvW, then that's a bug in cygwin1.dll). But on top
> of that, if you are using cmd.exe to generate your command line, then
> you must use proper escaping, otherwise, cmd.exe can produce a command
> line that has unexpected quoting in the string handed to
> CommandLineToArgvW, and the Windows parsing when there are unbalanced
> quotes can be screwy
Great explanation, it's very helpful.
I've been using cmd.exe to generate the command line for my tests, but the
original problem was when my compiled Go binary directly executes another
Windows process using the Win32 APIs like CreateProcess directly. Here's a
simple Go program that reproduces the issue:
package main
import (
"log"
"os"
"os/exec"
)
func main() {
cmd := exec.Command("C:\\cygwin64\\bin\\bash.exe", "test.sh", "foo", "bar\"baz", "bat")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
if err := cmd.Run(); err != nil {
log.Fatal(err)
}
}
The output of this process is:
foo
bar\baz bat
To prove it is not going through cmd.exe, I debugged the Go program
to the point that it calls the Win32 CreateProcess function, and the
first two arguments are:
lpApplicationName: "C:\\cygwin64\\bin\\bash.exe"
lpCommandLine: "C:\\cygwin64\\bin\\bash.exe test.sh foo bar\\\"baz bat"
So unless I'm missing something, bash.exe is not interpreting the command line
following the rules pointed to by the documentation for CommandLineToArgvW.
Thanks,
Stephen
--
Problem reports: http://cygwin.com/problems.html
FAQ: http://cygwin.com/faq/
Documentation: http://cygwin.com/docs.html
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple