From 694d790cd25072ea93b51ab497faec843ecf05af Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Thu, 11 Dec 2025 02:20:26 -0800 Subject: [PATCH 01/11] Fix printf formats --- fobos/fobos.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fobos/fobos.c b/fobos/fobos.c index a2e21ac..d32b008 100644 --- a/fobos/fobos.c +++ b/fobos/fobos.c @@ -2012,7 +2012,7 @@ int fobos_rx_read_async(struct fobos_dev_t * dev, fobos_rx_cb_t cb, void *ctx, u result = libusb_submit_transfer(dev->transfer[i]); if (result < 0) { - printf_internal("Failed to submit transfer #%i, err %i\n", i, result); + printf_internal("Failed to submit transfer #%lu, err %i\n", (unsigned long)i, result); dev->rx_async_status = FOBOS_CANCELING; break; } @@ -2057,7 +2057,7 @@ int fobos_rx_read_async(struct fobos_dev_t * dev, fobos_rx_cb_t cb, void *ctx, u libusb_handle_events_timeout_completed(dev->libusb_ctx, &tvx, NULL); if (result < 0) { - printf_internal("libusb_cancel_transfer[%d] returned: %d %s\n", i, result, libusb_error_name(result)); + printf_internal("libusb_cancel_transfer[%lu] returned: %d %s\n", (unsigned long)i, result, libusb_error_name(result)); continue; } dev->rx_async_status = FOBOS_CANCELING; From 019a8ec645d9e75272c2ff517aa9dc66eafcf8a6 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Thu, 11 Dec 2025 02:41:26 -0800 Subject: [PATCH 02/11] better format fix (didn't know about %zu !) --- fobos/fobos.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fobos/fobos.c b/fobos/fobos.c index d32b008..cfd9942 100644 --- a/fobos/fobos.c +++ b/fobos/fobos.c @@ -2012,7 +2012,7 @@ int fobos_rx_read_async(struct fobos_dev_t * dev, fobos_rx_cb_t cb, void *ctx, u result = libusb_submit_transfer(dev->transfer[i]); if (result < 0) { - printf_internal("Failed to submit transfer #%lu, err %i\n", (unsigned long)i, result); + printf_internal("Failed to submit transfer #%zu, err %i\n", i, result); dev->rx_async_status = FOBOS_CANCELING; break; } @@ -2057,7 +2057,7 @@ int fobos_rx_read_async(struct fobos_dev_t * dev, fobos_rx_cb_t cb, void *ctx, u libusb_handle_events_timeout_completed(dev->libusb_ctx, &tvx, NULL); if (result < 0) { - printf_internal("libusb_cancel_transfer[%lu] returned: %d %s\n", (unsigned long)i, result, libusb_error_name(result)); + printf_internal("libusb_cancel_transfer[%zu] returned: %d %s\n", i, result, libusb_error_name(result)); continue; } dev->rx_async_status = FOBOS_CANCELING; From 874653aa4c83efe7175ba06fcc7b001e66dd8cfc Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sat, 2 May 2026 15:32:57 -0700 Subject: [PATCH 03/11] ChatGPT recommended changes for Debian portability --- CMakeLists.txt | 561 +++++++++++++++++++++++++------------------------ 1 file changed, 283 insertions(+), 278 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 903931e..9fdce20 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,278 +1,283 @@ -######################################################################## -# -# Fobos SDR project -# V.T. -# LGPL -# -######################################################################## -# -# This program is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program. If not, see . - -######################################################################## -# Project setup -######################################################################## -cmake_minimum_required(VERSION 3.7.2) - -if(${CMAKE_VERSION} VERSION_LESS "3.12.0") - project(fobos) -else() - project(fobos C) -endif() - -include(GNUInstallDirs) -message(>>> "CMAKE_INSTALL_LIBDIR: " ${CMAKE_INSTALL_LIBDIR}) -set(CMAKE_C_FLAGS, "${CMAKE_C_FLAGS} -std=c99") -######################################################################## - -######################################################################## -# Select the release build type by default to get optimization flags -######################################################################## -if(NOT CMAKE_BUILD_TYPE) - set(CMAKE_BUILD_TYPE "Release") - message(STATUS "Build type not specified: defaulting to release.") -endif(NOT CMAKE_BUILD_TYPE) -######################################################################## - -######################################################################## -# Compiler specific setup -######################################################################## -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - ADD_DEFINITIONS(-Wall) - ADD_DEFINITIONS(-Wextra) - ADD_DEFINITIONS(-Wno-unused-parameter) - ADD_DEFINITIONS(-Wno-unused) - ADD_DEFINITIONS(-Wsign-compare) - ADD_DEFINITIONS(-ansi) -elseif(MSVC14 OR MSVC14) - ADD_DEFINITIONS(-D_CRT_SECURE_NO_WARNINGS) - ADD_DEFINITIONS(-D_TIMESPEC_DEFINED) -endif() -######################################################################## - -######################################################################## -# Find build dependencies -######################################################################## -find_package(PkgConfig) -if(PKG_CONFIG_FOUND) - pkg_check_modules(LIBUSB libusb-1.0 IMPORTED_TARGET) - if(LIBUSB_LINK_LIBRARIES) - set(LIBUSB_LIBRARIES "${LIBUSB_LINK_LIBRARIES}") - endif() -else() -if (CMAKE_VS_PLATFORM_NAME STREQUAL Win32) - set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS32/dll) -endif() -if (CMAKE_VS_PLATFORM_NAME STREQUAL x64) - set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS64/dll) -endif() - set(LIBUSB_INCLUDE_DIRS ${CMAKE_SOURCE_DIR}/libusb/include) -endif() -if(PKG_CONFIG_FOUND AND NOT LIBUSB_FOUND) - message(FATAL_ERROR "LibUSB 1.0 required") -endif() -######################################################################## - -######################################################################## -# Install udev rules -######################################################################## -install( - FILES fobos-sdr.rules - DESTINATION "/etc/udev/rules.d" - COMPONENT "udev" - ) -######################################################################## - -######################################################################## -# Print Summary -######################################################################## -message(>>> "Build: " ${CMAKE_BUILD_TYPE}) -message(>>> "OS: " ${CMAKE_SYSTEM_NAME}) -message(>>> "VS Platform: " ${CMAKE_VS_PLATFORM_NAME}) -message(>>> "LIBUSB_LIBRARIES: " ${LIBUSB_LIBRARIES}) -message(>>> "LIBUSB_INCLUDE_DIRS: " ${LIBUSB_INCLUDE_DIRS}) -message(>>> "PROJECT_BINARY_DIR: " ${PROJECT_BINARY_DIR}) - -######################################################################## -# Fobos SDR library -######################################################################## -add_library(libfobos SHARED fobos/fobos.c) - -target_compile_options(libfobos PUBLIC -std=c99) - -if(MSVC) -target_compile_options(libfobos PUBLIC "/MT") -ADD_CUSTOM_COMMAND(TARGET libfobos - POST_BUILD - COMMAND ${CMAKE_COMMAND} -E make_directory ${PROJECT_BINARY_DIR}/Debug - COMMAND ${CMAKE_COMMAND} -E copy ${LIBUSB_LIBRARIES}/libusb-1.0.dll ${PROJECT_BINARY_DIR}/Debug -) -ADD_CUSTOM_COMMAND(TARGET libfobos - POST_BUILD - COMMAND ${CMAKE_COMMAND} -E make_directory ${PROJECT_BINARY_DIR}/Release - COMMAND ${CMAKE_COMMAND} -E copy ${LIBUSB_LIBRARIES}/libusb-1.0.dll ${PROJECT_BINARY_DIR}/Release -) -else() -endif() - -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(libfobos PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(libfobos PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(libfobos PUBLIC - $ - $ - $/fobos - ${LIBUSB_INCLUDE_DIRS} - ) - -set_target_properties(libfobos PROPERTIES DEFINE_SYMBOL "FOBOS_EXPORTS") -set_target_properties(libfobos PROPERTIES OUTPUT_NAME fobos) -######################################################################## - -######################################################################## -# Install public header files -######################################################################## -INSTALL( - FILES fobos/fobos.h - DESTINATION include -) -######################################################################## - -######################################################################## -# Install built library files & utilities -######################################################################## -INSTALL( - TARGETS libfobos - LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} -) -######################################################################## - -######################################################################## -# Create Pkg Config File -######################################################################## -FOREACH(inc ${LIBUSB_INCLUDEDIR}) - LIST(APPEND LIBFOBOS_PC_CFLAGS "-I${inc}") -ENDFOREACH(inc) - -FOREACH(lib ${LIBUSB_LIBRARY_DIRS}) - LIST(APPEND LIBFOBOS_PC_LIBS "-L${lib}") -ENDFOREACH(lib) - -# use space-separation format for the pc file -STRING(REPLACE ";" " " LIBFOBOS_PC_CFLAGS "${LIBFOBOS_PC_CFLAGS}") -STRING(REPLACE ";" " " LIBFOBOS_PC_LIBS "${LIBFOBOS_PC_LIBS}") - -set(prefix "${CMAKE_INSTALL_PREFIX}") -set(exec_prefix \${prefix}) -set(includedir \${prefix}/include) -set(libdir \${exec_prefix}/lib) - -CONFIGURE_FILE( - ${CMAKE_CURRENT_SOURCE_DIR}/libfobos.pc.in - ${CMAKE_CURRENT_BINARY_DIR}/libfobos.pc -@ONLY) - -INSTALL( - FILES ${CMAKE_CURRENT_BINARY_DIR}/libfobos.pc - DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig -) -######################################################################## - -######################################################################## -# Create uninstall target -######################################################################## -configure_file( - ${CMAKE_SOURCE_DIR}/cmake/cmake_uninstall.cmake.in - ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake -@ONLY) - -add_custom_target(uninstall - ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake -) -######################################################################## - -######################################################################## -# Create executable fobos_devinfo -######################################################################## -add_executable(fobos_devinfo - eval/fobos_devinfo_main.c) - -target_compile_options(fobos_devinfo PUBLIC -std=c99) - -target_link_libraries(fobos_devinfo PRIVATE libfobos) - -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}) - -target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}/fobos) -######################################################################## - -######################################################################## -# Create executable fobos_recorder -######################################################################## -add_executable(fobos_recorder - eval/fobos_recorder_main.c - wav/wav_file.c) - -target_compile_options(fobos_recorder PUBLIC -std=c99) - -target_link_libraries(fobos_recorder PRIVATE libfobos) - -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}) - -target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}/fobos) -######################################################################## - -######################################################################## -# Create executable fobos_fwloader -######################################################################## -add_executable(fobos_fwloader - eval/fobos_fwloader_main.c) - -target_compile_options(fobos_fwloader PUBLIC -std=c99) - -target_link_libraries(fobos_fwloader PRIVATE libfobos) - -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}) - -target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}/fobos) -######################################################################## - - -######################################################################## -# Directories -######################################################################## -set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) -set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) -set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) -######################################################################## +######################################################################## +# +# Fobos SDR project +# V.T. +# LGPL +# +######################################################################## +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +######################################################################## +# Project setup +######################################################################## +cmake_minimum_required(VERSION 3.7.2) + +if(${CMAKE_VERSION} VERSION_LESS "3.12.0") + project(fobos) +else() + project(fobos C) +endif() + +include(GNUInstallDirs) +message(>>> "CMAKE_INSTALL_LIBDIR: " ${CMAKE_INSTALL_LIBDIR}) +set(CMAKE_C_STANDARD 99) +set(CMAKE_C_STANDARD_REQUIRED ON) +######################################################################## + +######################################################################## +# Select the release build type by default to get optimization flags +######################################################################## +if(NOT CMAKE_BUILD_TYPE) + set(CMAKE_BUILD_TYPE "Release") + message(STATUS "Build type not specified: defaulting to release.") +endif(NOT CMAKE_BUILD_TYPE) +######################################################################## + +######################################################################## +# Compiler specific setup +######################################################################## +if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) + ADD_DEFINITIONS(-Wall) + ADD_DEFINITIONS(-Wextra) + ADD_DEFINITIONS(-Wno-unused-parameter) + ADD_DEFINITIONS(-Wno-unused) + ADD_DEFINITIONS(-Wsign-compare) + ADD_DEFINITIONS(-ansi) +elseif(MSVC14 OR MSVC14) + ADD_DEFINITIONS(-D_CRT_SECURE_NO_WARNINGS) + ADD_DEFINITIONS(-D_TIMESPEC_DEFINED) +endif() +######################################################################## + +######################################################################## +# Find build dependencies +######################################################################## +find_package(PkgConfig) +if(PKG_CONFIG_FOUND) + pkg_check_modules(LIBUSB libusb-1.0 IMPORTED_TARGET) + if(LIBUSB_LINK_LIBRARIES) + set(LIBUSB_LIBRARIES "${LIBUSB_LINK_LIBRARIES}") + endif() +else() +if (CMAKE_VS_PLATFORM_NAME STREQUAL Win32) + set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS32/dll) +endif() +if (CMAKE_VS_PLATFORM_NAME STREQUAL x64) + set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS64/dll) +endif() + set(LIBUSB_INCLUDE_DIRS ${CMAKE_SOURCE_DIR}/libusb/include) +endif() +if(PKG_CONFIG_FOUND AND NOT LIBUSB_FOUND) + message(FATAL_ERROR "LibUSB 1.0 required") +endif() +######################################################################## + +######################################################################## +# Install udev rules +######################################################################## +install( + FILES fobos-sdr.rules + DESTINATION "${CMAKE_INSTALL_LIBDIR}/udev/rules.d" + COMPONENT "udev" +) +######################################################################## + +######################################################################## +# Print Summary +######################################################################## +message(>>> "Build: " ${CMAKE_BUILD_TYPE}) +message(>>> "OS: " ${CMAKE_SYSTEM_NAME}) +message(>>> "VS Platform: " ${CMAKE_VS_PLATFORM_NAME}) +message(>>> "LIBUSB_LIBRARIES: " ${LIBUSB_LIBRARIES}) +message(>>> "LIBUSB_INCLUDE_DIRS: " ${LIBUSB_INCLUDE_DIRS}) +message(>>> "PROJECT_BINARY_DIR: " ${PROJECT_BINARY_DIR}) + +######################################################################## +# Fobos SDR library +######################################################################## +add_library(libfobos SHARED fobos/fobos.c) + +target_compile_options(libfobos PUBLIC -std=c99) + +if(MSVC) +target_compile_options(libfobos PUBLIC "/MT") +ADD_CUSTOM_COMMAND(TARGET libfobos + POST_BUILD + COMMAND ${CMAKE_COMMAND} -E make_directory ${PROJECT_BINARY_DIR}/Debug + COMMAND ${CMAKE_COMMAND} -E copy ${LIBUSB_LIBRARIES}/libusb-1.0.dll ${PROJECT_BINARY_DIR}/Debug +) +ADD_CUSTOM_COMMAND(TARGET libfobos + POST_BUILD + COMMAND ${CMAKE_COMMAND} -E make_directory ${PROJECT_BINARY_DIR}/Release + COMMAND ${CMAKE_COMMAND} -E copy ${LIBUSB_LIBRARIES}/libusb-1.0.dll ${PROJECT_BINARY_DIR}/Release +) +else() +endif() + +if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) + target_link_libraries(libfobos PRIVATE ${LIBUSB_LIBRARIES}) +else() + target_link_directories(libfobos PRIVATE ${LIBUSB_LIBRARIES}) +endif() + +target_include_directories(libfobos PUBLIC + $ + $ + $ + ${LIBUSB_INCLUDE_DIRS} +) + +set_target_properties(libfobos PROPERTIES + OUTPUT_NAME fobos + VERSION 0.0.0 + SOVERSION 0 + DEFINE_SYMBOL "FOBOS_EXPORTS" +) +######################################################################## + +######################################################################## +# Install public header files +######################################################################## +INSTALL( + FILES fobos/fobos.h + DESTINATION include +) +######################################################################## + +######################################################################## +# Install built library files & utilities +######################################################################## +INSTALL( + TARGETS libfobos + LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} +) +######################################################################## + +######################################################################## +# Create Pkg Config File +######################################################################## +FOREACH(inc ${LIBUSB_INCLUDEDIR}) + LIST(APPEND LIBFOBOS_PC_CFLAGS "-I${inc}") +ENDFOREACH(inc) + +FOREACH(lib ${LIBUSB_LIBRARY_DIRS}) + LIST(APPEND LIBFOBOS_PC_LIBS "-L${lib}") +ENDFOREACH(lib) + +# use space-separation format for the pc file +STRING(REPLACE ";" " " LIBFOBOS_PC_CFLAGS "${LIBFOBOS_PC_CFLAGS}") +STRING(REPLACE ";" " " LIBFOBOS_PC_LIBS "${LIBFOBOS_PC_LIBS}") + +set(prefix "${CMAKE_INSTALL_PREFIX}") +set(exec_prefix \${prefix}) +set(includedir \${prefix}/include) +set(libdir \${exec_prefix}/${CMAKE_INSTALL_LIBDIR}) + +CONFIGURE_FILE( + ${CMAKE_CURRENT_SOURCE_DIR}/libfobos.pc.in + ${CMAKE_CURRENT_BINARY_DIR}/libfobos.pc +@ONLY) + +INSTALL( + FILES ${CMAKE_CURRENT_BINARY_DIR}/libfobos.pc + DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig +) +######################################################################## + +######################################################################## +# Create uninstall target +######################################################################## +configure_file( + ${CMAKE_SOURCE_DIR}/cmake/cmake_uninstall.cmake.in + ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake +@ONLY) + +add_custom_target(uninstall + ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake +) +######################################################################## + +######################################################################## +# Create executable fobos_devinfo +######################################################################## +add_executable(fobos_devinfo + eval/fobos_devinfo_main.c) + +target_compile_options(fobos_devinfo PUBLIC -std=c99) + +target_link_libraries(fobos_devinfo PRIVATE libfobos) + +if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) + target_link_libraries(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) +else() + target_link_directories(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) +endif() + +target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}) + +target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}/fobos) +######################################################################## + +######################################################################## +# Create executable fobos_recorder +######################################################################## +add_executable(fobos_recorder + eval/fobos_recorder_main.c + wav/wav_file.c) + +target_compile_options(fobos_recorder PUBLIC -std=c99) + +target_link_libraries(fobos_recorder PRIVATE libfobos) + +if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) + target_link_libraries(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) +else() + target_link_directories(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) +endif() + +target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}) + +target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}/fobos) +######################################################################## + +######################################################################## +# Create executable fobos_fwloader +######################################################################## +add_executable(fobos_fwloader + eval/fobos_fwloader_main.c) + +target_compile_options(fobos_fwloader PUBLIC -std=c99) + +target_link_libraries(fobos_fwloader PRIVATE libfobos) + +if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) + target_link_libraries(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) +else() + target_link_directories(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) +endif() + +target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}) + +target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}/fobos) +######################################################################## + + +######################################################################## +# Directories +######################################################################## +set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) +set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib) +set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) +######################################################################## From 4a7425a255aea1f29ba79426c739ca8e343e21d4 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sat, 2 May 2026 17:22:50 -0700 Subject: [PATCH 04/11] change CMakeLists.txt to better align with Debian standards add rules to build Debian binary packages (.deb) --- fobos-sdr.rules => 60-fobos-sdr.rules | 0 CMakeLists.txt | 15 +- debian/.gitignore | 5 + debian/README.Debian.ex | 6 + debian/README.source.ex | 9 + debian/changelog | 5 + debian/control | 38 ++ debian/copyright | 513 ++++++++++++++++++++++++++ debian/fobos-udev.install | 3 + debian/gbp.conf.ex | 56 +++ debian/libfobos-dev-dirs | 2 + debian/libfobos-dev.install | 3 + debian/libfobos0.dirs | 1 + debian/libfobos0.install | 1 + debian/postinst.ex | 39 ++ debian/postrm.ex | 37 ++ debian/preinst.ex | 35 ++ debian/prerm.ex | 38 ++ debian/rules | 26 ++ debian/salsa-ci.yml.ex | 10 + debian/source/format | 1 + debian/upstream.ex/metadata.ex | 10 + debian/watch.ex | 37 ++ install_manifest.txt | 6 + libfobos.pc.in | 18 +- 25 files changed, 897 insertions(+), 17 deletions(-) rename fobos-sdr.rules => 60-fobos-sdr.rules (100%) create mode 100644 debian/.gitignore create mode 100644 debian/README.Debian.ex create mode 100644 debian/README.source.ex create mode 100644 debian/changelog create mode 100644 debian/control create mode 100644 debian/copyright create mode 100644 debian/fobos-udev.install create mode 100644 debian/gbp.conf.ex create mode 100644 debian/libfobos-dev-dirs create mode 100644 debian/libfobos-dev.install create mode 100644 debian/libfobos0.dirs create mode 100644 debian/libfobos0.install create mode 100644 debian/postinst.ex create mode 100644 debian/postrm.ex create mode 100644 debian/preinst.ex create mode 100644 debian/prerm.ex create mode 100755 debian/rules create mode 100644 debian/salsa-ci.yml.ex create mode 100644 debian/source/format create mode 100644 debian/upstream.ex/metadata.ex create mode 100644 debian/watch.ex create mode 100644 install_manifest.txt diff --git a/fobos-sdr.rules b/60-fobos-sdr.rules similarity index 100% rename from fobos-sdr.rules rename to 60-fobos-sdr.rules diff --git a/CMakeLists.txt b/CMakeLists.txt index 9fdce20..ddbb1b1 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -22,13 +22,12 @@ ######################################################################## # Project setup ######################################################################## -cmake_minimum_required(VERSION 3.7.2) +cmake_minimum_required(VERSION 3.10) -if(${CMAKE_VERSION} VERSION_LESS "3.12.0") - project(fobos) -else() - project(fobos C) -endif() +project(fobos + VERSION 2.4.1 + LANGUAGES C +) include(GNUInstallDirs) message(>>> "CMAKE_INSTALL_LIBDIR: " ${CMAKE_INSTALL_LIBDIR}) @@ -88,8 +87,8 @@ endif() # Install udev rules ######################################################################## install( - FILES fobos-sdr.rules - DESTINATION "${CMAKE_INSTALL_LIBDIR}/udev/rules.d" + FILES 60-fobos-sdr.rules + DESTINATION "lib/udev/rules.d" COMPONENT "udev" ) ######################################################################## diff --git a/debian/.gitignore b/debian/.gitignore new file mode 100644 index 0000000..525c2f1 --- /dev/null +++ b/debian/.gitignore @@ -0,0 +1,5 @@ +/*.substvars +/.debhelper/ +/debhelper-build-stamp +/files +/tmp/ diff --git a/debian/README.Debian.ex b/debian/README.Debian.ex new file mode 100644 index 0000000..c3a6f5c --- /dev/null +++ b/debian/README.Debian.ex @@ -0,0 +1,6 @@ +libfobos for Debian +------------------ + + + + -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 diff --git a/debian/README.source.ex b/debian/README.source.ex new file mode 100644 index 0000000..8dd4bb0 --- /dev/null +++ b/debian/README.source.ex @@ -0,0 +1,9 @@ +libfobos for Debian +------------------ + + + + + + -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 diff --git a/debian/changelog b/debian/changelog new file mode 100644 index 0000000..35727c5 --- /dev/null +++ b/debian/changelog @@ -0,0 +1,5 @@ +libfobos (2.4.1-1) UNRELEASED; urgency=medium + + * Initial release. (Closes: #nnnn) + + -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 diff --git a/debian/control b/debian/control new file mode 100644 index 0000000..a6ff5f0 --- /dev/null +++ b/debian/control @@ -0,0 +1,38 @@ +Source: libfobos +Section: libs +Priority: optional +Maintainer: Phil Karn +Rules-Requires-Root: no +Build-Depends: + debhelper-compat (= 13), + cmake, +Standards-Version: 4.7.2 +Homepage: https://rigexpert.com +Vcs-Git: https://github.com/ka9q/libfobos-debian.git +Vcs-Browser: https://github.com/ka9q/libfobos-debian + +Package: libfobos-dev +Section: libdevel +Architecture: any +Multi-Arch: same +Depends: + libfobos0 (= ${binary:Version}), + ${misc:Depends}, +Description: interface to RigExpert Fobos SDR + Provides an API to the RigExpert Fobos SDR + +Package: libfobos0 +Architecture: any +Multi-Arch: same +Depends: + ${shlibs:Depends}, + ${misc:Depends}, +Description: RigExpert Fobos SDR runtime library + Runtime library for RigExpert Fobos SDR + +Package: fobos-udev +Architecture: all +Depends: ${misc:Depends}, udev +Description: udev rules for RigExpert Fobos SDR + udev rules for accessing RigExpert Fobos SDR devices. + diff --git a/debian/copyright b/debian/copyright new file mode 100644 index 0000000..912e24c --- /dev/null +++ b/debian/copyright @@ -0,0 +1,513 @@ +Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ +Source: +Upstream-Name: libfobos +Upstream-Contact: + +Copyright: + RigExpert (I presume) +License: LGPL 2.1 + GNU LESSER GENERAL PUBLIC LICENSE + Version 2.1, February 1999 + + Copyright (C) 1991, 1999 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + +[This is the first released version of the Lesser GPL. It also counts + as the successor of the GNU Library Public License, version 2, hence + the version number 2.1.] + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +Licenses are intended to guarantee your freedom to share and change +free software--to make sure the software is free for all its users. + + This license, the Lesser General Public License, applies to some +specially designated software packages--typically libraries--of the +Free Software Foundation and other authors who decide to use it. You +can use it too, but we suggest you first think carefully about whether +this license or the ordinary General Public License is the better +strategy to use in any particular case, based on the explanations below. + + When we speak of free software, we are referring to freedom of use, +not price. Our General Public Licenses are designed to make sure that +you have the freedom to distribute copies of free software (and charge +for this service if you wish); that you receive source code or can get +it if you want it; that you can change the software and use pieces of +it in new free programs; and that you are informed that you can do +these things. + + To protect your rights, we need to make restrictions that forbid +distributors to deny you these rights or to ask you to surrender these +rights. These restrictions translate to certain responsibilities for +you if you distribute copies of the library or if you modify it. + + For example, if you distribute copies of the library, whether gratis +or for a fee, you must give the recipients all the rights that we gave +you. You must make sure that they, too, receive or can get the source +code. If you link other code with the library, you must provide +complete object files to the recipients, so that they can relink them +with the library after making changes to the library and recompiling +it. And you must show them these terms so they know their rights. + + We protect your rights with a two-step method: (1) we copyright the +library, and (2) we offer you this license, which gives you legal +permission to copy, distribute and/or modify the library. + + To protect each distributor, we want to make it very clear that +there is no warranty for the free library. Also, if the library is +modified by someone else and passed on, the recipients should know +that what they have is not the original version, so that the original +author's reputation will not be affected by problems that might be +introduced by others. + + Finally, software patents pose a constant threat to the existence of +any free program. We wish to make sure that a company cannot +effectively restrict the users of a free program by obtaining a +restrictive license from a patent holder. Therefore, we insist that +any patent license obtained for a version of the library must be +consistent with the full freedom of use specified in this license. + + Most GNU software, including some libraries, is covered by the +ordinary GNU General Public License. This license, the GNU Lesser +General Public License, applies to certain designated libraries, and +is quite different from the ordinary General Public License. We use +this license for certain libraries in order to permit linking those +libraries into non-free programs. + + When a program is linked with a library, whether statically or using +a shared library, the combination of the two is legally speaking a +combined work, a derivative of the original library. The ordinary +General Public License therefore permits such linking only if the +entire combination fits its criteria of freedom. The Lesser General +Public License permits more lax criteria for linking other code with +the library. + + We call this license the "Lesser" General Public License because it +does Less to protect the user's freedom than the ordinary General +Public License. It also provides other free software developers Less +of an advantage over competing non-free programs. These disadvantages +are the reason we use the ordinary General Public License for many +libraries. However, the Lesser license provides advantages in certain +special circumstances. + + For example, on rare occasions, there may be a special need to +encourage the widest possible use of a certain library, so that it becomes +a de-facto standard. To achieve this, non-free programs must be +allowed to use the library. A more frequent case is that a free +library does the same job as widely used non-free libraries. In this +case, there is little to gain by limiting the free library to free +software only, so we use the Lesser General Public License. + + In other cases, permission to use a particular library in non-free +programs enables a greater number of people to use a large body of +free software. For example, permission to use the GNU C Library in +non-free programs enables many more people to use the whole GNU +operating system, as well as its variant, the GNU/Linux operating +system. + + Although the Lesser General Public License is Less protective of the +users' freedom, it does ensure that the user of a program that is +linked with the Library has the freedom and the wherewithal to run +that program using a modified version of the Library. + + The precise terms and conditions for copying, distribution and +modification follow. Pay close attention to the difference between a +"work based on the library" and a "work that uses the library". The +former contains code derived from the library, whereas the latter must +be combined with the library in order to run. + + GNU LESSER GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License Agreement applies to any software library or other +program which contains a notice placed by the copyright holder or +other authorized party saying it may be distributed under the terms of +this Lesser General Public License (also called "this License"). +Each licensee is addressed as "you". + + A "library" means a collection of software functions and/or data +prepared so as to be conveniently linked with application programs +(which use some of those functions and data) to form executables. + + The "Library", below, refers to any such software library or work +which has been distributed under these terms. A "work based on the +Library" means either the Library or any derivative work under +copyright law: that is to say, a work containing the Library or a +portion of it, either verbatim or with modifications and/or translated +straightforwardly into another language. (Hereinafter, translation is +included without limitation in the term "modification".) + + "Source code" for a work means the preferred form of the work for +making modifications to it. For a library, complete source code means +all the source code for all modules it contains, plus any associated +interface definition files, plus the scripts used to control compilation +and installation of the library. + + Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running a program using the Library is not restricted, and output from +such a program is covered only if its contents constitute a work based +on the Library (independent of the use of the Library in a tool for +writing it). Whether that is true depends on what the Library does +and what the program that uses the Library does. + + 1. You may copy and distribute verbatim copies of the Library's +complete source code as you receive it, in any medium, provided that +you conspicuously and appropriately publish on each copy an +appropriate copyright notice and disclaimer of warranty; keep intact +all the notices that refer to this License and to the absence of any +warranty; and distribute a copy of this License along with the +Library. + + You may charge a fee for the physical act of transferring a copy, +and you may at your option offer warranty protection in exchange for a +fee. + + 2. You may modify your copy or copies of the Library or any portion +of it, thus forming a work based on the Library, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) The modified work must itself be a software library. + + b) You must cause the files modified to carry prominent notices + stating that you changed the files and the date of any change. + + c) You must cause the whole of the work to be licensed at no + charge to all third parties under the terms of this License. + + d) If a facility in the modified Library refers to a function or a + table of data to be supplied by an application program that uses + the facility, other than as an argument passed when the facility + is invoked, then you must make a good faith effort to ensure that, + in the event an application does not supply such function or + table, the facility still operates, and performs whatever part of + its purpose remains meaningful. + + (For example, a function in a library to compute square roots has + a purpose that is entirely well-defined independent of the + application. Therefore, Subsection 2d requires that any + application-supplied function or table used by this function must + be optional: if the application does not supply it, the square + root function must still compute square roots.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Library, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Library, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote +it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Library. + +In addition, mere aggregation of another work not based on the Library +with the Library (or with a work based on the Library) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may opt to apply the terms of the ordinary GNU General Public +License instead of this License to a given copy of the Library. To do +this, you must alter all the notices that refer to this License, so +that they refer to the ordinary GNU General Public License, version 2, +instead of to this License. (If a newer version than version 2 of the +ordinary GNU General Public License has appeared, then you can specify +that version instead if you wish.) Do not make any other change in +these notices. + + Once this change is made in a given copy, it is irreversible for +that copy, so the ordinary GNU General Public License applies to all +subsequent copies and derivative works made from that copy. + + This option is useful when you wish to copy part of the code of +the Library into a program that is not a library. + + 4. You may copy and distribute the Library (or a portion or +derivative of it, under Section 2) in object code or executable form +under the terms of Sections 1 and 2 above provided that you accompany +it with the complete corresponding machine-readable source code, which +must be distributed under the terms of Sections 1 and 2 above on a +medium customarily used for software interchange. + + If distribution of object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the +source code from the same place satisfies the requirement to +distribute the source code, even though third parties are not +compelled to copy the source along with the object code. + + 5. A program that contains no derivative of any portion of the +Library, but is designed to work with the Library by being compiled or +linked with it, is called a "work that uses the Library". Such a +work, in isolation, is not a derivative work of the Library, and +therefore falls outside the scope of this License. + + However, linking a "work that uses the Library" with the Library +creates an executable that is a derivative of the Library (because it +contains portions of the Library), rather than a "work that uses the +library". The executable is therefore covered by this License. +Section 6 states terms for distribution of such executables. + + When a "work that uses the Library" uses material from a header file +that is part of the Library, the object code for the work may be a +derivative work of the Library even though the source code is not. +Whether this is true is especially significant if the work can be +linked without the Library, or if the work is itself a library. The +threshold for this to be true is not precisely defined by law. + + If such an object file uses only numerical parameters, data +structure layouts and accessors, and small macros and small inline +functions (ten lines or less in length), then the use of the object +file is unrestricted, regardless of whether it is legally a derivative +work. (Executables containing this object code plus portions of the +Library will still fall under Section 6.) + + Otherwise, if the work is a derivative of the Library, you may +distribute the object code for the work under the terms of Section 6. +Any executables containing that work also fall under Section 6, +whether or not they are linked directly with the Library itself. + + 6. As an exception to the Sections above, you may also combine or +link a "work that uses the Library" with the Library to produce a +work containing portions of the Library, and distribute that work +under terms of your choice, provided that the terms permit +modification of the work for the customer's own use and reverse +engineering for debugging such modifications. + + You must give prominent notice with each copy of the work that the +Library is used in it and that the Library and its use are covered by +this License. You must supply a copy of this License. If the work +during execution displays copyright notices, you must include the +copyright notice for the Library among them, as well as a reference +directing the user to the copy of this License. Also, you must do one +of these things: + + a) Accompany the work with the complete corresponding + machine-readable source code for the Library including whatever + changes were used in the work (which must be distributed under + Sections 1 and 2 above); and, if the work is an executable linked + with the Library, with the complete machine-readable "work that + uses the Library", as object code and/or source code, so that the + user can modify the Library and then relink to produce a modified + executable containing the modified Library. (It is understood + that the user who changes the contents of definitions files in the + Library will not necessarily be able to recompile the application + to use the modified definitions.) + + b) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (1) uses at run time a + copy of the library already present on the user's computer system, + rather than copying library functions into the executable, and (2) + will operate properly with a modified version of the library, if + the user installs one, as long as the modified version is + interface-compatible with the version that the work was made with. + + c) Accompany the work with a written offer, valid for at + least three years, to give the same user the materials + specified in Subsection 6a, above, for a charge no more + than the cost of performing this distribution. + + d) If distribution of the work is made by offering access to copy + from a designated place, offer equivalent access to copy the above + specified materials from the same place. + + e) Verify that the user has already received a copy of these + materials or that you have already sent this user a copy. + + For an executable, the required form of the "work that uses the +Library" must include any data and utility programs needed for +reproducing the executable from it. However, as a special exception, +the materials to be distributed need not include anything that is +normally distributed (in either source or binary form) with the major +components (compiler, kernel, and so on) of the operating system on +which the executable runs, unless that component itself accompanies +the executable. + + It may happen that this requirement contradicts the license +restrictions of other proprietary libraries that do not normally +accompany the operating system. Such a contradiction means you cannot +use both them and the Library together in an executable that you +distribute. + + 7. You may place library facilities that are a work based on the +Library side-by-side in a single library together with other library +facilities not covered by this License, and distribute such a combined +library, provided that the separate distribution of the work based on +the Library and of the other library facilities is otherwise +permitted, and provided that you do these two things: + + a) Accompany the combined library with a copy of the same work + based on the Library, uncombined with any other library + facilities. This must be distributed under the terms of the + Sections above. + + b) Give prominent notice with the combined library of the fact + that part of it is a work based on the Library, and explaining + where to find the accompanying uncombined form of the same work. + + 8. You may not copy, modify, sublicense, link with, or distribute +the Library except as expressly provided under this License. Any +attempt otherwise to copy, modify, sublicense, link with, or +distribute the Library is void, and will automatically terminate your +rights under this License. However, parties who have received copies, +or rights, from you under this License will not have their licenses +terminated so long as such parties remain in full compliance. + + 9. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Library or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Library (or any work based on the +Library), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Library or works based on it. + + 10. Each time you redistribute the Library (or any work based on the +Library), the recipient automatically receives a license from the +original licensor to copy, distribute, link with or modify the Library +subject to these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties with +this License. + + 11. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Library at all. For example, if a patent +license would not permit royalty-free redistribution of the Library by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Library. + +If any portion of this section is held invalid or unenforceable under any +particular circumstance, the balance of the section is intended to apply, +and the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 12. If the distribution and/or use of the Library is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Library under this License may add +an explicit geographical distribution limitation excluding those countries, +so that distribution is permitted only in or among countries not thus +excluded. In such case, this License incorporates the limitation as if +written in the body of this License. + + 13. The Free Software Foundation may publish revised and/or new +versions of the Lesser General Public License from time to time. +Such new versions will be similar in spirit to the present version, +but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library +specifies a version number of this License which applies to it and +"any later version", you have the option of following the terms and +conditions either of that version or of any later version published by +the Free Software Foundation. If the Library does not specify a +license version number, you may choose any version ever published by +the Free Software Foundation. + + 14. If you wish to incorporate parts of the Library into other free +programs whose distribution conditions are incompatible with these, +write to the author to ask for permission. For software which is +copyrighted by the Free Software Foundation, write to the Free +Software Foundation; we sometimes make exceptions for this. Our +decision will be guided by the two goals of preserving the free status +of all derivatives of our free software and of promoting the sharing +and reuse of software generally. + + NO WARRANTY + + 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO +WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. +EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR +OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY +KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE +LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME +THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN +WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY +AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU +FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR +CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE +LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING +RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A +FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF +SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH +DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Libraries + + If you develop a new library, and you want it to be of the greatest +possible use to the public, we recommend making it free software that +everyone can redistribute and change. You can do so by permitting +redistribution under these terms (or, alternatively, under the terms of the +ordinary General Public License). + + To apply these terms, attach the following notices to the library. It is +safest to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least the +"copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 + USA + +Also add information on how to contact you by electronic and paper mail. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the library, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the + library `Frob' (a library for tweaking knobs) written by James Random + Hacker. + + , 1 April 1990 + Ty Coon, President of Vice + +That's all there is to it! + diff --git a/debian/fobos-udev.install b/debian/fobos-udev.install new file mode 100644 index 0000000..ec939c5 --- /dev/null +++ b/debian/fobos-udev.install @@ -0,0 +1,3 @@ +# debian/fobos-udev.install +usr/lib/udev/rules.d/60-fobos-sdr.rules + diff --git a/debian/gbp.conf.ex b/debian/gbp.conf.ex new file mode 100644 index 0000000..0627f18 --- /dev/null +++ b/debian/gbp.conf.ex @@ -0,0 +1,56 @@ +# See gbp(1) provided by git-buildpackage package for an explanation of each +# option or browse https://manpages.debian.org/unstable/git-buildpackage/gbp.1.en.html + +[DEFAULT] +# DEP-14 format. Other naming convention are available, +# see DEP-14 for more details. +debian-branch = debian/latest +upstream-branch = upstream/latest + +# Enable pristine-tar to exactly reproduce orig tarballs +pristine-tar = True + +# The Debian packaging git repository may also host actual upstream tags and +# branches, typically named 'main' or 'master'. Configure the upstream tag +# format below, so that `gbp import-orig` will run correctly, and link tarball +# import branch (`upstream/latest`) with the equivalent upstream release tag, +# showing a complete audit trail of what upstream released and what was imported +# into Debian. +#upstream-vcs-tag = %(version%~%.)s + +# If upstream publishes tarball signatures, git-buildpackage will by default +# import and use the them. Change this to 'on' to make 'gbp import-orig' abort +# if the signature is not found or is not valid. +#upstream-signatures = on + +# Ensure the Debian maintainer signs git tags automatically. +#sign-tags = True + +# Ease dropping / adding patches. +#patch-numbers = False + +# Group debian/changelog entries with the same "[ Author ]" instead of making +# multiple ones for the same author. +#multimaint-merge = True + +# Automatically open a new changelog entry about the new upstream release, but +# do not commit it, as the 'gbp dch' still needs to run and list all commits +# based on when the debian/changelog last was updated in a git commit. +#postimport = dch -v %(version)s "New upstream release" + +# Ensure a human always reviews all the debian/changelog entries. +#spawn-editor = always + +# No need to confirm package name or version at any time, git-buildpackage +# always gets it right. +#interactive = False + +# Ensure we always target Debian on Debian branches. +#dch-opt = --vendor=debian + +# If this package ever needs to be maintained for Ubuntu, remember to override +# the branch, tag and commit messages. +#debian-branch = ubuntu/24.04-noble +#debian-tag = ubuntu/%(version)s +#debian-tag-msg = %(pkg)s Ubuntu release %(version)s +#dch-opt = --vendor=ubuntu diff --git a/debian/libfobos-dev-dirs b/debian/libfobos-dev-dirs new file mode 100644 index 0000000..4418816 --- /dev/null +++ b/debian/libfobos-dev-dirs @@ -0,0 +1,2 @@ +usr/lib +usr/include diff --git a/debian/libfobos-dev.install b/debian/libfobos-dev.install new file mode 100644 index 0000000..7df81cd --- /dev/null +++ b/debian/libfobos-dev.install @@ -0,0 +1,3 @@ +usr/include/* +usr/lib/*/lib*.so +usr/lib/*/pkgconfig/* diff --git a/debian/libfobos0.dirs b/debian/libfobos0.dirs new file mode 100644 index 0000000..6845771 --- /dev/null +++ b/debian/libfobos0.dirs @@ -0,0 +1 @@ +usr/lib diff --git a/debian/libfobos0.install b/debian/libfobos0.install new file mode 100644 index 0000000..3ddde58 --- /dev/null +++ b/debian/libfobos0.install @@ -0,0 +1 @@ +usr/lib/*/lib*.so.* diff --git a/debian/postinst.ex b/debian/postinst.ex new file mode 100644 index 0000000..87a9a25 --- /dev/null +++ b/debian/postinst.ex @@ -0,0 +1,39 @@ +#!/bin/sh +# postinst script for libfobos. +# +# See: dh_installdeb(1). + +set -e + +# Summary of how this script can be called: +# * 'configure' +# * 'abort-upgrade' +# * 'abort-remove' 'in-favour' +# +# * 'abort-remove' +# * 'abort-deconfigure' 'in-favour' +# 'removing' +# +# for details, see https://www.debian.org/doc/debian-policy/ or +# the debian-policy package. + + +case "$1" in + configure) + ;; + + abort-upgrade|abort-remove|abort-deconfigure) + ;; + + *) + echo "postinst called with unknown argument '$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/debian/postrm.ex b/debian/postrm.ex new file mode 100644 index 0000000..935f57f --- /dev/null +++ b/debian/postrm.ex @@ -0,0 +1,37 @@ +#!/bin/sh +# postrm script for libfobos. +# +# See: dh_installdeb(1). + +set -e + +# Summary of how this script can be called: +# * 'remove' +# * 'purge' +# * 'upgrade' +# * 'failed-upgrade' +# * 'abort-install' +# * 'abort-install' +# * 'abort-upgrade' +# * 'disappear' +# +# for details, see https://www.debian.org/doc/debian-policy/ or +# the debian-policy package. + + +case "$1" in + purge|remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear) + ;; + + *) + echo "postrm called with unknown argument '$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/debian/preinst.ex b/debian/preinst.ex new file mode 100644 index 0000000..68ef927 --- /dev/null +++ b/debian/preinst.ex @@ -0,0 +1,35 @@ +#!/bin/sh +# preinst script for libfobos. +# +# See: dh_installdeb(1). + +set -e + +# Summary of how this script can be called: +# * 'install' +# * 'install' +# * 'upgrade' +# * 'abort-upgrade' +# for details, see https://www.debian.org/doc/debian-policy/ or +# the debian-policy package. + + +case "$1" in + install|upgrade) + ;; + + abort-upgrade) + ;; + + *) + echo "preinst called with unknown argument '$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/debian/prerm.ex b/debian/prerm.ex new file mode 100644 index 0000000..1482ed0 --- /dev/null +++ b/debian/prerm.ex @@ -0,0 +1,38 @@ +#!/bin/sh +# prerm script for libfobos. +# +# See: dh_installdeb(1). + +set -e + +# Summary of how this script can be called: +# * 'remove' +# * 'upgrade' +# * 'failed-upgrade' +# * 'remove' 'in-favour' +# * 'deconfigure' 'in-favour' +# 'removing' +# +# for details, see https://www.debian.org/doc/debian-policy/ or +# the debian-policy package. + + +case "$1" in + remove|upgrade|deconfigure) + ;; + + failed-upgrade) + ;; + + *) + echo "prerm called with unknown argument '$1'" >&2 + exit 1 + ;; +esac + +# dh_installdeb will replace this with shell code automatically +# generated by other debhelper scripts. + +#DEBHELPER# + +exit 0 diff --git a/debian/rules b/debian/rules new file mode 100755 index 0000000..f1d1d25 --- /dev/null +++ b/debian/rules @@ -0,0 +1,26 @@ +#!/usr/bin/make -f + +# See debhelper(7) (uncomment to enable). +# Output every command that modifies files on the build system. +#export DH_VERBOSE = 1 + + +# See FEATURE AREAS in dpkg-buildflags(1). +#export DEB_BUILD_MAINT_OPTIONS = hardening=+all + +# See ENVIRONMENT in dpkg-buildflags(1). +# Package maintainers to append CFLAGS. +#export DEB_CFLAGS_MAINT_APPEND = -Wall -pedantic +# Package maintainers to append LDFLAGS. +#export DEB_LDFLAGS_MAINT_APPEND = -Wl,--as-needed + + +%: + dh $@ + + +# dh_make generated override targets. +# This is an example for Cmake (see ). +#override_dh_auto_configure: +# dh_auto_configure -- \ +# -DCMAKE_LIBRARY_PATH=$(DEB_HOST_MULTIARCH) diff --git a/debian/salsa-ci.yml.ex b/debian/salsa-ci.yml.ex new file mode 100644 index 0000000..11a64c6 --- /dev/null +++ b/debian/salsa-ci.yml.ex @@ -0,0 +1,10 @@ +# For more information on what jobs are run see: +# https://salsa.debian.org/salsa-ci-team/pipeline +# +# To enable the jobs, go to your repository (at salsa.debian.org) +# and click over Settings > CI/CD > Expand (in General pipelines). +# In "CI/CD configuration file" write debian/salsa-ci.yml and click +# in "Save Changes". The CI tests will run after the next commit. +--- +include: + - https://salsa.debian.org/salsa-ci-team/pipeline/raw/master/recipes/debian.yml diff --git a/debian/source/format b/debian/source/format new file mode 100644 index 0000000..163aaf8 --- /dev/null +++ b/debian/source/format @@ -0,0 +1 @@ +3.0 (quilt) diff --git a/debian/upstream.ex/metadata.ex b/debian/upstream.ex/metadata.ex new file mode 100644 index 0000000..774e657 --- /dev/null +++ b/debian/upstream.ex/metadata.ex @@ -0,0 +1,10 @@ +# Example file for upstream/metadata. +# See https://wiki.debian.org/UpstreamMetadata for more info/fields. +# Below an example based on a github project. + +# Bug-Database: https://github.com//libfobos/issues +# Bug-Submit: https://github.com//libfobos/issues/new +# Changelog: https://github.com//libfobos/blob/master/CHANGES +# Documentation: https://github.com//libfobos/wiki +# Repository-Browse: https://github.com//libfobos +# Repository: https://github.com//libfobos.git diff --git a/debian/watch.ex b/debian/watch.ex new file mode 100644 index 0000000..077e533 --- /dev/null +++ b/debian/watch.ex @@ -0,0 +1,37 @@ +# Example watch control file for uscan. +# Rename this file to "watch" and then you can run the "uscan" command +# to check for upstream updates and more. +# See uscan(1) for format. + +# Compulsory line, this is a version 4 file. +version=4 + +# PGP signature mangle, so foo.tar.gz has foo.tar.gz.sig. +#opts="pgpsigurlmangle=s%$%.sig%" + +# HTTP site (basic). +#http://example.com/downloads.html \ +# files/libfobos-([\d\.]+)\.tar\.gz + +# Uncomment to examine an FTP server. +#ftp://ftp.example.com/pub/libfobos-(.*)\.tar\.gz + +# SourceForge hosted projects. +#http://sf.net/libfobos/ libfobos-(.*)\.tar\.gz + +# GitHub hosted projects. +#opts="filenamemangle=s%(?:.*?)?v?(@ANY_VERSION@@ARCHIVE_EXT@)%@PACKAGE@-$1%" \ +# https://github.com///tags \ +# (?:.*?/)v?@ANY_VERSION@@ARCHIVE_EXT@ + +# GitLab hosted projects. +#opts="filenamemangle=s%(?:.*?)?v?(@ANY_VERSION@@ARCHIVE_EXT@)%@PACKAGE@-$1%" \ +# https://gitlab.com///-/tags \ +# archive/v?@ANY_VERSION@/-v?\d\S*@ARCHIVE_EXT@ + +# PyPI. +#https://pypi.debian.net/libfobos/libfobos-(.+)\.(?:zip|tgz|tbz|txz|(?:tar\.(?:gz|bz2|xz))) + +# Direct Git. +#opts="mode=git" http://git.example.com/libfobos.git \ +# refs/tags/v([\d\.]+) diff --git a/install_manifest.txt b/install_manifest.txt new file mode 100644 index 0000000..0d3318d --- /dev/null +++ b/install_manifest.txt @@ -0,0 +1,6 @@ +/usr/lib/udev/rules.d/60-fobos-sdr.rules +/usr/include/fobos.h +/usr/lib/x86_64-linux-gnu/libfobos.so.0.0.0 +/usr/lib/x86_64-linux-gnu/libfobos.so.0 +/usr/lib/x86_64-linux-gnu/libfobos.so +/usr/lib/x86_64-linux-gnu/pkgconfig/libfobos.pc \ No newline at end of file diff --git a/libfobos.pc.in b/libfobos.pc.in index 37a9144..6218780 100644 --- a/libfobos.pc.in +++ b/libfobos.pc.in @@ -1,11 +1,11 @@ -prefix=@prefix@ -exec_prefix=@exec_prefix@ -libdir=@libdir@ -includedir=@includedir@ +prefix=@CMAKE_INSTALL_PREFIX@ +exec_prefix=${prefix} +libdir=${exec_prefix}/@CMAKE_INSTALL_LIBDIR@ +includedir=${prefix}/include -Name: RigExpert Fobos SDR Library -Description: C Utility Library -Version: @LIBVER@ -Cflags: -I${includedir}/ @LIBFOBOS_PC_CFLAGS@ +Name: libfobos +Description: RigExpert Fobos SDR Library +Version: @PROJECT_VERSION@ +Cflags: -I${includedir} Libs: -L${libdir} -lfobos -Libs.private: -lusb-1.0 @LIBFOBOS_PC_LIBS@ +Libs.private: -lusb-1.0 From 7a4beb4ac93e1e2f2b9c3b28ec0e1c26bb472e60 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sun, 10 May 2026 23:05:07 -0700 Subject: [PATCH 05/11] fixes to Linux builds --- CMakeLists.txt | 66 ++++++++++++-------------------------------------- fobos/fobos.c | 2 +- libfobos.pc.in | 2 +- 3 files changed, 18 insertions(+), 52 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index ddbb1b1..84e7887 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -63,24 +63,8 @@ endif() ######################################################################## # Find build dependencies ######################################################################## -find_package(PkgConfig) -if(PKG_CONFIG_FOUND) - pkg_check_modules(LIBUSB libusb-1.0 IMPORTED_TARGET) - if(LIBUSB_LINK_LIBRARIES) - set(LIBUSB_LIBRARIES "${LIBUSB_LINK_LIBRARIES}") - endif() -else() -if (CMAKE_VS_PLATFORM_NAME STREQUAL Win32) - set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS32/dll) -endif() -if (CMAKE_VS_PLATFORM_NAME STREQUAL x64) - set(LIBUSB_LIBRARIES ${CMAKE_SOURCE_DIR}/libusb/MS64/dll) -endif() - set(LIBUSB_INCLUDE_DIRS ${CMAKE_SOURCE_DIR}/libusb/include) -endif() -if(PKG_CONFIG_FOUND AND NOT LIBUSB_FOUND) - message(FATAL_ERROR "LibUSB 1.0 required") -endif() +find_package(PkgConfig REQUIRED) +pkg_check_modules(LIBUSB REQUIRED IMPORTED_TARGET libusb-1.0) ######################################################################## ######################################################################## @@ -125,17 +109,12 @@ ADD_CUSTOM_COMMAND(TARGET libfobos else() endif() -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(libfobos PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(libfobos PRIVATE ${LIBUSB_LIBRARIES}) -endif() +target_link_libraries(libfobos PRIVATE PkgConfig::LIBUSB) target_include_directories(libfobos PUBLIC $ $ $ - ${LIBUSB_INCLUDE_DIRS} ) set_target_properties(libfobos PROPERTIES @@ -216,17 +195,14 @@ add_executable(fobos_devinfo target_compile_options(fobos_devinfo PUBLIC -std=c99) +target_include_directories(fobos_devinfo PRIVATE + ${CMAKE_SOURCE_DIR} + ${CMAKE_SOURCE_DIR}/fobos +) target_link_libraries(fobos_devinfo PRIVATE libfobos) -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_devinfo PRIVATE ${LIBUSB_LIBRARIES}) -endif() -target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}) -target_include_directories(fobos_devinfo PRIVATE ${CMAKE_SOURCE_DIR}/fobos) ######################################################################## ######################################################################## @@ -240,15 +216,10 @@ target_compile_options(fobos_recorder PUBLIC -std=c99) target_link_libraries(fobos_recorder PRIVATE libfobos) -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_recorder PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}) - -target_include_directories(fobos_recorder PRIVATE ${CMAKE_SOURCE_DIR}/fobos) +target_include_directories(fobos_recorder PRIVATE + ${CMAKE_SOURCE_DIR} + ${CMAKE_SOURCE_DIR}/fobos +) ######################################################################## ######################################################################## @@ -259,17 +230,12 @@ add_executable(fobos_fwloader target_compile_options(fobos_fwloader PUBLIC -std=c99) -target_link_libraries(fobos_fwloader PRIVATE libfobos) - -if(CMAKE_COMPILER_IS_GNUCC AND NOT WIN32) - target_link_libraries(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) -else() - target_link_directories(fobos_fwloader PRIVATE ${LIBUSB_LIBRARIES}) -endif() - -target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}) +target_include_directories(fobos_fwloader PRIVATE + ${CMAKE_SOURCE_DIR} + ${CMAKE_SOURCE_DIR}/fobos +) -target_include_directories(fobos_fwloader PRIVATE ${CMAKE_SOURCE_DIR}/fobos) +target_link_libraries(fobos_fwloader PRIVATE libfobos) ######################################################################## diff --git a/fobos/fobos.c b/fobos/fobos.c index cfd9942..50cbd03 100644 --- a/fobos/fobos.c +++ b/fobos/fobos.c @@ -31,7 +31,7 @@ #pragma comment(lib, "libusb-1.0.lib") #define printf_internal _cprintf #else -#include +#include #include #endif #ifndef printf_internal diff --git a/libfobos.pc.in b/libfobos.pc.in index 6218780..4aa1b29 100644 --- a/libfobos.pc.in +++ b/libfobos.pc.in @@ -1,7 +1,7 @@ prefix=@CMAKE_INSTALL_PREFIX@ exec_prefix=${prefix} libdir=${exec_prefix}/@CMAKE_INSTALL_LIBDIR@ -includedir=${prefix}/include +includedir=@includedir@ Name: libfobos Description: RigExpert Fobos SDR Library From 68653967c178be97039b3105e8e1af58d95684ea Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sun, 10 May 2026 23:06:02 -0700 Subject: [PATCH 06/11] modified .gitignore --- .gitignore | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 7a06271..635c29f 100644 --- a/.gitignore +++ b/.gitignore @@ -27,7 +27,7 @@ install-sh stamp-h1 libtool Doxyfile - +.DS_Store .tarball-version .version From 3418d03ea7f60daaa3f032444c39e9e35d0b772e Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sun, 17 May 2026 20:09:38 -0400 Subject: [PATCH 07/11] clean out deadwood; install udev rules --- debian/README.Debian.ex | 6 ------ debian/README.source.ex | 9 -------- debian/control | 9 +------- debian/fobos-udev.install | 3 --- debian/libfobos0.install | 1 + debian/postinst.ex | 39 ---------------------------------- debian/postrm.ex | 37 -------------------------------- debian/preinst.ex | 35 ------------------------------ debian/prerm.ex | 38 --------------------------------- debian/salsa-ci.yml.ex | 10 --------- debian/upstream.ex/metadata.ex | 10 --------- debian/watch.ex | 37 -------------------------------- 12 files changed, 2 insertions(+), 232 deletions(-) delete mode 100644 debian/README.Debian.ex delete mode 100644 debian/README.source.ex delete mode 100644 debian/fobos-udev.install delete mode 100644 debian/postinst.ex delete mode 100644 debian/postrm.ex delete mode 100644 debian/preinst.ex delete mode 100644 debian/prerm.ex delete mode 100644 debian/salsa-ci.yml.ex delete mode 100644 debian/upstream.ex/metadata.ex delete mode 100644 debian/watch.ex diff --git a/debian/README.Debian.ex b/debian/README.Debian.ex deleted file mode 100644 index c3a6f5c..0000000 --- a/debian/README.Debian.ex +++ /dev/null @@ -1,6 +0,0 @@ -libfobos for Debian ------------------- - - - - -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 diff --git a/debian/README.source.ex b/debian/README.source.ex deleted file mode 100644 index 8dd4bb0..0000000 --- a/debian/README.source.ex +++ /dev/null @@ -1,9 +0,0 @@ -libfobos for Debian ------------------- - - - - - - -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 diff --git a/debian/control b/debian/control index a6ff5f0..f96c80c 100644 --- a/debian/control +++ b/debian/control @@ -28,11 +28,4 @@ Depends: ${shlibs:Depends}, ${misc:Depends}, Description: RigExpert Fobos SDR runtime library - Runtime library for RigExpert Fobos SDR - -Package: fobos-udev -Architecture: all -Depends: ${misc:Depends}, udev -Description: udev rules for RigExpert Fobos SDR - udev rules for accessing RigExpert Fobos SDR devices. - + Runtime library for RigExpert Fobos SDR diff --git a/debian/fobos-udev.install b/debian/fobos-udev.install deleted file mode 100644 index ec939c5..0000000 --- a/debian/fobos-udev.install +++ /dev/null @@ -1,3 +0,0 @@ -# debian/fobos-udev.install -usr/lib/udev/rules.d/60-fobos-sdr.rules - diff --git a/debian/libfobos0.install b/debian/libfobos0.install index 3ddde58..ae83260 100644 --- a/debian/libfobos0.install +++ b/debian/libfobos0.install @@ -1 +1,2 @@ usr/lib/*/lib*.so.* +usr/lib/udev/rules.d/60-fobos-sdr.rules diff --git a/debian/postinst.ex b/debian/postinst.ex deleted file mode 100644 index 87a9a25..0000000 --- a/debian/postinst.ex +++ /dev/null @@ -1,39 +0,0 @@ -#!/bin/sh -# postinst script for libfobos. -# -# See: dh_installdeb(1). - -set -e - -# Summary of how this script can be called: -# * 'configure' -# * 'abort-upgrade' -# * 'abort-remove' 'in-favour' -# -# * 'abort-remove' -# * 'abort-deconfigure' 'in-favour' -# 'removing' -# -# for details, see https://www.debian.org/doc/debian-policy/ or -# the debian-policy package. - - -case "$1" in - configure) - ;; - - abort-upgrade|abort-remove|abort-deconfigure) - ;; - - *) - echo "postinst called with unknown argument '$1'" >&2 - exit 1 - ;; -esac - -# dh_installdeb will replace this with shell code automatically -# generated by other debhelper scripts. - -#DEBHELPER# - -exit 0 diff --git a/debian/postrm.ex b/debian/postrm.ex deleted file mode 100644 index 935f57f..0000000 --- a/debian/postrm.ex +++ /dev/null @@ -1,37 +0,0 @@ -#!/bin/sh -# postrm script for libfobos. -# -# See: dh_installdeb(1). - -set -e - -# Summary of how this script can be called: -# * 'remove' -# * 'purge' -# * 'upgrade' -# * 'failed-upgrade' -# * 'abort-install' -# * 'abort-install' -# * 'abort-upgrade' -# * 'disappear' -# -# for details, see https://www.debian.org/doc/debian-policy/ or -# the debian-policy package. - - -case "$1" in - purge|remove|upgrade|failed-upgrade|abort-install|abort-upgrade|disappear) - ;; - - *) - echo "postrm called with unknown argument '$1'" >&2 - exit 1 - ;; -esac - -# dh_installdeb will replace this with shell code automatically -# generated by other debhelper scripts. - -#DEBHELPER# - -exit 0 diff --git a/debian/preinst.ex b/debian/preinst.ex deleted file mode 100644 index 68ef927..0000000 --- a/debian/preinst.ex +++ /dev/null @@ -1,35 +0,0 @@ -#!/bin/sh -# preinst script for libfobos. -# -# See: dh_installdeb(1). - -set -e - -# Summary of how this script can be called: -# * 'install' -# * 'install' -# * 'upgrade' -# * 'abort-upgrade' -# for details, see https://www.debian.org/doc/debian-policy/ or -# the debian-policy package. - - -case "$1" in - install|upgrade) - ;; - - abort-upgrade) - ;; - - *) - echo "preinst called with unknown argument '$1'" >&2 - exit 1 - ;; -esac - -# dh_installdeb will replace this with shell code automatically -# generated by other debhelper scripts. - -#DEBHELPER# - -exit 0 diff --git a/debian/prerm.ex b/debian/prerm.ex deleted file mode 100644 index 1482ed0..0000000 --- a/debian/prerm.ex +++ /dev/null @@ -1,38 +0,0 @@ -#!/bin/sh -# prerm script for libfobos. -# -# See: dh_installdeb(1). - -set -e - -# Summary of how this script can be called: -# * 'remove' -# * 'upgrade' -# * 'failed-upgrade' -# * 'remove' 'in-favour' -# * 'deconfigure' 'in-favour' -# 'removing' -# -# for details, see https://www.debian.org/doc/debian-policy/ or -# the debian-policy package. - - -case "$1" in - remove|upgrade|deconfigure) - ;; - - failed-upgrade) - ;; - - *) - echo "prerm called with unknown argument '$1'" >&2 - exit 1 - ;; -esac - -# dh_installdeb will replace this with shell code automatically -# generated by other debhelper scripts. - -#DEBHELPER# - -exit 0 diff --git a/debian/salsa-ci.yml.ex b/debian/salsa-ci.yml.ex deleted file mode 100644 index 11a64c6..0000000 --- a/debian/salsa-ci.yml.ex +++ /dev/null @@ -1,10 +0,0 @@ -# For more information on what jobs are run see: -# https://salsa.debian.org/salsa-ci-team/pipeline -# -# To enable the jobs, go to your repository (at salsa.debian.org) -# and click over Settings > CI/CD > Expand (in General pipelines). -# In "CI/CD configuration file" write debian/salsa-ci.yml and click -# in "Save Changes". The CI tests will run after the next commit. ---- -include: - - https://salsa.debian.org/salsa-ci-team/pipeline/raw/master/recipes/debian.yml diff --git a/debian/upstream.ex/metadata.ex b/debian/upstream.ex/metadata.ex deleted file mode 100644 index 774e657..0000000 --- a/debian/upstream.ex/metadata.ex +++ /dev/null @@ -1,10 +0,0 @@ -# Example file for upstream/metadata. -# See https://wiki.debian.org/UpstreamMetadata for more info/fields. -# Below an example based on a github project. - -# Bug-Database: https://github.com//libfobos/issues -# Bug-Submit: https://github.com//libfobos/issues/new -# Changelog: https://github.com//libfobos/blob/master/CHANGES -# Documentation: https://github.com//libfobos/wiki -# Repository-Browse: https://github.com//libfobos -# Repository: https://github.com//libfobos.git diff --git a/debian/watch.ex b/debian/watch.ex deleted file mode 100644 index 077e533..0000000 --- a/debian/watch.ex +++ /dev/null @@ -1,37 +0,0 @@ -# Example watch control file for uscan. -# Rename this file to "watch" and then you can run the "uscan" command -# to check for upstream updates and more. -# See uscan(1) for format. - -# Compulsory line, this is a version 4 file. -version=4 - -# PGP signature mangle, so foo.tar.gz has foo.tar.gz.sig. -#opts="pgpsigurlmangle=s%$%.sig%" - -# HTTP site (basic). -#http://example.com/downloads.html \ -# files/libfobos-([\d\.]+)\.tar\.gz - -# Uncomment to examine an FTP server. -#ftp://ftp.example.com/pub/libfobos-(.*)\.tar\.gz - -# SourceForge hosted projects. -#http://sf.net/libfobos/ libfobos-(.*)\.tar\.gz - -# GitHub hosted projects. -#opts="filenamemangle=s%(?:.*?)?v?(@ANY_VERSION@@ARCHIVE_EXT@)%@PACKAGE@-$1%" \ -# https://github.com///tags \ -# (?:.*?/)v?@ANY_VERSION@@ARCHIVE_EXT@ - -# GitLab hosted projects. -#opts="filenamemangle=s%(?:.*?)?v?(@ANY_VERSION@@ARCHIVE_EXT@)%@PACKAGE@-$1%" \ -# https://gitlab.com///-/tags \ -# archive/v?@ANY_VERSION@/-v?\d\S*@ARCHIVE_EXT@ - -# PyPI. -#https://pypi.debian.net/libfobos/libfobos-(.+)\.(?:zip|tgz|tbz|txz|(?:tar\.(?:gz|bz2|xz))) - -# Direct Git. -#opts="mode=git" http://git.example.com/libfobos.git \ -# refs/tags/v([\d\.]+) From 9713f8e6059138907eafab93895cd82fc9732de9 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Sun, 17 May 2026 20:44:32 -0400 Subject: [PATCH 08/11] add to .gitignore --- .gitignore | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.gitignore b/.gitignore index 635c29f..d220206 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,6 @@ +\#*\# +.\#* +*~undo-tree~ build/ Makefile Makefile.in From 32fa87ee2946911aa39a873d48797f748cd68c37 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Thu, 28 May 2026 23:59:33 -0700 Subject: [PATCH 09/11] delete some more useless debian files --- debian/gbp.conf.ex | 56 -------------------------------------------- debian/source/format | 1 - 2 files changed, 57 deletions(-) delete mode 100644 debian/gbp.conf.ex delete mode 100644 debian/source/format diff --git a/debian/gbp.conf.ex b/debian/gbp.conf.ex deleted file mode 100644 index 0627f18..0000000 --- a/debian/gbp.conf.ex +++ /dev/null @@ -1,56 +0,0 @@ -# See gbp(1) provided by git-buildpackage package for an explanation of each -# option or browse https://manpages.debian.org/unstable/git-buildpackage/gbp.1.en.html - -[DEFAULT] -# DEP-14 format. Other naming convention are available, -# see DEP-14 for more details. -debian-branch = debian/latest -upstream-branch = upstream/latest - -# Enable pristine-tar to exactly reproduce orig tarballs -pristine-tar = True - -# The Debian packaging git repository may also host actual upstream tags and -# branches, typically named 'main' or 'master'. Configure the upstream tag -# format below, so that `gbp import-orig` will run correctly, and link tarball -# import branch (`upstream/latest`) with the equivalent upstream release tag, -# showing a complete audit trail of what upstream released and what was imported -# into Debian. -#upstream-vcs-tag = %(version%~%.)s - -# If upstream publishes tarball signatures, git-buildpackage will by default -# import and use the them. Change this to 'on' to make 'gbp import-orig' abort -# if the signature is not found or is not valid. -#upstream-signatures = on - -# Ensure the Debian maintainer signs git tags automatically. -#sign-tags = True - -# Ease dropping / adding patches. -#patch-numbers = False - -# Group debian/changelog entries with the same "[ Author ]" instead of making -# multiple ones for the same author. -#multimaint-merge = True - -# Automatically open a new changelog entry about the new upstream release, but -# do not commit it, as the 'gbp dch' still needs to run and list all commits -# based on when the debian/changelog last was updated in a git commit. -#postimport = dch -v %(version)s "New upstream release" - -# Ensure a human always reviews all the debian/changelog entries. -#spawn-editor = always - -# No need to confirm package name or version at any time, git-buildpackage -# always gets it right. -#interactive = False - -# Ensure we always target Debian on Debian branches. -#dch-opt = --vendor=debian - -# If this package ever needs to be maintained for Ubuntu, remember to override -# the branch, tag and commit messages. -#debian-branch = ubuntu/24.04-noble -#debian-tag = ubuntu/%(version)s -#debian-tag-msg = %(pkg)s Ubuntu release %(version)s -#dch-opt = --vendor=ubuntu diff --git a/debian/source/format b/debian/source/format deleted file mode 100644 index 163aaf8..0000000 --- a/debian/source/format +++ /dev/null @@ -1 +0,0 @@ -3.0 (quilt) From 3dbaab3b74ededa926a91b91cecdb89a473d1523 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Fri, 29 May 2026 00:02:06 -0700 Subject: [PATCH 10/11] remove debian cruft --- debian/changelog | 7 +++--- debian/gbp.conf.ex | 56 -------------------------------------------- debian/source/format | 1 - 3 files changed, 4 insertions(+), 60 deletions(-) delete mode 100644 debian/gbp.conf.ex delete mode 100644 debian/source/format diff --git a/debian/changelog b/debian/changelog index 35727c5..14b1a1f 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,5 +1,6 @@ -libfobos (2.4.1-1) UNRELEASED; urgency=medium +libfobos (2.4.1-3) trixie; urgency=medium - * Initial release. (Closes: #nnnn) + * clean out deadwood + * install udev rules as part of library not separate package - -- Phil Karn Sat, 02 May 2026 15:47:24 -0700 + -- Phil Karn Sun, 17 May 2026 17:11:55 -0700 diff --git a/debian/gbp.conf.ex b/debian/gbp.conf.ex deleted file mode 100644 index 0627f18..0000000 --- a/debian/gbp.conf.ex +++ /dev/null @@ -1,56 +0,0 @@ -# See gbp(1) provided by git-buildpackage package for an explanation of each -# option or browse https://manpages.debian.org/unstable/git-buildpackage/gbp.1.en.html - -[DEFAULT] -# DEP-14 format. Other naming convention are available, -# see DEP-14 for more details. -debian-branch = debian/latest -upstream-branch = upstream/latest - -# Enable pristine-tar to exactly reproduce orig tarballs -pristine-tar = True - -# The Debian packaging git repository may also host actual upstream tags and -# branches, typically named 'main' or 'master'. Configure the upstream tag -# format below, so that `gbp import-orig` will run correctly, and link tarball -# import branch (`upstream/latest`) with the equivalent upstream release tag, -# showing a complete audit trail of what upstream released and what was imported -# into Debian. -#upstream-vcs-tag = %(version%~%.)s - -# If upstream publishes tarball signatures, git-buildpackage will by default -# import and use the them. Change this to 'on' to make 'gbp import-orig' abort -# if the signature is not found or is not valid. -#upstream-signatures = on - -# Ensure the Debian maintainer signs git tags automatically. -#sign-tags = True - -# Ease dropping / adding patches. -#patch-numbers = False - -# Group debian/changelog entries with the same "[ Author ]" instead of making -# multiple ones for the same author. -#multimaint-merge = True - -# Automatically open a new changelog entry about the new upstream release, but -# do not commit it, as the 'gbp dch' still needs to run and list all commits -# based on when the debian/changelog last was updated in a git commit. -#postimport = dch -v %(version)s "New upstream release" - -# Ensure a human always reviews all the debian/changelog entries. -#spawn-editor = always - -# No need to confirm package name or version at any time, git-buildpackage -# always gets it right. -#interactive = False - -# Ensure we always target Debian on Debian branches. -#dch-opt = --vendor=debian - -# If this package ever needs to be maintained for Ubuntu, remember to override -# the branch, tag and commit messages. -#debian-branch = ubuntu/24.04-noble -#debian-tag = ubuntu/%(version)s -#debian-tag-msg = %(pkg)s Ubuntu release %(version)s -#dch-opt = --vendor=ubuntu diff --git a/debian/source/format b/debian/source/format deleted file mode 100644 index 163aaf8..0000000 --- a/debian/source/format +++ /dev/null @@ -1 +0,0 @@ -3.0 (quilt) From 9c5e60fbeb09dca059f21b0ec4da7f33ce7e2ae0 Mon Sep 17 00:00:00 2001 From: Phil Karn Date: Fri, 29 May 2026 00:05:52 -0700 Subject: [PATCH 11/11] ignore debian build subdirectories --- .gitignore | 1 + debian/.gitignore | 3 +++ 2 files changed, 4 insertions(+) diff --git a/.gitignore b/.gitignore index d220206..4d11a8c 100644 --- a/.gitignore +++ b/.gitignore @@ -43,3 +43,4 @@ CMakeCache.txt */CMakeFiles CMakeFiles *.cmake +obj-x86_64-linux-gnu/ diff --git a/debian/.gitignore b/debian/.gitignore index 525c2f1..bff7e66 100644 --- a/debian/.gitignore +++ b/debian/.gitignore @@ -3,3 +3,6 @@ /debhelper-build-stamp /files /tmp/ +fobos-udev/ +libfobos-dev/ +libfobos0/