Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Windows build fails #37

Open
Frank-Buss opened this issue Dec 15, 2021 · 6 comments
Open

Windows build fails #37

Frank-Buss opened this issue Dec 15, 2021 · 6 comments

Comments

@Frank-Buss
Copy link

When I try to compile it on Windows, I get the following error:

   Compiling serde_urlencoded v0.6.1
   Compiling toml v0.5.8
The following warnings were emitted during compilation:

warning: march=native is enabled, this build is non-portable
warning: cl : Befehlszeile error D8021 : Ung�ltiges numerisches Argument /Wno-implicit-function-declaration.

error: failed to run custom build command for `packetcrypt-sys v0.4.0 (W:\projects\pkt.cash\packetcrypt_rs\packetcrypt-sys)`

Caused by:
  process didn't exit successfully: `W:\projects\pkt.cash\packetcrypt_rs\target\release\build\packetcrypt-sys-a62cb9e478073187\build-script-build` (exit code: 1)
  --- stderr


  error occurred: Command "C:\\Program Files\\Microsoft Visual Studio\\2022\\Community\\VC\\Tools\\MSVC\\14.30.30705\\bin\\HostX64\\x64\\cl.exe" "-nologo" "-MD" "-O2" "-Brepro" "-I" "W:\\projects\\pkt.cash\\packetcrypt_rs\\target\\release\\build\\libsodium-sys-df89fd4f4518355c\\out\\source\\libsodium\\src\\libsodium\\include" "-I" "packetcrypt/include" "-I" "packetcrypt/src" "-W4" "-Wno-implicit-function-declaration" "-O2" "-FoW:\\projects\\pkt.cash\\packetcrypt_rs\\target\\release\\build\\packetcrypt-sys-e959eb6f756871c5\\out\\lib\\packetcrypt/src/Validate.o" "-c" "packetcrypt/src/Validate.c" with args "cl.exe" did not execute successfully (status code exit code: 2).


warning: build failed, waiting for other jobs to finish...
error: build failed

Tested with Visual Studio Community 2019 and 2022.

@Frank-Buss
Copy link
Author

One problem with Visual Studio is this line:

.flag("-Wno-implicit-function-declaration")

Another problem might be this line:
.flag("-Wno-implicit-function-declaration")

but it still uses "-O2" from somewhere when deleted.

But I managed to cross-compile it from Linux now. Prerequisite (on Debian) : apt install mingw-w64. Then install the Rust cross compilation tool, as described here:
https://rust-lang.github.io/rustup/cross-compilation.html
and finally you can build it for Windows on Linux like this:

cargo build --target x86_64-pc-windows-gnu --release

@alexandervenezia
Copy link

alexandervenezia commented Dec 18, 2021

I was able to successfully compile the repo on my Windows system by switching to the GNU toolchain for rustup, which would second that the problem is with an interaction with MSVC. Anyone having issues might want to try these commands:

rustup toolchain install stable-x86_64-pc-windows-gnu
rustup set default-host x86_64-pc-windows-gnu

Before attempting to compile as normal. Obviously, it would be ideal if this were not necessary and the default MSVC toolchain could be used, but it may be a functional workaround.

@cjdelisle
Copy link
Owner

The problem here is that there is C code in packetcrypt_rs and when we're on windows it's trying to use cl.exe to compile it. The language which cl.exe compiles is "not really C", it's Microsoft's flavor of C++, projects which support cl.exe are lined with ifdef _MSC_VER to adjust to this compiler's dialect, something which I would ideally like to keep out of this codebase.

However, new versions of microsoft visual studio do ship with the option of using the clang compiler, but last time I checked, the rust package cc, which manages the compiling, was not capable of finding the clang executable in order to use it.

@Frank-Buss
Copy link
Author

The bug has nothing to do with how MSVC implements the C++ standard, but with wrong compiler options. And MSVC is pretty standard conform last time I checked, I don't expect many MSC_VER tests. Except for the Microsoft declspec mess for using DLLs, but this is just one place and a few defines for exported/imported functions, in case a DLL is used at all and it is not linked statically.

@cjdelisle
Copy link
Owner

Oh, interesting. I don't have a windows computer handy but if you can get it building with the right flags then we should be able to put it on github actions so that we're sure it doesn't break in the future. The build flags are in build.rs inside of packetcrypt-sys

@Frank-Buss
Copy link
Author

I don't know if github actions support Visual Studio. But I managed to compile it now on a clean Windows 10 installation. Needs only msys2, probably this could be used with github actions. Here are the steps:
#39 (comment)
I tested it in a Oracle Virtual Box VM, so should be possible for you to reproduce this (a Windows 10 Pro licence key on eBay costs about $20, and the ISO is officially available from the Microsoft webpage), and then add the instructions to the readme. Or maybe better a separate build-readme for Windows, because most people might just download the binary release.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants