Opened 5 years ago
Closed 4 years ago
#1727 closed defect (fixed)
chicken-install srfi-18 fails on Windows
| Reported by: | Josh Helzer | Owned by: | |
|---|---|---|---|
| Priority: | major | Milestone: | 5.3 |
| Component: | unknown | Version: | 5.2.0 |
| Keywords: | Cc: | ||
| Estimated difficulty: |
Description
The culprit appears to be improper path escaping:
C:\>chicken-install srfi-18
building srfi-18
C:\Users\j\AppData\Local\chicken-install\srfi-18\build-srfi-18.bat -host -D compiling-extension -J -s -regenerate-import-libraries -setup-mode -I C:\Users\j\AppData\Local\chicken-install\srfi-18 -C -IC:\Users\j\AppData\Local\chicken-install\srfi-18 -O2 -d1 srfi-18.scm -o C:\Users\j\AppData\Local\chicken-install\srfi-18\srfi-18.so
'""C:' is not recognized as an internal or external command,
operable program or batch file.
1 file(s) copied.
'""C:' is not recognized as an internal or external command,
operable program or batch file.
Error: shell command terminated with nonzero exit code
1
"C:\\Users\\j\\AppData\\Local\\chicken-install\\srfi-18\\srfi-18.build.bat"
C:\>
Attachments (1)
Change History (10)
comment:1 Changed 5 years ago by
comment:2 Changed 5 years ago by
Hey, I've also had this problem with some eggs in the past on Windows. I've been able to get around it when it pops up by removing some extra quotes in the build-*.bat files.
The problem seems to be that %CHICKEN_CSC% and %CHICKEN_CSI% are already quoted, but some of the batch files themselves quote the variable, causing doubled quotes that Windows cannot handle.
I believe that this should be all of the affected eggs:
; In
$ grep --include=*.bat -rw . -e '"%CHICKEN_CSC%"' -e '"%CHICKEN_CSI%"' | awk -F "/" '{ print $2 }'
; Out
breadline
imlib2
openssl
socket
srfi-18
taglib
comment:3 Changed 5 years ago by
I've looked into this today and discovered that we might need to do a breaking change. Windows handles quoting differently when applied to environment variables:
C:\Users\me> set JAVA="C:\path\to\java" C:\Users\me> echo %JAVA% "C:\path\to\java" C:\Users\me> echo "%JAVA%" ""C:\path\to\java"" C:\Users\me> %JAVA% -version openjdk version "11.0.8" 2020-07-14 [...] C:\Users\me> "%JAVA%" -version '""C:' is not recognized as an internal or external command, operable program or batch file.
In fact, quotes aren't permitted in paths. If I inspect the environment variables on my Windows machine, it may look like this:
PSModulePath=C:\Program Files\WindowsPowerShell\Modules;[...]
Which is not what egg-compile.scm does:
(printf #<<EOF
@echo off~%
set PATH=~a;%PATH%
set CHICKEN_CC=~a
set CHICKEN_CXX=~a
set CHICKEN_CSC=~a
set CHICKEN_CSI=~a
EOF
(qs* default-bindir platform) (qs* default-cc platform)
(qs* default-cxx platform) (qs* default-csc platform)
(qs* default-csi platform))
default-bindir should not be quoted at all. According to https://ss64.com/nt/set.html, the set command should instead quote its entire argument, including the name. The above session again, but with correct quoting:
C:\Users\me> set "JAVA=C:\path\to\java" C:\Users\me> echo %JAVA% C:\path\to\java C:\Users\me> echo "%JAVA%" "C:\path\to\java" C:\Users\me> %JAVA% -version '""C:' is not recognized as an internal or external command, operable program or batch file. C:\Users\me> "%JAVA%" -version openjdk version "11.0.8" 2020-07-14 [...]
I believe that to be the correct behavior and am willing to write a patch to implement it. However it will require every single egg installable on Windows (I've found nine with a .bat file) to use quoting for the CHICKEN_CSC, CHICKEN_CSI, CHICKEN_CC and CHICKEN_CXX variables, otherwise the scripts will break on every installation that contains spaces in its installation path. On the upside, this would relieve me from fixing the above six scripts, five of which I'm directly responsible for :)
Changed 5 years ago by
| Attachment: | 0001-Correctly-quote-set-calls-in-Windows-scripts.patch added |
|---|
comment:4 Changed 5 years ago by
Here's an untested patch that should resolve the reported problem. If it's accepted, I'll look into adjusting the three remaining eggs to quote CHICKEN_CSC and CHICKEN_CSI.
comment:5 Changed 5 years ago by
I've tested the patch successfully using "PREFIX=C:/chicken 5.2.0" for my new installation. Both the srfi-18 and taglib egg (socket egg flaked out due to WINAPI nonsense) have been installed successfully using it. As mentioned earlier, I'd submit patches to the sendfile, kiwi and bind eggs.
comment:6 Changed 5 years ago by
| Milestone: | someday → 5.4 |
|---|
comment:7 Changed 5 years ago by
| Milestone: | 5.4 → 5.3 |
|---|
comment:8 Changed 4 years ago by
I've tested it now with Cygwin in addition to my previous test with mingw64-msys2, seems like Cygwin isn't affected by the patch at all. So that's one less thing to worry about.
comment:9 Changed 4 years ago by
| Resolution: | → fixed |
|---|---|
| Status: | new → closed |
This should be fixed by 278c2477.

Hi there! I think this isn't a SRFI-18 specific problem, but rather a
chicken-installproblem.It looks like you might have missed the CHICKEN build instructions from the
READMEfile:- When installing under mingw, with a windows shell ("cmd.exe"), pass an absolute pathname (including the drive letter) as PREFIX and use forward slashes. If you are building the sources from git, use backslashes to specify the path to `chicken' (the "CHICKEN" variable).Note that this requires you to use forward slashes, probably because of this issue. Of course, if you can fix CHICKEN and
chicken-installspecifically to make it work with backslashes that would be great too.