-
Notifications
You must be signed in to change notification settings - Fork 717
Description
Prerequisites
Please put an X between the brackets as you perform the following steps:
- Check that your issue is not already filed:
https://github.com/leanprover/lean4/issues - Reduce the issue to a minimal, self-contained, reproducible test case.
Avoid dependencies to Mathlib or Batteries. - Test your test case against the latest nightly release, for example on
https://live.lean-lang.org/#project=lean-nightly
(You can also use the settings there to switch to “Lean nightly”)
Description
IO.Process.spawn inserts additional unnecessary quotes, leading to problems trying to execute e.g. cmd.exe /c echo hi because the current quoting turns it into "cmd.exe" "/c" "echo" "hi", producing an error unknown command ""echo"". Avoiding unnecessary quoting should solve this issue.
Context
This came up while trying to write a test for #8534. The "solution" I used highlights another problem which is that the command string is not correctly quoted.
Steps to Reproduce
#eval return (← IO.Process.output { cmd := "cmd.exe", args := #["/c", "echo", "hi"] }).stderr
Expected behavior: The process should run successfully and produce no stderr. The output should be: "hi\r\n".
Actual behavior: The process produces an error message along the lines of unknown command ""echo"".
Versions
Lean 4.21.0-nightly-2025-05-30
Impact
Add 👍 to issues you consider important. If others are impacted by this issue, please ask them to add 👍 to it.