File 0000-remove-vendoring.patch of Package rpi-imager

diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 68d84805..01ed204f 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -40,27 +40,6 @@ set(CMAKE_CXX_STANDARD_REQUIRED ON)
 # You _must_ set your Qt6 root for the build to progress.
 set(Qt6_ROOT "/opt/Qt/6.9.0/gcc_arm64" CACHE PATH "Your Qt6 root path")
 
-if (WIN32)
-    set(MINGW64_ROOT "" CACHE PATH "Your MinGW64 root path, likely provided by QtCreator")
-    set(IMAGER_SIGNED_APP OFF CACHE BOOL "Sign Imager and its installer as part of the build. Requires a valid Code Signing certificate.")
-endif()
-
-if (APPLE)
-    set(IMAGER_SIGNED_APP OFF CACHE BOOL "Perform signing of the Imager .app as part of the build")
-    set(IMAGER_SIGNING_IDENTITY "" CACHE STRING "The Developer Identity to use for signing.")
-    set(IMAGER_NOTARIZE_APP OFF CACHE BOOL "Perform notarization of the Imager .dmg as part of the build")
-    set(IMAGER_NOTARIZE_KEYCHAIN_PROFILE "" CACHE STRING "The name of the Keychain item containing your notarization credentials")
-
-    # Per CMake Bug 21918, if you do not use the following block, CMake will automatically include homebrew libraries.
-    # This is undesirable, as on macOS/Apple Silicon, you may find newer versions of Qt will pull in new dependencies
-    # - breaking your x86_64 build prematurely. Regardless, this is desirable behaviour to make the build more predictable.
-    set(CMAKE_IGNORE_PATH)
-    foreach(_prefix /sw /opt/local /usr/local /opt/homebrew)
-      list(APPEND CMAKE_IGNORE_PATH ${_prefix}/bin ${_prefix}/include ${_prefix}/lib)
-      list(APPEND CMAKE_SYSTEM_IGNORE_PATH ${_prefix}/bin ${_prefix}/include ${_prefix}/lib)
-    endforeach()
-endif(APPLE)
-
 # Bundled code will occasionally use identical options - eg, BUILD_TESTING.
 set(BUILD_TESTING OFF)
 set(BUILD_STATIC_LIBS ON)
@@ -69,453 +48,25 @@ set(BUILD_SHARED_LIBS OFF)
 include(FetchContent)
 
 # Bundled liblzma
