Bug 2458 - System.Diagnostics.Process Spaces removed in path to executable
Summary: System.Diagnostics.Process Spaces removed in path to executable
Status: NEW
Alias: None
Product: Class Libraries
Classification: Mono
Component: System (show other bugs)
Version: 2.10.x
Hardware: PC Linux
: --- normal
Target Milestone: Untriaged
Assignee: Bugzilla
URL:
Depends on:
Blocks:
 
Reported: 2011-12-12 06:00 UTC by mark w
Modified: 2011-12-12 11:05 UTC (History)
1 user (show)

See Also:
Tags:
Is this bug a regression?: ---
Last known good build:


Attachments

Description mark w 2011-12-12 06:00:44 UTC
I attempted to upgrade one of our systems from mono-2.6.1 to mono-2.10.2. This system constructs a command-line, escapes appropriate characters and instantiates a process using System.Diagnostics.Process. It has been running for over two years. What we discovered after the update was that if the path on the command-line contained spaces (and was correctly escaped) they were removed and thus the process would not be able to find the file. For example: -

given the path /tmp/hello\ world/a.txt the process would report that it had been passed /tmp/helloworld/a.txt

Thanks
Mark
Comment 1 Mikayla Hutchinson [MSFT] 2011-12-12 11:05:15 UTC
This is most likely because we switched from using glib to our own implementation, eglib. glib had more advanced handling of quoted values but was not actually compatible with MS.NET's Process.Start handling.

I would recommend using double quotes and escaped double quotes, since that's the only escaping that's compatible with MS.NET's Process.Start.

Alternatively you might be able to build Mono against glib.

Note You need to log in before you can comment on or make changes to this bug.