-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Auto-package windows binaries on build (and fix a few bugs and warnings) #1391
Auto-package windows binaries on build (and fix a few bugs and warnings) #1391
Conversation
@dmaltsiniotis what are the remaining issues with this? It seems like it's working? |
Hi @martinling, Thanks for reminding me on this PR. The last issue that I ran into with this PR is that there is a discrepancy between running CMAKE locally on Windows, vs running CMAKE on the Windows build agents in GitHub. The difference is that when I run the CMAKE install locally, the 3rd party dependencies installed by vcpkg install (libusb, pthreads, fftw) are copied over into the install directory. However when cmake install runs in GitHub, the three libraries are NOT copied over to the install directory, resulting in an incomplete zip package. I have not been successful in coaxing CMAKE to force copy the DLLs over every time, but my knowledge if CMAKE is rather rudimentary. That is the last remaining issue, otherwise the builds and the new packaging step all run successfully. |
Thanks for clarifying! What an annoying little problem to be left with. I've had some success at using action-tmate to get a shell on the GitHub CI runners and debug things interactively that way, might be worth trying here. But sometimes the result is just "it behaves differently on the runner and I can't tell why!". |
@dmaltsiniotis I've just had a go at building the
I get the same result you see: everything is built correctly but the external DLL dependencies aren't copied to the |
aef2a05
to
0fcc86c
Compare
@martinling, I think I've finally addressed the missing dll mystery. This PR is ready to review now. I haven't found the exact cause of why it doesn't work specifically on the build server, but the issue is that the vcpkg makefile is not being found/invoked on the build server, but it is on my local instance (environment variable difference?). The solution was to force/hint CMAKE to find it by specifying the vcpkg msbuild makefile as an additional tool-chain via command line parameter. Alternatively, we could include the vcpkg cmake file as part of an |
…p hackrf-tools. * Add artifact publish step for Windows libraries and host tools. * Replace runner.workspace with github.workspace. * Update checkout task to v4 to supress warning. * Update CMAKE for libhackrf and hackrf-tools to also install DLLs on WIN32 platforms. * Update uploadartifact task to v4 since v3 uses an end-of-life node version 16. * Add a new windows variable for the vcpkg cmake toolchain makefile.
0fcc86c
to
3d83a2f
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great!
I agree with specifying the CMAKE_TOOLCHAIN_FILE
on the command line in the CI script, since it's specific to where that file is installed on the build server. I wouldn't want to hardcode that in the CMakeLists.txt
.
At some point I would like to see the package-finding code in our CMake setup get smart enough to find the vcpkg-installed dependencies without having to give all the paths explicitly, but that's out of the scope of this PR.
Thanks for all your work on this, it's very much appreciated.
Fixes #1286 |
Thank you very much for the contribution! |
This PR adds a new windows build package artifact to each build, and also addresses a number of windows-related build issues.
The primary change with this pull request is the addition of a new artifact on build called
hackrf-tools-windows.zip
. This artifact contains the combination of the windows libhackrf build and hackrf-tools build together. The intent of this artifact is to provide a convenient way for Windows users who prefer to download pre-built Windows binaries to do so from an official source. This is the first step in a longer-term vision to be able to auto-package the HackRF One libraries and tools around a more comprehensive installer.Specific changes in this pull request are:
checkout
anduploadartifact
tasks to v4 to suppress warnings since v3 uses an end-of-life node version 16.Comments and criticisms are welcome.