-set(LIBLZMA_VERSION "5.8.1")
-FetchContent_Declare(xz
-    GIT_REPOSITORY https://github.com/tukaani-project/xz.git
-    GIT_TAG v${LIBLZMA_VERSION}
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-set(XZ_MICROLZMA_DECODER OFF CACHE BOOL "" FORCE)
-set(XZ_MICROLZMA_ENCODER OFF CACHE BOOL "" FORCE)
-set(XZ_LZIP_DECODER OFF CACHE BOOL "" FORCE)
-set(XZ_ENABLE_SANDBOX OFF CACHE BOOL "" FORCE)
-set(XZ_BUILD_SHARED_LIBS OFF CACHE BOOL "" FORCE)
-set(XZ_ENABLE_DOXYGEN OFF CACHE BOOL "" FORCE)
-set(XZ_DECODERS
-    lzma1
-    lzma2
-    delta
-)
-set(XZ_ENCODERS
-    lzma1
-    lzma2
-    delta
-)
-set(CREATE_LZMA_SYMLINKS OFF CACHE BOOL "" FORCE)
-set(CREATE_XZ_SYMLINKS OFF CACHE BOOL "" FORCE)
-FetchContent_GetProperties(xz)
-if(NOT xz_POPULATED)
-    FetchContent_Populate(xz)
-    add_subdirectory(${xz_SOURCE_DIR} ${xz_BINARY_DIR} EXCLUDE_FROM_ALL)
+find_package(LibLZMA 5.8.1 REQUIRED)
+if(LIBLZMA_FOUND)
+    set(EXTRALIBS ${EXTRALIBS} LibLZMA::LibLZMA)
 endif()
-unset(XZ_MICROLZMA_DECODER)
-unset(XZ_MICROLZMA_ENCODER)
-unset(XZ_LZIP_DECODER)
-unset(XZ_ENABLE_SANDBOX)
-unset(XZ_BUILD_SHARED_LIBS)
-unset(XZ_ENABLE_DOXYGEN)
-unset(CREATE_LZMA_SYMLINKS)
-unset(CREATE_XZ_SYMLINKS)
-set(LIBLZMA_FOUND true CACHE BOOL "" FORCE)
-set(LIBLZMA_INCLUDE_DIR ${xz_SOURCE_DIR}/src/liblzma/api CACHE PATH "" FORCE)
-set(LIBLZMA_INCLUDE_DIRS ${xz_SOURCE_DIR}/src/liblzma/api CACHE PATH "" FORCE)
-set(LIBLZMA_LIBRARY liblzma CACHE FILEPATH "" FORCE)
-set(LIBLZMA_LIBRARIES ${xz_BINARY_DIR}/liblzma.a CACHE FILEPATH "" FORCE)
-set(LIBLZMA_HAS_AUTO_DECODER true CACHE BOOL "" FORCE)
-set(LIBLZMA_HAS_EASY_ENCODER true CACHE BOOL "" FORCE)
-set(LIBLZMA_HAS_LZMA_PRESET true CACHE BOOL "" FORCE)
 
 # Bundled zstd
-set(ZSTD_VERSION "1.5.7")
-FetchContent_Declare(zstd
-    GIT_REPOSITORY https://github.com/facebook/zstd.git
-    GIT_TAG v${ZSTD_VERSION}
-    SOURCE_SUBDIR build/cmake
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-set(ZSTD_BUILD_PROGRAMS OFF CACHE BOOL "" FORCE)
-set(ZSTD_BUILD_SHARED OFF CACHE BOOL "" FORCE)
-set(ZSTD_BUILD_STATIC ON CACHE BOOL "" FORCE)
-set(ZSTD_BUILD_TESTS OFF CACHE BOOL "" FORCE)
-set(ZSTD_BUILD_DICTBUILDER OFF CACHE BOOL "" FORCE)
-FetchContent_GetProperties(zstd)
-if(NOT zstd_POPULATED)
-    FetchContent_Populate(zstd)
-    add_subdirectory(${zstd_SOURCE_DIR}/build/cmake ${zstd_BINARY_DIR} EXCLUDE_FROM_ALL)
-endif()
-unset(ZSTD_BUILD_PROGRAMS)
-unset(ZSTD_BUILD_SHARED)
-unset(ZSTD_BUILD_STATIC)
-unset(ZSTD_BUILD_TESTS)
-unset(ZSTD_BUILD_DICTBUILDER)
-set(ZSTD_FOUND true CACHE BOOL "" FORCE)
-set(Zstd_VERSION ${ZSTD_VERSION} CACHE STRING "" FORCE)
-set(Zstd_INCLUDE_DIR ${CMAKE_CURRENT_BINARY_DIR}/_deps/zstd-src/lib CACHE PATH "" FORCE)
-set(ZSTD_INCLUDE_DIR ${CMAKE_CURRENT_BINARY_DIR}/_deps/zstd-src/lib CACHE PATH "" FORCE)
-set(Zstd_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/_deps/zstd-src/lib CACHE PATH "" FORCE)
-set(ZSTD_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/_deps/zstd-src/lib CACHE PATH "" FORCE)
-set(Zstd_LIBRARIES libzstd_static CACHE FILEPATH "" FORCE)
-set(ZSTD_LIBRARIES libzstd_static CACHE FILEPATH "" FORCE)
-set(ZSTD_LIBRARY ${CMAKE_CURRENT_BINARY_DIR}/_deps/zstd-build/lib/libzstd.a CACHE FILEPATH "" FORCE)
-
-# Remote nghttp2
-set(NGHTTP2_VERSION "1.66.0")
-FetchContent_Declare(nghttp2
-    GIT_REPOSITORY https://github.com/nghttp2/nghttp2.git
-    GIT_TAG        v${NGHTTP2_VERSION}
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-set(BUILD_EXAMPLES OFF)
-set(ENABLE_LIB_ONLY ON)
-set(ENABLE_FAILMALLOC OFF)
-FetchContent_GetProperties(nghttp2)
-if(NOT nghttp2_POPULATED)
-    FetchContent_Populate(nghttp2)
-    add_subdirectory(${nghttp2_SOURCE_DIR} ${nghttp2_BINARY_DIR} EXCLUDE_FROM_ALL)
-endif()
-unset(ENABLE_LIB_ONLY)
-unset(ENABLE_FAILMALLOC)
-unset(BUILD_EXAMPLES)
-set(NGHTTP2_LIBRARIES nghttp2_static CACHE FILEPATH "" FORCE)
-set(NGHTTP2_LIBRARY nghttp2_static CACHE FILEPATH "" FORCE)
-set(NGHTTP2_INCLUDE_DIR ${nghttp2_SOURCE_DIR}/lib CACHE PATH "" FORCE)
-set(NGHTTP2_INCLUDE_DIRS ${nghttp2_SOURCE_DIR}/lib CACHE PATH "" FORCE)
-set(NGHTTP2_FOUND true CACHE BOOL "" FORCE)
-
+find_package(zstd 1.5.7 REQUIRED)
 
 # Bundled zlib
-set(ZLIB_VERSION "1.4.1.1")
-set(ZLIB_BUILD_EXAMPLES OFF CACHE BOOL "" FORCE)
-set(ZLIB_BUILD_SHARED OFF CACHE BOOL "" FORCE)
-set(ZLIB_BUILD_STATIC ON CACHE BOOL "" FORCE)
-set(ZLIB_BUILD_TESTS OFF CACHE BOOL "" FORCE)
-set(SKIP_INSTALL_ALL ON CACHE BOOL "" FORCE)
-FetchContent_Declare(zlib
-    GIT_REPOSITORY https://github.com/madler/zlib.git
-    GIT_TAG 5a82f71ed1dfc0bec044d9702463dbdf84ea3b71 # v1.4.1.1, as of 27/05/2025
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-FetchContent_GetProperties(zlib)
-if(NOT zlib_POPULATED)
-    FetchContent_Populate(zlib)
-    add_subdirectory(${zlib_SOURCE_DIR} ${zlib_BINARY_DIR} EXCLUDE_FROM_ALL)
-endif()
-unset(ZLIB_BUILD_EXAMPLES)
-unset(ZLIB_BUILD_SHARED)
-unset(ZLIB_BUILD_STATIC)
-unset(ZLIB_BUILD_TESTS)
-unset(SKIP_INSTALL_ALL)
-# Set zlib variables that libarchive's CMake will use
-set(ZLIB_USE_STATIC_LIBS ON CACHE BOOL "" FORCE) # This is to help FindZlib.cmake find the static library over the shared one
-set(ZLIB_ROOT ${zlib_SOURCE_DIR} CACHE PATH "" FORCE)
-
-# On Windows with MinGW, zlib builds with .a extension, not .lib
-# Set the correct library path before find_package
-if (WIN32 AND CMAKE_COMPILER_IS_GNUCXX)
-    set(ZLIB_LIBRARY ${zlib_BINARY_DIR}/libzlibstatic.a CACHE FILEPATH "" FORCE)
-    set(ZLIB_LIBRARIES ${zlib_BINARY_DIR}/libzlibstatic.a CACHE STRING "" FORCE)
-else()
-    set(ZLIB_LIBRARY ${zlib_BINARY_DIR}/libz.a CACHE FILEPATH "" FORCE)
-    set(ZLIB_LIBRARIES ${zlib_BINARY_DIR}/libz.a CACHE STRING "" FORCE)
-endif()
-
-# Since we're building zlib ourselves with EXCLUDE_FROM_ALL, we don't need find_package
-# Instead, we'll create the ZLIB::ZLIB target manually and set all required variables
-set(ZLIB_INCLUDE_DIR ${zlib_SOURCE_DIR} CACHE PATH "" FORCE)
-set(ZLIB_INCLUDE_DIRS ${zlib_SOURCE_DIR} CACHE PATH "" FORCE)
-
-# Create ZLIB::ZLIB target manually since we're not using find_package
-# Set zlib variables that other packages expect
-set(ZLIB_FOUND TRUE CACHE BOOL "" FORCE)
-add_library(ZLIB::ZLIB STATIC IMPORTED)
-if (WIN32 AND CMAKE_COMPILER_IS_GNUCXX)
-    set_target_properties(ZLIB::ZLIB PROPERTIES
-        IMPORTED_LOCATION "${zlib_BINARY_DIR}/libzlibstatic.a"
-        INTERFACE_INCLUDE_DIRECTORIES "${zlib_SOURCE_DIR};${zlib_BINARY_DIR}"
-    )
-    add_dependencies(ZLIB::ZLIB zlibstatic)
-else()
-    set_target_properties(ZLIB::ZLIB PROPERTIES
-        IMPORTED_LOCATION "${zlib_BINARY_DIR}/libz.a"
-        INTERFACE_INCLUDE_DIRECTORIES "${zlib_SOURCE_DIR};${zlib_BINARY_DIR}"
-    )
-    add_dependencies(ZLIB::ZLIB zlibstatic)
+find_package(ZLIB REQUIRED)
+if(ZLIB_FOUND)
+    set(EXTRALIBS ${EXTRALIBS} ZLIB::ZLIB)
 endif()
 
-# Debug output
-message(STATUS "ZLIB_LIBRARY set to: ${ZLIB_LIBRARY}")
-message(STATUS "ZLIB_LIBRARIES set to: ${ZLIB_LIBRARIES}")
-message(STATUS "ZLIB_INCLUDE_DIRS set to: ${ZLIB_INCLUDE_DIRS}")
-
 # Bundled libarchive
-
-set(ENABLE_WERROR OFF CACHE BOOL "")
-set(ENABLE_INSTALL OFF CACHE BOOL "")
-set(ENABLE_TEST OFF CACHE BOOL "")
-set(ENABLE_CNG OFF CACHE BOOL "")
-set(ENABLE_MBEDTLS OFF CACHE BOOL "")
-set(ENABLE_NETTLE OFF CACHE BOOL "")
-set(ENABLE_OPENSSL OFF CACHE BOOL "")
-# Configure libarchive with explicit zlib support
-set(ENABLE_ZLIB ON CACHE BOOL "")
-set(ENABLE_BZip2 OFF CACHE BOOL "")
-set(ENABLE_LZ4 OFF CACHE BOOL "")
-set(ENABLE_LZO OFF CACHE BOOL "")
-set(ENABLE_LIBB2 OFF CACHE BOOL "")
-set(ENABLE_LIBXML2 OFF CACHE BOOL "")
-set(ENABLE_EXPAT OFF CACHE BOOL "")
-set(ENABLE_PCREPOSIX OFF CACHE BOOL "")
-set(ENABLE_PCRE2POSIX OFF CACHE BOOL "")
-set(ENABLE_LIBGCC OFF CACHE BOOL "")
-set(ENABLE_TAR OFF CACHE BOOL "")
-set(ENABLE_CPIO OFF CACHE BOOL "")
-set(ENABLE_CAT OFF CACHE BOOL "")
-set(BUILD_SHARED_LIBS OFF CACHE BOOL "")
-set(ARCHIVE_BUILD_STATIC_LIBS ON CACHE BOOL "")
-set(ARCHIVE_BUILD_EXAMPLES OFF CACHE BOOL "")
-set(ENABLE_ZSTD ON CACHE BOOL "")
-set(POSIX_REGEX_LIB "libc" CACHE STRING "" FORCE)
-set(LIBARCHIVE_VERSION "3.8.1")
-
-# Create a patch script to fix ZSTD detection in libarchive
-set(LIBARCHIVE_PATCH_FILE "${CMAKE_CURRENT_BINARY_DIR}/libarchive_zstd_patch.cmake")
-file(WRITE ${LIBARCHIVE_PATCH_FILE} "
-# Read the original CMakeLists.txt
-file(READ \"\${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt\" CONTENT)
-
-# Find the start and end of the ZSTD section
-string(FIND \"\${CONTENT}\" \"IF(ZSTD_FOUND)\" ZSTD_START)
-string(FIND \"\${CONTENT}\" \"MARK_AS_ADVANCED(CLEAR ZSTD_INCLUDE_DIR)\" ZSTD_END)
-
-if(ZSTD_START GREATER -1 AND ZSTD_END GREATER -1)
-    # Calculate positions
-    math(EXPR ZSTD_END \"\${ZSTD_END} + 40\") # Length of \"MARK_AS_ADVANCED(CLEAR ZSTD_INCLUDE_DIR)\"
-    
-    # Extract parts before and after the ZSTD section
-    string(SUBSTRING \"\${CONTENT}\" 0 \${ZSTD_START} BEFORE_ZSTD)
-    string(SUBSTRING \"\${CONTENT}\" \${ZSTD_END} -1 AFTER_ZSTD)
-    
-    # Create the new ZSTD section
-    set(NEW_ZSTD_SECTION \"IF(ZSTD_FOUND)
-  SET(HAVE_ZSTD_H 1)
-  INCLUDE_DIRECTORIES(\\\${ZSTD_INCLUDE_DIR})
-  LIST(APPEND ADDITIONAL_LIBS \\\${ZSTD_LIBRARY})
-  
-  # Check if ZSTD variables were provided externally (indicating static build)
-  get_property(ZSTD_LIB_IS_CACHE CACHE ZSTD_LIBRARY PROPERTY TYPE)
-  get_property(ZSTD_INC_IS_CACHE CACHE ZSTD_INCLUDE_DIR PROPERTY TYPE)
-  if(ZSTD_LIB_IS_CACHE AND ZSTD_INC_IS_CACHE)
-    # Skip function checks for static builds and assume all functions are available
-    message(STATUS \\\"Using provided ZSTD library: \\\${ZSTD_LIBRARY}\\\")
-    SET(HAVE_LIBZSTD 1)
-    SET(HAVE_ZSTD_compressStream 1)
-    SET(HAVE_ZSTD_minCLevel 1)
-  else()
-    # Original function checks for dynamic builds
-    CMAKE_PUSH_CHECK_STATE()
-    SET(CMAKE_REQUIRED_LIBRARIES \\\${ZSTD_LIBRARY})
-    SET(CMAKE_REQUIRED_INCLUDES \\\${ZSTD_INCLUDE_DIR})
-    CHECK_FUNCTION_EXISTS(ZSTD_decompressStream HAVE_LIBZSTD)
-    CHECK_FUNCTION_EXISTS(ZSTD_compressStream HAVE_ZSTD_compressStream)
-    CHECK_FUNCTION_EXISTS(ZSTD_minCLevel HAVE_ZSTD_minCLevel)
-    CMAKE_POP_CHECK_STATE()
-  endif()
-ENDIF(ZSTD_FOUND)
-MARK_AS_ADVANCED(CLEAR ZSTD_INCLUDE_DIR)\")
-    
-    # Combine the parts
-    set(NEW_CONTENT \"\${BEFORE_ZSTD}\${NEW_ZSTD_SECTION}\")
-    
-    # Write the modified content back
-    file(WRITE \"\${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt\" \"\${NEW_CONTENT}\${AFTER_ZSTD}\")
-    message(STATUS \"Patched libarchive CMakeLists.txt for static ZSTD support\")
-else()
-    message(WARNING \"Could not find ZSTD section in libarchive CMakeLists.txt\")
-endif()
-")
-
-FetchContent_Declare(libarchive
-    GIT_REPOSITORY https://github.com/libarchive/libarchive.git
-    GIT_TAG v${LIBARCHIVE_VERSION}
-    PATCH_COMMAND ${CMAKE_COMMAND} -P ${LIBARCHIVE_PATCH_FILE}
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-FetchContent_GetProperties(libarchive)
-if(NOT libarchive_POPULATED)
-    FetchContent_Populate(libarchive)
-    add_subdirectory(${libarchive_SOURCE_DIR} ${libarchive_BINARY_DIR} EXCLUDE_FROM_ALL)
-endif()
-
-# Ensure libarchive is built after zlib
-if (TARGET archive_static AND TARGET ZLIB::ZLIB)
-    add_dependencies(archive_static ZLIB::ZLIB)
-endif()
-
-unset(POSIX_REGEX_LIB)
-unset(ENABLE_WERROR)
-unset(ENABLE_INSTALL)
-unset(ENABLE_TEST)
-unset(ENABLE_CNG)
-unset(ENABLE_MBEDTLS)
-unset(ENABLE_NETTLE)
-unset(ENABLE_OPENSSL)
-unset(ENABLE_ZLIB)
-unset(ENABLE_BZip2)
-unset(ENABLE_LZ4)
-unset(ENABLE_LZO)
-unset(ENABLE_LIBB2)
-unset(ENABLE_LIBXML2)
-unset(ENABLE_EXPAT)
-unset(ENABLE_PCREPOSIX)
-unset(ENABLE_PCRE2POSIX)
-unset(ENABLE_LIBGCC)
-unset(ENABLE_TAR)
-unset(ENABLE_CPIO)
-unset(ENABLE_CAT)
-unset(ARCHIVE_BUILD_SHARED_LIBS)
-unset(ENABLE_ZSTD)
-set(LibArchive_FOUND true CACHE BOOL "" FORCE)
-set(LibArchive_LIBRARIES archive_static CACHE FILEPATH "" FORCE)
-set(LibArchive_INCLUDE_DIR ${libarchive_SOURCE_DIR}/libarchive CACHE PATH "" FORCE)
-set(LibArchive_INCLUDE_DIRS ${libarchive_SOURCE_DIR}/libarchive CACHE PATH "" FORCE)
+find_package(LibArchive 3.8.1 REQUIRED)
 
 # Bundled libcurl
-set(CURL_VERSION "8.14.1")
-string(REPLACE "." "_" CURL_TAG ${CURL_VERSION})
-FetchContent_Declare(curl
-    GIT_REPOSITORY https://github.com/curl/curl.git
-    GIT_TAG curl-${CURL_TAG}
-    ${USE_OVERRIDE_FIND_PACKAGE}
-)
-set(BUILD_CURL_EXE OFF CACHE BOOL "" FORCE)
-set(BUILD_LIBCURL_DOCS OFF CACHE BOOL "" FORCE)
-set(BUILD_MISC_DOCS OFF CACHE BOOL "" FORCE)
-set(ENABLE_CURL_MANUAL OFF CACHE BOOL "" FORCE)
-set(BUILD_EXAMPLES OFF CACHE BOOL "" FORCE)
-set(CURL_USE_LIBPSL OFF CACHE BOOL "" FORCE)
-set(CURL_USE_LIBSSH2 OFF CACHE BOOL "" FORCE)
-set(CURL_DISABLE_ALTSVC ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_BASIC_AUTH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_BEARER_AUTH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_DIGEST_AUTH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_KERBEROS_AUTH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_NEGOTIATE_AUTH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_NTLM ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_AWS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_DICT ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_FILE ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_FTP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_GOPHER ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_IMAP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_LDAPS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_MQTT ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_POP3 ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_RTSP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SMB ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SMTP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_TELNET ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_TFTP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_DOH ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_HSTS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_IPFS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_WEBSOCKETS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_PROXY ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_QUIC ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_FORM_API ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_MIME ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_BINDLOCAL ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_GETOPTIONS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_HEADERS_API ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_LIBCURL_OPTION ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_NETRC ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_PARSEDATE ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SHA512_256 ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SHUFFLE_DNS ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SOCKETPAIR ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_SRP ON CACHE BOOL "" FORCE)
-set(CURL_DISABLE_VERBOSE_STRINGS ON CACHE BOOL "" FORCE)
-set(USE_NGHTTP2 ON CACHE BOOL "" FORCE)
-set(CURL_ZSTD ON)
-set(CURL_ENABLE_EXPORT_TARGET OFF CACHE BOOL "" FORCE)
-set(CURL_DISABLE_INSTALL ON)
-if (APPLE)
-    # TODO: SecureTransport is a deprecated API in macOS, supporting
-    #       only up to TLS v1.2. cURL has not implemented the replacement,
-    #       Network.framework, and so we will need to select an alternative.
-    #       Best recommendation: Libressl, as used by Apple in the curl binary
-    #       on macOS.
-    set(CURL_USE_SECTRANSP ON)
-    set(CURL_DEFAULT_SSL_BACKEND "secure-transport")
-    set(USE_APPLE_IDN ON)
-else()
-    if (WIN32)
-        set(CURL_USE_SCHANNEL ON)
-        set(CURL_DEFAULT_SSL_BACKEND "schannel")
-    else ()
-        set(CURL_USE_GNUTLS ON)
-        set(CURL_DEFAULT_SSL_BACKEND "gnutls")
-    endif(WIN32)
-endif(APPLE)
-
-FetchContent_GetProperties(curl)
-if(NOT curl_POPULATED)
-    FetchContent_Populate(curl)
-    add_subdirectory(${curl_SOURCE_DIR} ${curl_BINARY_DIR} EXCLUDE_FROM_ALL)
-endif()
-
-unset(BUILD_CURL_EXE)
-unset(BUILD_LIBCURL_DOCS)
-unset(BUILD_MISC_DOCS)
-unset(ENABLE_CURL_MANUAL)
-unset(BUILD_EXAMPLES)
-unset(CURL_USE_LIBPSL)
-unset(CURL_USE_LIBSSH2)
-unset(CURL_DISABLE_ALTSVC)
-unset(CURL_DISABLE_BASIC_AUTH)
-unset(CURL_DISABLE_BEARER_AUTH)
-unset(CURL_DISABLE_DIGEST_AUTH)
-unset(CURL_DISABLE_KERBEROS_AUTH)
-unset(CURL_DISABLE_NEGOTIATE_AUTH)
-unset(CURL_DISABLE_NTLM)
-unset(CURL_DISABLE_AWS)
-unset(CURL_DISABLE_DICT)
-unset(CURL_DISABLE_FILE)
-unset(CURL_DISABLE_FTP)
-unset(CURL_DISABLE_GOPHER)
-unset(CURL_DISABLE_IMAP)
-unset(CURL_DISABLE_LDAP)
-unset(CURL_DISABLE_LDAPS)
-unset(CURL_DISABLE_MQTT)
-unset(CURL_DISABLE_POP3)
-unset(CURL_DISABLE_RTSP)
-unset(CURL_DISABLE_SMB)
-unset(CURL_DISABLE_SMTP)
-unset(CURL_DISABLE_TELNET)
-unset(CURL_DISABLE_TFTP)
-unset(CURL_DISABLE_DOH)
-unset(CURL_DISABLE_HSTS)
-unset(CURL_DISABLE_IPFS)
-unset(CURL_DISABLE_WEBSOCKETS)
-unset(CURL_DISABLE_PROXY)
-unset(CURL_DISABLE_QUIC)
-unset(CURL_DISABLE_FORM_API)
-unset(CURL_DISABLE_MIME)
-unset(CURL_DISABLE_BINDLOCAL)
-unset(CURL_DISABLE_GETOPTIONS)
-unset(CURL_DISABLE_HEADERS_API)
-unset(CURL_DISABLE_LIBCURL_OPTION)
-unset(CURL_DISABLE_NETRC)
-unset(CURL_DISABLE_PARSEDATE)
-unset(CURL_DISABLE_SHA512_256)
-unset(CURL_DISABLE_SHUFFLE_DNS)
-unset(CURL_DISABLE_SOCKETPAIR)
-unset(CURL_DISABLE_SRP)
-unset(CURL_DISABLE_VERBOSE_STRINGS)
-unset(USE_NGHTTP2)
-unset(CURL_ZSTD)
-unset(CURL_ENABLE_EXPORT_TARGET)
-unset(CURL_DISABLE_INSTALL)
-unset(CURL_USE_SECTRANSP)
-unset(CURL_DEFAULT_SSL_BACKEND)
-unset(USE_APPLE_IDN)
-unset(CURL_USE_SCHANNEL)
-unset(CURL_USE_GNUTLS)
-
-set(CURL_FOUND true CACHE BOOL "" FORCE)
-set(CURL_LIBRARIES libcurl_static CACHE FILEPATH "" FORCE)
-set(CURL_INCLUDE_DIR ${curl_SOURCE_DIR}/include CACHE PATH "" FORCE)
-set(CURL_INCLUDE_DIRS ${curl_SOURCE_DIR}/include CACHE PATH "" FORCE)
+find_package(CURL 8.14.1 REQUIRED)
 
 # Adding headers explicity so they are displayed in Qt Creator
 set(HEADERS config.h imagewriter.h networkaccessmanagerfactory.h nan.h drivelistitem.h drivelistmodel.h drivelistmodelpollthread.h driveformatthread.h powersaveblocker.h cli.h
@@ -526,80 +77,22 @@ set(HEADERS config.h imagewriter.h networkaccessmanagerfactory.h nan.h drivelist
 )
 
 # Add dependencies
-if (APPLE)
-    set_source_files_properties("icons/rpi-imager.icns" PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
-    set(PLATFORM_SOURCES
-        mac/acceleratedcryptographichash_commoncrypto.cpp
-        mac/macfile.cpp
-        mac/macfile.h
-        dependencies/mountutils/src/darwin/functions.cpp
-        mac/macwlancredentials.h
-        mac/macwlancredentials.cpp
-        dependencies/drivelist/src/darwin/list.mm
-        dependencies/drivelist/src/darwin/REDiskList.m
-        mac/file_operations_macos.cpp
-        mac/buffer_optimization_macos.cpp
-    )
-    set(DEPENDENCIES  icons/rpi-imager.icns)
-    enable_language(OBJC C)
-elseif (UNIX)
-    find_package(GnuTLS REQUIRED)
-    set(PLATFORM_SOURCES
-        dependencies/mountutils/src/linux/functions.cpp
-        linux/linuxdrivelist.cpp
-        linux/networkmanagerapi.h
-        linux/networkmanagerapi.cpp
-        linux/stpanalyzer.h
-        linux/stpanalyzer.cpp
-        linux/acceleratedcryptographichash_gnutls.cpp
-        linux/file_operations_linux.cpp
-        linux/buffer_optimization_linux.cpp
-    )
-    set(EXTRALIBS ${EXTRALIBS} GnuTLS::GnuTLS idn2 nettle)
-    set(DEPENDENCIES "")
-    add_definitions(-DHAVE_GNUTLS)
-elseif (WIN32)
-    # Find dlltool for creating import library
-    if(NOT CMAKE_DLLTOOL)
-        find_program(CMAKE_DLLTOOL NAMES dlltool x86_64-w64-mingw32-dlltool)
-        if(NOT CMAKE_DLLTOOL)
-            # Try to find it in the same directory as the compiler
-            get_filename_component(COMPILER_DIR ${CMAKE_C_COMPILER} DIRECTORY)
-            find_program(CMAKE_DLLTOOL NAMES dlltool x86_64-w64-mingw32-dlltool PATHS ${COMPILER_DIR} NO_DEFAULT_PATH)
-        endif()
-        if(NOT CMAKE_DLLTOOL)
-            message(FATAL_ERROR "Could not find dlltool, needed for creating wlanapi import library")
-        endif()
-        message(STATUS "Found dlltool: ${CMAKE_DLLTOOL}")
-    endif()
-    
-    add_custom_command(
-        OUTPUT wlanapi_delayed.lib
-        COMMAND ${CMAKE_DLLTOOL} --input-def "${CMAKE_CURRENT_SOURCE_DIR}/windows/wlanapi.def"
-                --output-delaylib "${CMAKE_BINARY_DIR}/wlanapi_delayed.lib" --dllname "wlanapi.dll"
-        DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/windows/wlanapi.def
-        WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
-        COMMENT "Creating wlanapi delay-load library"
-        VERBATIM
-    )
-    set(PLATFORM_SOURCES
-        windows/acceleratedcryptographichash_cng.cpp
-        dependencies/mountutils/src/windows/functions.cpp
-        dependencies/drivelist/src/windows/list.cpp
-        windows/winfile.cpp
-        windows/winfile.h
-        windows/winwlancredentials.h
-        windows/winwlancredentials.cpp
-        windows/file_operations_windows.cpp
-        windows/buffer_optimization_windows.cpp
-    )
-    set(DEPENDENCIES
-        windows/rpi-imager.rc
-        wlanapi_delayed.lib
-    )
-    set(EXTRALIBS setupapi ${CMAKE_BINARY_DIR}/wlanapi_delayed.lib Bcrypt.dll)
+find_package(GnuTLS REQUIRED)
+set(PLATFORM_SOURCES
+    dependencies/mountutils/src/linux/functions.cpp
+    linux/linuxdrivelist.cpp
+    linux/networkmanagerapi.h
+    linux/networkmanagerapi.cpp
+    linux/stpanalyzer.h
+    linux/stpanalyzer.cpp
+    linux/acceleratedcryptographichash_gnutls.cpp
+    linux/file_operations_linux.cpp
+    linux/buffer_optimization_linux.cpp
+)
+set(EXTRALIBS ${EXTRALIBS} GnuTLS::GnuTLS idn2 nettle)
+set(DEPENDENCIES "")
+add_definitions(-DHAVE_GNUTLS)
 
-endif()
 
 include_directories(BEFORE .)
 
@@ -745,286 +238,24 @@ qt_add_qml_module(${PROJECT_NAME}
     NO_PLUGIN
 )
 
-# Because dependencies are typically not available by default on Windows, build bundled code
-if (WIN32)
-    # Target Windows 10, in line with Qt requirements
-    add_definitions(-DWINVER=0x0A00 -D_WIN32_WINNT=0x0A00 -DNTDDI_VERION=0x0A000000)
-
-    # Strip debug symbols
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND ${CMAKE_STRIP} "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.exe")
-
-    if (IMAGER_SIGNED_APP)
-    # Borrowed from the 'mstdlib' project: Code signing
-    # First, determine our build architecture
-    if (CMAKE_SIZEOF_VOID_P EQUAL 8)
-            set(arch x64)
-    else ()
-            set(arch x86)
-    endif ()
-    #
-    #  Now find signtool
-    if (NOT SIGNTOOL)
-            # Try to list all Windows 10 SDK versions, if any.
-            set(win10_kit_versions)
-            set(regkey "HKEY_LOCAL_MACHINE\\SOFTWARE\\WOW6432Node\\Microsoft\\Windows Kits\\Installed Roots")
-            set(regval "KitsRoot10")
-            # Note: must be a cache operation in order to read from the registry.
-            get_filename_component(w10_kits_path "[${regkey};${regval}]" ABSOLUTE CACHE)
-            if (w10_kits_path)
-                message(WARNING "Found Windows 10 kits path: ${w10_kits_path}")
-                file(GLOB w10_kit_versions "${w10_kits_path}/bin/10.*")
-                # Reverse list, so newer (higher-numbered) versions appear first.
-                list(REVERSE w10_kit_versions)
-            endif ()
-            unset(w10_kits_path CACHE)
-            if (w10_kit_versions)
-                    find_program(SIGNTOOL
-                                    NAMES           signtool
-                                    PATHS           ${w10_kit_versions}
-                                    PATH_SUFFIXES   ${arch}
-                                                    bin/${arch}
-                                                    bin
-                                    NO_DEFAULT_PATH
-                    )
-            endif ()
-    endif ()
-
-    if (NOT SIGNTOOL)
-        message(FATAL_ERROR "Unable to locate signtool.exe used for code signing")
+# UNIX, Linux systems
+if (NOT CMAKE_CROSSCOMPILING)
+    find_program(LSBLK "lsblk")
+    if (NOT LSBLK)
+        message(FATAL_ERROR "Unable to locate lsblk (used for disk enumeration)")
     endif()
-    add_definitions(-DSIGNTOOL="${SIGNTOOL}")
 
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND "${SIGNTOOL}" sign /tr http://timestamp.digicert.com /td sha256 /fd sha256 /a "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.exe")
-
-
-    endif(IMAGER_SIGNED_APP)
-
-    # Windeploy
-    find_program(WINDEPLOYQT "windeployqt.exe" PATHS "${Qt6_ROOT}/bin")
-    if (NOT WINDEPLOYQT)
-        message(FATAL_ERROR "Unable to locate windeployqt.exe")
-    endif()
-
-    file(MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/deploy")
-
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND ${CMAKE_COMMAND} -E copy
-            "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.exe"
-            "${CMAKE_SOURCE_DIR}/../license.txt" "${CMAKE_SOURCE_DIR}/windows/rpi-imager-cli.cmd"
-            "${CMAKE_BINARY_DIR}/deploy")
-
-    # Inno Setup configuration
-    option(ENABLE_INNO_INSTALLER "Build Inno Setup installer instead of NSIS" OFF)
-    
-    if(ENABLE_INNO_INSTALLER)
-        # Create installer output directory
-        file(MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/installer")
-        
-        # Configure the Inno Setup script
-        configure_file(
-            "${CMAKE_CURRENT_SOURCE_DIR}/windows/rpi-imager.iss.in"
-            "${CMAKE_CURRENT_BINARY_DIR}/rpi-imager.iss"
-            @ONLY)
-            
-        # Find Inno Setup compiler
-        find_program(INNO_COMPILER NAMES iscc ISCC "iscc.exe" PATHS
-            "C:/Program Files (x86)/Inno Setup 6"
-            "C:/Program Files/Inno Setup 6"
-            DOC "Path to Inno Setup compiler")
-            
-        if(INNO_COMPILER)
-            if(IMAGER_SIGNED_APP)
-                add_custom_target(inno_installer
-                    COMMAND "${INNO_COMPILER}" "${CMAKE_CURRENT_BINARY_DIR}/rpi-imager.iss" "/DSIGNING_ENABLED" "/Ssign=${SIGNTOOL} sign /tr http://timestamp.digicert.com /td sha256 /fd sha256 /a $p"
-                    DEPENDS ${PROJECT_NAME}
-                    COMMENT "Building Inno Setup installer"
-                    VERBATIM)
-            else()
-                add_custom_target(inno_installer
-                    COMMAND "${INNO_COMPILER}" "${CMAKE_CURRENT_BINARY_DIR}/rpi-imager.iss"
-                    DEPENDS ${PROJECT_NAME}
-                    COMMENT "Building Inno Setup installer"
-                    VERBATIM)
-            endif()
-            message(STATUS "Added 'inno_installer' target to build the Inno Setup installer")
-        else()
-            message(WARNING "Inno Setup compiler not found. Install Inno Setup from https://jrsoftware.org/isinfo.php")
-        endif()
-    else()
-        # NSIS Installer (legacy option)
-        configure_file(
-            "${CMAKE_CURRENT_SOURCE_DIR}/windows/rpi-imager.nsi.in"
-            "${CMAKE_CURRENT_BINARY_DIR}/rpi-imager.nsi"
-            @ONLY)
+    execute_process(COMMAND "${LSBLK}" "--json" OUTPUT_QUIET RESULT_VARIABLE ret)
+    if (ret EQUAL "1")
+        message(FATAL_ERROR "util-linux package too old. lsblk does not support --json (used for disk enumeration)")
     endif()
-
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND ${CMAKE_COMMAND} -E copy
-            "${MINGW64_ROOT}/bin/libgcc_s_seh-1.dll"
-            "${MINGW64_ROOT}/bin/libstdc++-6.dll"
-            "${MINGW64_ROOT}/bin/libwinpthread-1.dll"
-            "${CMAKE_BINARY_DIR}/deploy")
-
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND "${WINDEPLOYQT}" --no-translations --qmldir "${CMAKE_CURRENT_SOURCE_DIR}" "${CMAKE_BINARY_DIR}/deploy/rpi-imager.exe")
-
-    # Remove excess files
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND ${CMAKE_COMMAND} -E remove
-            "${CMAKE_BINARY_DIR}/deploy/imageformats/qtiff.dll"
-            "${CMAKE_BINARY_DIR}/deploy/imageformats/qwebp.dll"
-            "${CMAKE_BINARY_DIR}/deploy/imageformats/qgif.dll")
-
-elseif(APPLE)
-    find_library(Cocoa Cocoa)
-    find_library(CoreFoundation CoreFoundation)
-    find_library(DiskArbitration DiskArbitration)
-    find_library(Security Security)
-    find_library(IOKit IOKit)
-    find_library(SystemConfiguration SystemConfiguration)
-    set(EXTRALIBS ${EXTRALIBS} ${CoreFoundation} ${DiskArbitration} ${Security} ${Cocoa} ${IOKit} ${SystemConfiguration} iconv)
-    
-    # Set application name with proper spacing
-    set(APP_NAME "Raspberry Pi Imager")
-    
-    # Set all required bundle properties
-    set(MACOSX_BUNDLE_BUNDLE_NAME "${APP_NAME}")
-    set(MACOSX_BUNDLE_EXECUTABLE_NAME "${PROJECT_NAME}")
-    set(MACOSX_BUNDLE_GUI_IDENTIFIER "org.raspberrypi.imagingutility")
-    set(MACOSX_BUNDLE_BUNDLE_VERSION "${IMAGER_VERSION_STR}")
-    set(MACOSX_BUNDLE_SHORT_VERSION_STRING "${IMAGER_VERSION_STR}")
-    set(MACOSX_BUNDLE_LONG_VERSION_STRING "${IMAGER_VERSION_STR}")
-    set(MACOSX_BUNDLE_ICON_FILE "rpi-imager.icns")
-    string(TIMESTAMP CURRENT_YEAR "%Y")
-    set(MACOSX_BUNDLE_COPYRIGHT "Copyright © 2020-${CURRENT_YEAR} Raspberry Pi Ltd")
-    
-    # Simple macos bundle with minimal Info.plist configuration
-    set_target_properties(${PROJECT_NAME} PROPERTIES 
-        MACOSX_BUNDLE YES)
-
-    # Define app bundle location
-    set(APP_BUNDLE_PATH "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.app")
-    set(DMG_PATH "${CMAKE_BINARY_DIR}/${APP_NAME}.dmg")
-    set(FINAL_DMG_PATH "${CMAKE_BINARY_DIR}/${APP_NAME}-${IMAGER_VERSION_STR}.dmg")
-
-    # Manually configure the Info.plist file from a template
-    configure_file(
-        "${CMAKE_CURRENT_SOURCE_DIR}/mac/Info.plist.in" 
-        "${CMAKE_BINARY_DIR}/Info.plist"
-        @ONLY
-    )
-
-    # Clean only specific files/directories but not the entire app bundle
-    # This ensures directory structure for lipo doesn't get removed
-    add_custom_command(TARGET ${PROJECT_NAME} PRE_BUILD
-        COMMAND ${CMAKE_COMMAND} -E echo "Cleaning up previous macOS DMG files..."
-        COMMAND ${CMAKE_COMMAND} -E remove -f "${DMG_PATH}"
-        COMMAND ${CMAKE_COMMAND} -E remove -f "${FINAL_DMG_PATH}"
-        COMMENT "Cleaning previous macOS build artifacts"
-    )
-
-    # Ensure required directories exist before building
-    add_custom_command(TARGET ${PROJECT_NAME} PRE_LINK
-        COMMAND ${CMAKE_COMMAND} -E echo "Ensuring app bundle directories exist..."
-        COMMAND ${CMAKE_COMMAND} -E make_directory "${APP_BUNDLE_PATH}"
-        COMMAND ${CMAKE_COMMAND} -E make_directory "${APP_BUNDLE_PATH}/Contents"
-        COMMAND ${CMAKE_COMMAND} -E make_directory "${APP_BUNDLE_PATH}/Contents/MacOS"
-        COMMAND ${CMAKE_COMMAND} -E make_directory "${APP_BUNDLE_PATH}/Contents/Resources"
-        COMMENT "Creating app bundle directory structure"
-    )
-
-    # Add a post-build command to copy the Info.plist file to the app bundle
-    add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
-        COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_BINARY_DIR}/Info.plist" "${APP_BUNDLE_PATH}/Contents/Info.plist"
-        COMMENT "Installing custom Info.plist"
-    )
-
-    find_program(MACDEPLOYQT "macdeployqt" PATHS "${Qt6_ROOT}/bin")
-    if (NOT MACDEPLOYQT)
-        message(FATAL_ERROR "Unable to locate macdeployqt")
-    endif()
-
-    # Deploy Qt dependencies as part of the main build
-    add_custom_command(TARGET ${PROJECT_NAME}
-        POST_BUILD
-        COMMAND ${CMAKE_COMMAND} -E echo "Deploying Qt dependencies..."
-        COMMAND "${MACDEPLOYQT}" "${APP_BUNDLE_PATH}" -qmldir="${CMAKE_CURRENT_SOURCE_DIR}" -always-overwrite
-        COMMENT "Deploying Qt dependencies"
-    )
-
-    # Create explicit DMG target (similar to inno_installer on Windows)
-    if(IMAGER_SIGNED_APP)
-        if(IMAGER_SIGNING_IDENTITY)
-            # Configure the styled DMG creation script
-            configure_file(
-                "${CMAKE_CURRENT_SOURCE_DIR}/mac/create_styled_dmg.sh.in"
-                "${CMAKE_BINARY_DIR}/create_styled_dmg.sh"
-                @ONLY
-            )
-            
-            # Using a simpler script for macOS post-processing
-            configure_file(
-                "${CMAKE_CURRENT_SOURCE_DIR}/mac/macos_post_build.sh.in"
-                "${CMAKE_BINARY_DIR}/macos_post_build.sh"
-                @ONLY
-            )
-            
-            # Make the script executable
-            execute_process(
-                COMMAND chmod +x "${CMAKE_BINARY_DIR}/macos_post_build.sh"
-            )
-            
-            # Create signed DMG target
-            add_custom_target(dmg
-                COMMAND "${CMAKE_BINARY_DIR}/macos_post_build.sh"
-                DEPENDS ${PROJECT_NAME}
-                COMMENT "Creating signed macOS DMG"
-                VERBATIM)
-        else()
-            message(FATAL_ERROR "Signing requested, but no signing identity provided")
-        endif(IMAGER_SIGNING_IDENTITY)
-    else()
-        # Create unsigned DMG target
-        add_custom_target(dmg
-            COMMAND ${CMAKE_COMMAND} -E echo "Creating DMG..."
-            COMMAND hdiutil create -volname "${APP_NAME}" -srcfolder "${APP_BUNDLE_PATH}" -ov -format UDBZ "${DMG_PATH}"
-            COMMAND ${CMAKE_COMMAND} -E echo "Creating versioned DMG at ${FINAL_DMG_PATH}..."
-            COMMAND ${CMAKE_COMMAND} -E copy "${DMG_PATH}" "${FINAL_DMG_PATH}"
-            DEPENDS ${PROJECT_NAME}
-            COMMENT "Creating macOS DMG"
-            VERBATIM)
-    endif(IMAGER_SIGNED_APP)
-    
-    message(STATUS "Added 'dmg' target to build the macOS DMG installer")
-
-else()
-    # UNIX, Linux systems
-    if (NOT CMAKE_CROSSCOMPILING)
-        find_program(LSBLK "lsblk")
-        if (NOT LSBLK)
-            message(FATAL_ERROR "Unable to locate lsblk (used for disk enumeration)")
-        endif()
-
-        execute_process(COMMAND "${LSBLK}" "--json" OUTPUT_QUIET RESULT_VARIABLE ret)
-        if (ret EQUAL "1")
-            message(FATAL_ERROR "util-linux package too old. lsblk does not support --json (used for disk enumeration)")
-        endif()
-    endif()
-
-    install(TARGETS ${PROJECT_NAME} DESTINATION bin)
-    install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/rpi-imager.png" DESTINATION share/icons/hicolor/128x128/apps)
-    install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/org.raspberrypi.rpi-imager.desktop" DESTINATION share/applications)
-    install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/org.raspberrypi.rpi-imager.metainfo.xml" DESTINATION share/metainfo)
 endif()
 
+install(TARGETS ${PROJECT_NAME} DESTINATION bin)
+install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/rpi-imager.png" DESTINATION share/icons/hicolor/128x128/apps)
+install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/org.raspberrypi.rpi-imager.desktop" DESTINATION share/applications)
+install(FILES "${CMAKE_CURRENT_LIST_DIR}/../debian/org.raspberrypi.rpi-imager.metainfo.xml" DESTINATION share/metainfo)
+
 add_dependencies(${PROJECT_NAME} ZLIB::ZLIB)
 include_directories(${CURL_INCLUDE_DIR} ${LibArchive_INCLUDE_DIR} ${LIBLZMA_INCLUDE_DIRS} ${LIBDRM_INCLUDE_DIRS} ${ZLIB_INCLUDE_DIRS} ${ZSTD_INCLUDE_DIR})
 target_link_libraries(${PROJECT_NAME} PRIVATE ${QT}::Core ${QT}::Quick ${QT}::Svg ${CURL_LIBRARIES} ${LibArchive_LIBRARIES} ${ZSTD_LIBRARIES} ${LIBLZMA_LIBRARIES} ZLIB::ZLIB ${LIBDRM_LIBRARIES} ${ATOMIC_LIBRARY} ${EXTRALIBS})
openSUSE Build Service is sponsored by