mirror of
https://github.com/greatscottgadgets/hackrf.git
synced 2026-03-03 05:55:18 +01:00
Merge pull request #1594 from martinling/pkg-config-windows
CMake: support use of pkgconf to find libraries on Windows
This commit is contained in:
13
.github/workflows/build.yml
vendored
13
.github/workflows/build.yml
vendored
@@ -9,10 +9,7 @@ on:
|
||||
- cron: 1 12 * * 1
|
||||
|
||||
env:
|
||||
WIN_LIBUSB_INC: -DLIBUSB_INCLUDE_DIR=C:/vcpkg/installed/x64-windows/include/libusb-1.0
|
||||
WIN_LIBUSB_LIB: -DLIBUSB_LIBRARIES=C:/vcpkg/installed/x64-windows/lib/libusb-1.0.lib
|
||||
WIN_FFTW_INC: -DFFTW3f_INCLUDE_DIRS=C:/vcpkg/installed/x64-windows/include
|
||||
WIN_FFTW_LIB: -DFFTW3f_LIBRARIES=C:/vcpkg/installed/x64-windows/lib/fftw3f.lib
|
||||
WIN_PKG_CONFIG: -DPKG_CONFIG_EXECUTABLE=C:/vcpkg/installed/x64-windows/tools/pkgconf/pkgconf.exe
|
||||
WIN_CMAKE_TOOLCHAIN: -DCMAKE_TOOLCHAIN_FILE=C:/vcpkg/scripts/buildsystems/vcpkg.cmake
|
||||
|
||||
# Override OSX architecture detection. Required for CMake versions < 3.19.2.
|
||||
@@ -54,7 +51,7 @@ jobs:
|
||||
if: matrix.os == 'ubuntu-latest'
|
||||
|
||||
- name: Install dependencies (Windows)
|
||||
run: vcpkg install --triplet=x64-windows libusb fftw3 pthreads
|
||||
run: vcpkg install --triplet=x64-windows libusb fftw3 pthreads pkgconf
|
||||
if: matrix.os == 'windows-latest'
|
||||
|
||||
# Build libhackrf and hackrf-tools together
|
||||
@@ -68,7 +65,7 @@ jobs:
|
||||
|
||||
- name: Configure CMake (Windows)
|
||||
working-directory: ${{github.workspace}}/host/build
|
||||
run: cmake $env:GITHUB_WORKSPACE/host/ $env:WIN_LIBUSB_INC $env:WIN_LIBUSB_LIB $env:WIN_FFTW_INC $env:WIN_FFTW_LIB $env:WIN_CMAKE_TOOLCHAIN
|
||||
run: cmake $env:GITHUB_WORKSPACE/host/ $env:WIN_PKG_CONFIG $env:WIN_CMAKE_TOOLCHAIN
|
||||
if: matrix.os == 'windows-latest'
|
||||
|
||||
- name: Build
|
||||
@@ -86,7 +83,7 @@ jobs:
|
||||
|
||||
- name: Configure CMake (libhackrf, Windows)
|
||||
working-directory: ${{github.workspace}}/host/libhackrf/build
|
||||
run: cmake $env:GITHUB_WORKSPACE/host/libhackrf/ $env:WIN_LIBUSB_INC $env:WIN_LIBUSB_LIB $env:WIN_CMAKE_TOOLCHAIN
|
||||
run: cmake $env:GITHUB_WORKSPACE/host/libhackrf/ $env:WIN_PKG_CONFIG $env:WIN_CMAKE_TOOLCHAIN
|
||||
if: matrix.os == 'windows-latest'
|
||||
|
||||
- name: Build (libhackrf)
|
||||
@@ -122,7 +119,7 @@ jobs:
|
||||
- name: Configure CMake (hackrf-tools, Windows)
|
||||
working-directory: ${{github.workspace}}/host/hackrf-tools/build
|
||||
run: |
|
||||
cmake $env:GITHUB_WORKSPACE/host/hackrf-tools/ $env:WIN_FFTW_INC $env:WIN_FFTW_LIB -DLIBHACKRF_INCLUDE_DIR="$env:GITHUB_WORKSPACE/install/include/libhackrf" -DLIBHACKRF_LIBRARIES="$env:GITHUB_WORKSPACE/install/bin/hackrf.lib" $env:WIN_CMAKE_TOOLCHAIN
|
||||
cmake $env:GITHUB_WORKSPACE/host/hackrf-tools/ -DLIBHACKRF_INCLUDE_DIR="$env:GITHUB_WORKSPACE/install/include/libhackrf" -DLIBHACKRF_LIBRARIES="$env:GITHUB_WORKSPACE/install/bin/hackrf.lib" $env:WIN_PKG_CONFIG $env:WIN_CMAKE_TOOLCHAIN
|
||||
if: matrix.os == 'windows-latest'
|
||||
|
||||
- name: Build (hackrf-tools)
|
||||
|
||||
@@ -19,16 +19,14 @@ if(LIBUSB_INCLUDE_DIR AND LIBUSB_LIBRARIES)
|
||||
set(LIBUSB_FOUND TRUE)
|
||||
|
||||
else(LIBUSB_INCLUDE_DIR AND LIBUSB_LIBRARIES)
|
||||
if(NOT WIN32)
|
||||
# use pkg-config to get the directories and then use these values in the
|
||||
# FIND_PATH() and FIND_LIBRARY() calls
|
||||
find_package(PkgConfig)
|
||||
pkg_check_modules(PC_LIBUSB libusb-1.0)
|
||||
endif(NOT WIN32)
|
||||
# use pkg-config to get the directories and then use these values in the
|
||||
# FIND_PATH() and FIND_LIBRARY() calls
|
||||
find_package(PkgConfig)
|
||||
pkg_check_modules(PC_LIBUSB libusb-1.0)
|
||||
|
||||
set(LIBUSB_LIBRARY_NAME usb-1.0)
|
||||
set(LIBUSB_LIBRARY_NAMES usb-1.0)
|
||||
if(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD")
|
||||
set(LIBUSB_LIBRARY_NAME usb)
|
||||
set(LIBUSB_LIBRARY_NAMES usb)
|
||||
elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows")
|
||||
# vcpkg's libusb-1.0 has a "lib" prefix, but on Windows MVSC, CMake doesn't
|
||||
# search for static libraries with lib prefixes automatically.
|
||||
@@ -40,7 +38,7 @@ else(LIBUSB_INCLUDE_DIR AND LIBUSB_LIBRARIES)
|
||||
|
||||
find_library(
|
||||
LIBUSB_LIBRARIES
|
||||
NAMES ${LIBUSB_LIBRARY_NAME}
|
||||
NAMES ${LIBUSB_LIBRARY_NAMES}
|
||||
PATHS ${PC_LIBUSB_LIBDIR} ${PC_LIBUSB_LIBRARY_DIRS})
|
||||
|
||||
endif(LIBUSB_INCLUDE_DIR AND LIBUSB_LIBRARIES)
|
||||
|
||||
Reference in New Issue
Block a user