From 2ba7239443f20a46fd42c8b3f7bfce6e8b81e0d0 Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Sat, 17 Feb 2024 15:48:50 +0800 Subject: [PATCH 1/9] Fixed pointer type incompatibility warnings --- contrib/win32/stdlib.c | 28 ++++++++++++++-------------- contrib/windows.h | 2 +- 2 files changed, 15 insertions(+), 15 deletions(-) diff --git a/contrib/win32/stdlib.c b/contrib/win32/stdlib.c index 5a1bd560..2193d1e1 100644 --- a/contrib/win32/stdlib.c +++ b/contrib/win32/stdlib.c @@ -34,24 +34,24 @@ // Handle platform specific includes #include "contrib/windows.h" -//There is no setenv()and unsetenv() in windows,but we can use putenv() instead. +// This implementation of setenv() and unsetenv() using _putenv_s() as the +// underlying function. +// NOTE: unlike the POSIX functions, they return errno instead of -1 when they +// fail, and they allow name to contain '=', which is not allowed by the POSIX +// standard. int setenv(const char *name, const char *value, int overwrite) { - char *env = getenv(name); - if ((env && overwrite) || (!env)) { - char *str[32]; - strcpy(str, name); - strcat(str, "="); - strcat(str, value); - return putenv(str); + if (!overwrite) { + size_t sz; + // Test for existence. + getenv_s(&sz, NULL, 0, name); + if (sz != 0) + return 0; } - return -1; + return _putenv_s(name, value); } -void unsetenv(const char *name) +int unsetenv(const char *name) { - char *str[32]; - strcpy(str, name); - strcat(str, "="); - putenv(str); + return _putenv_s(name, ""); } diff --git a/contrib/windows.h b/contrib/windows.h index 3928d6ed..e0afb098 100644 --- a/contrib/windows.h +++ b/contrib/windows.h @@ -59,6 +59,6 @@ * These declarations get rid of the "implicit declaration warning." */ int setenv(const char *name, const char *value, int overwrite); -void unsetenv(const char *name); +int unsetenv(const char *name); #endif From 295b9f4921df7641c7937a0ef94c2155b61360da Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Thu, 2 May 2024 21:25:11 +0800 Subject: [PATCH 2/9] Fixed #714 --- contrib/win32/stdlib.c | 46 +++++++++++++++++++++++++++++++++++++++++- contrib/windows.h | 40 +++++++++++++++++++----------------- 2 files changed, 66 insertions(+), 20 deletions(-) diff --git a/contrib/win32/stdlib.c b/contrib/win32/stdlib.c index 2193d1e1..374141cb 100644 --- a/contrib/win32/stdlib.c +++ b/contrib/win32/stdlib.c @@ -31,7 +31,9 @@ * @brief Windows System compatibility */ -// Handle platform specific includes +#include +#include + #include "contrib/windows.h" // This implementation of setenv() and unsetenv() using _putenv_s() as the @@ -55,3 +57,45 @@ int unsetenv(const char *name) { return _putenv_s(name, ""); } + +#ifdef NEED_LIBNFC_SNPRINTF + +#include +#include + +int libnfc_vsnprintf(char *s, size_t n, const char *format, va_list arg) +{ + int retval; + + /* _vsnprintf() does not work with zero length buffer + * so count number of character by _vscprintf() call */ + if (n == 0) + return _vscprintf(format, arg); + + retval = _vsnprintf(s, n, format, arg); + + /* _vsnprintf() does not fill trailing null byte if there is not place for it + */ + if (retval < 0 || (size_t)retval == n) + s[n - 1] = '\0'; + + /* _vsnprintf() returns negative number if buffer is too small + * so count number of character by _vscprintf() call */ + if (retval < 0) + retval = _vscprintf(format, arg); + + return retval; +} + +int libnfc_snprintf(char *buffer, size_t n, const char *format, ...) +{ + int retval; + va_list argptr; + + va_start(argptr, format); + retval = libnfc_vsnprintf(buffer, n, format, argptr); + va_end(argptr); + return retval; +} + +#endif diff --git a/contrib/windows.h b/contrib/windows.h index e0afb098..dce8d9d9 100644 --- a/contrib/windows.h +++ b/contrib/windows.h @@ -33,26 +33,28 @@ #ifndef __WINDOWS_H__ #define __WINDOWS_H__ -# include -# include -# include "win32/err.h" -# if defined (__MINGW32__) -/* - * Cheating here on the snprintf to incorporate the format argument - * into the VA_ARGS. Else we get MinGW errors regarding number of arguments - * if doing a fixed string with no arguments. -*/ -# define snprintf(S, n, ...) sprintf(S, __VA_ARGS__) -# define pipe(fds) _pipe(fds, 5000, _O_BINARY) -# define ETIMEDOUT WSAETIMEDOUT -# define ENOTSUP WSAEOPNOTSUPP -# define ECONNABORTED WSAECONNABORTED -# else -#ifndef _MSC_VER -# define snprintf sprintf_s +#define WIN32_LEAN_AND_MEAN +#include +#include + +#ifdef __MINGW32__ + +#if __MINGW64_VERSION_MAJOR < 3 +#include +#define ETIMEDOUT WSAETIMEDOUT +#define ENOTSUP WSAEOPNOTSUPP +#define ECONNABORTED WSAECONNABORTED +#endif + +#if __MINGW64_VERSION_MAJOR < 8 +#define NEED_LIBNFC_SNPRINTF +#define snprintf libnfc_snprintf +#endif + #endif -# define strdup _strdup -# endif + +#define pipe(fds) _pipe(fds, 4096, _O_BINARY) +#define strdup _strdup /* * setenv and unsetenv are not Windows compliant nor implemented in MinGW. From 97220ab1bae6e4aa27e9b8bae5eb26194adf6ca2 Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Fri, 3 May 2024 00:49:10 +0800 Subject: [PATCH 3/9] Fixed more errors --- contrib/windows.h | 7 +++---- libnfc/CMakeLists.txt | 6 ++++-- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/contrib/windows.h b/contrib/windows.h index dce8d9d9..bc23f8a9 100644 --- a/contrib/windows.h +++ b/contrib/windows.h @@ -38,21 +38,20 @@ #include #ifdef __MINGW32__ - #if __MINGW64_VERSION_MAJOR < 3 #include #define ETIMEDOUT WSAETIMEDOUT #define ENOTSUP WSAEOPNOTSUPP #define ECONNABORTED WSAECONNABORTED #endif +#endif -#if __MINGW64_VERSION_MAJOR < 8 +#if defined(_MSC_VER) && _MSC_VER < 1900 || \ + defined(__MINGW32__) && __MINGW64_VERSION_MAJOR < 8 #define NEED_LIBNFC_SNPRINTF #define snprintf libnfc_snprintf #endif -#endif - #define pipe(fds) _pipe(fds, 4096, _O_BINARY) #define strdup _strdup diff --git a/libnfc/CMakeLists.txt b/libnfc/CMakeLists.txt index d3321778..8d0d575a 100644 --- a/libnfc/CMakeLists.txt +++ b/libnfc/CMakeLists.txt @@ -5,9 +5,11 @@ IF(WIN32) # Add in the rc for version information in the dll LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/../windows/libnfc.rc) - IF (NOT MINGW) + IF(MSVC) LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc_msvc.def) - ENDIF() + ELSE(MSVC) + LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc.def) + ENDIF(MSVC) ENDIF(WIN32) # Library's chips From b40ba8c7db45af8dfa3126d262d1be19a901021e Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Sat, 1 Jun 2024 08:33:39 +0800 Subject: [PATCH 4/9] Update conditions for replacing `snprintf()` with `libnfc_snprintf()` --- contrib/win32/stdlib.c | 3 ++- contrib/windows.h | 13 ++++++------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/contrib/win32/stdlib.c b/contrib/win32/stdlib.c index 374141cb..e62e30c9 100644 --- a/contrib/win32/stdlib.c +++ b/contrib/win32/stdlib.c @@ -58,11 +58,12 @@ int unsetenv(const char *name) return _putenv_s(name, ""); } -#ifdef NEED_LIBNFC_SNPRINTF +#ifdef USE_LIBNFC_SNPRINTF #include #include +// The implementation of libnfc_snprintf() is taken from mingw-w64-crt int libnfc_vsnprintf(char *s, size_t n, const char *format, va_list arg) { int retval; diff --git a/contrib/windows.h b/contrib/windows.h index bc23f8a9..92887127 100644 --- a/contrib/windows.h +++ b/contrib/windows.h @@ -34,22 +34,21 @@ #define __WINDOWS_H__ #define WIN32_LEAN_AND_MEAN -#include #include -#ifdef __MINGW32__ -#if __MINGW64_VERSION_MAJOR < 3 +#if defined(__MINGW32__) && __MINGW64_VERSION_MAJOR < 3 #include #define ETIMEDOUT WSAETIMEDOUT #define ENOTSUP WSAEOPNOTSUPP #define ECONNABORTED WSAECONNABORTED #endif -#endif -#if defined(_MSC_VER) && _MSC_VER < 1900 || \ - defined(__MINGW32__) && __MINGW64_VERSION_MAJOR < 8 -#define NEED_LIBNFC_SNPRINTF +#if defined(_MSC_VER) && _MSC_VER < 1900 || \ + defined(__MINGW32__) && __MINGW64_VERSION_MAJOR < 8 && !defined(_UCRT) +#define USE_LIBNFC_SNPRINTF #define snprintf libnfc_snprintf + +int libnfc_snprintf(char *buffer, size_t n, const char *format, ...); #endif #define pipe(fds) _pipe(fds, 4096, _O_BINARY) From 532faa3cc687f49c04323f75bfd8d91760aad786 Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Sat, 1 Jun 2024 08:55:42 +0800 Subject: [PATCH 5/9] Update libnfc.def --- contrib/win32/{nfc.def => libnfc.def.in} | 3 +- contrib/win32/nfc_msvc.def | 57 ------------------------ libnfc/CMakeLists.txt | 28 ++---------- 3 files changed, 4 insertions(+), 84 deletions(-) rename contrib/win32/{nfc.def => libnfc.def.in} (97%) delete mode 100644 contrib/win32/nfc_msvc.def diff --git a/contrib/win32/nfc.def b/contrib/win32/libnfc.def.in similarity index 97% rename from contrib/win32/nfc.def rename to contrib/win32/libnfc.def.in index 22598172..e0ea1508 100644 --- a/contrib/win32/nfc.def +++ b/contrib/win32/libnfc.def.in @@ -1,5 +1,4 @@ -LIBRARY libnfc -VERSION 1.7 +VERSION @VERSION_MAJOR@.@VERSION_MINOR@ EXPORTS nfc_init diff --git a/contrib/win32/nfc_msvc.def b/contrib/win32/nfc_msvc.def deleted file mode 100644 index ec4dc80f..00000000 --- a/contrib/win32/nfc_msvc.def +++ /dev/null @@ -1,57 +0,0 @@ -LIBRARY nfc -VERSION 1.7 - -EXPORTS - nfc_init - nfc_exit - nfc_register_driver - nfc_open - nfc_close - nfc_abort_command - nfc_list_devices - nfc_idle - nfc_initiator_init - nfc_initiator_init_secure_element - nfc_initiator_select_passive_target - nfc_initiator_list_passive_targets - nfc_initiator_poll_target - nfc_initiator_select_dep_target - nfc_initiator_poll_dep_target - nfc_initiator_deselect_target - nfc_initiator_transceive_bytes - nfc_initiator_transceive_bits - nfc_initiator_transceive_bytes_timed - nfc_initiator_transceive_bits_timed - nfc_initiator_target_is_present - nfc_target_init - nfc_target_send_bytes - nfc_target_receive_bytes - nfc_target_send_bits - nfc_target_receive_bits - nfc_strerror - nfc_strerror_r - nfc_perror - nfc_device_get_last_error - nfc_device_get_name - nfc_device_get_connstring - nfc_device_get_supported_modulation - nfc_device_get_supported_baud_rate - nfc_device_get_supported_baud_rate_target_mode - nfc_device_set_property_int - nfc_device_set_property_bool - nfc_emulate_target - iso14443a_crc - iso14443a_crc_append - iso14443b_crc - iso14443b_crc_append - iso14443a_locate_historical_bytes - nfc_free - nfc_version - nfc_device_get_information_about - str_nfc_modulation_type - str_nfc_baud_rate - str_nfc_target - pn53x_transceive - pn532_SAMConfiguration - pn53x_read_register - pn53x_write_register diff --git a/libnfc/CMakeLists.txt b/libnfc/CMakeLists.txt index 8d0d575a..bdb35d8b 100644 --- a/libnfc/CMakeLists.txt +++ b/libnfc/CMakeLists.txt @@ -5,11 +5,8 @@ IF(WIN32) # Add in the rc for version information in the dll LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/../windows/libnfc.rc) - IF(MSVC) - LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc_msvc.def) - ELSE(MSVC) - LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc.def) - ENDIF(MSVC) + CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/libnfc.def.in ${CMAKE_CURRENT_BINARY_DIR}/libnfc.def) + LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/libnfc.def) ENDIF(WIN32) # Library's chips @@ -95,24 +92,5 @@ SET_TARGET_PROPERTIES(nfc PROPERTIES SOVERSION 6 VERSION 6.0.0) IF(WIN32) # Libraries that are windows specific TARGET_LINK_LIBRARIES(nfc wsock32) - IF(MINGW) - ADD_CUSTOM_COMMAND( - OUTPUT libnfc.lib - COMMAND ${DLLTOOL} -d ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc.def -l ${CMAKE_CURRENT_BINARY_DIR}/libnfc.lib ${CMAKE_CURRENT_BINARY_DIR}/libnfc.dll - DEPENDS nfc ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/nfc.def - ) - ADD_CUSTOM_TARGET(win32lib ALL DEPENDS libnfc.lib) - ELSE() - ADD_LIBRARY(win32lib ALIAS nfc) - ENDIF() - - # On Windows the shared (runtime) library should be either in the same - # directory as the excutables or in the path, we add it to same directory - INSTALL(TARGETS nfc RUNTIME DESTINATION bin COMPONENT libraries) - - # At compile time we need the .LIB file, we place it in the lib directory - INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/libnfc.lib DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libraries) -ELSE(WIN32) - INSTALL(TARGETS nfc LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libraries) ENDIF(WIN32) - +INSTALL(TARGETS nfc LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libraries) From 1dc24b2e05b89a87ffbf970b7eaa1211f6e5a5fb Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Tue, 11 Jun 2024 12:06:11 +0800 Subject: [PATCH 6/9] Include for _O_BINARY --- contrib/windows.h | 1 + 1 file changed, 1 insertion(+) diff --git a/contrib/windows.h b/contrib/windows.h index 92887127..148ec948 100644 --- a/contrib/windows.h +++ b/contrib/windows.h @@ -34,6 +34,7 @@ #define __WINDOWS_H__ #define WIN32_LEAN_AND_MEAN +#include #include #if defined(__MINGW32__) && __MINGW64_VERSION_MAJOR < 3 From 9933c8ca621e6e52f953755323df097740922d72 Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Mon, 17 Jun 2024 15:39:40 +0800 Subject: [PATCH 7/9] Add missing MAX_ATR_SIZE on Windows --- libnfc/drivers/pcsc.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/libnfc/drivers/pcsc.c b/libnfc/drivers/pcsc.c index 106d99ac..34d34185 100644 --- a/libnfc/drivers/pcsc.c +++ b/libnfc/drivers/pcsc.c @@ -85,6 +85,10 @@ #define LOG_GROUP NFC_LOG_GROUP_DRIVER #define LOG_CATEGORY "libnfc.driver.pcsc" +#ifndef MAX_ATR_SIZE +#define MAX_ATR_SIZE 33 +#endif + static const char *supported_devices[] = { "ACS ACR122", // ACR122U & Touchatag, last version "ACS ACR 38U-CCID", // Touchatag, early version From 9c5b8be8880c1720f5e1e89435ca7e553332309b Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Wed, 19 Jun 2024 00:53:07 +0800 Subject: [PATCH 8/9] Rewrite def and rc files --- CMakeLists.txt | 46 ++++--------------------------------- contrib/win32/libnfc.def.in | 1 + contrib/win32/version.rc.in | 26 ++++++++++----------- examples/CMakeLists.txt | 10 ++++---- libnfc/CMakeLists.txt | 24 +++++++++++-------- utils/CMakeLists.txt | 7 ++++-- 6 files changed, 43 insertions(+), 71 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index a8605fa4..96c97cdd 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,4 +1,4 @@ -cmake_minimum_required (VERSION 2.6) +cmake_minimum_required (VERSION 3.1) if (NOT DEFINED CMAKE_BUILD_TYPE) set (CMAKE_BUILD_TYPE Release CACHE STRING "Build type") @@ -51,10 +51,10 @@ ENDIF(LIBNFC_ENVVARS) SET(LIBNFC_DEBUG_MODE OFF CACHE BOOL "Debug mode") IF(LIBNFC_DEBUG_MODE) - ADD_DEFINITIONS(-DDEBUG) - SET(CMAKE_C_FLAGS "-g3 ${CMAKE_C_FLAGS}") - SET(WIN32_MODE "debug") + ADD_DEFINITIONS(-DDEBUG -D_DEBUG) + SET(CMAKE_C_FLAGS "-Wall -Wextra -pedantic ${CMAKE_C_FLAGS}") SET(CMAKE_RC_FLAGS "-D_DEBUG ${CMAKE_RC_FLAGS}") + SET(WIN32_MODE "debug") ELSE(LIBNFC_DEBUG_MODE) SET(WIN32_MODE "release") ENDIF(LIBNFC_DEBUG_MODE) @@ -93,39 +93,9 @@ IF(NOT DEFINED SHARE_INSTALL_PREFIX) SET(SHARE_INSTALL_PREFIX share) ENDIF(NOT DEFINED SHARE_INSTALL_PREFIX) -# Additonnal GCC flags -IF(CMAKE_COMPILER_IS_GNUCC) - # Make sure we will not miss some warnings ;) - SET(CMAKE_C_FLAGS "-Wall -pedantic -std=c99 ${CMAKE_C_FLAGS}") -ENDIF(CMAKE_COMPILER_IS_GNUCC) - # Workarounds for libusb in C99 ADD_DEFINITIONS(-Du_int8_t=uint8_t -Du_int16_t=uint16_t) -IF(MINGW) - IF (CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows") - IF(CMAKE_SYSTEM_PROCESSOR STREQUAL "x86") - # force MinGW-w64 in 32bit mode - MESSAGE("Building 32-bit Windows DLL") - #SET(CMAKE_C_FLAGS "-m32 ${CMAKE_C_FLAGS}") - #SET(CMAKE_MODULE_LINKER_FLAGS "--Wl,--enable-stdcall-fixup ${CMAKE_SHARED_LINKER_FLAGS}") - #SET(CMAKE_SHARED_LINKER_FLAGS "--Wl,--enable-stdcall-fixup ${CMAKE_SHARED_LINKER_FLAGS}") - #SET(CMAKE_EXE_LINKER_FLAGS "--Wl,--enable-stdcall-fixup ${CMAKE_EXE_LINKER_FLAGS}") - SET(CMAKE_RC_FLAGS "--target=pe-i386 --output-format=coff ${CMAKE_RC_FLAGS}") - ELSEIF((CMAKE_SYSTEM_PROCESSOR STREQUAL "x86_64") OR (CMAKE_SYSTEM_PROCESSOR STREQUAL "AMD64")) - MESSAGE("Building 64-bit Windows DLL") - SET(CMAKE_RC_FLAGS "--target=pe-x86-64 --output-format=coff ${CMAKE_RC_FLAGS}") - ELSE(CMAKE_SYSTEM_PROCESSOR STREQUAL "x86") - MESSAGE(FATAL_ERROR "Unknown Processor: ${CMAKE_SYSTEM_PROCESSOR}") - ENDIF(CMAKE_SYSTEM_PROCESSOR STREQUAL "x86") - ENDIF(CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows") - - FIND_PROGRAM(DLLTOOL dlltool CMAKE_FIND_ROOT_PATH_BOTH) - IF (NOT DLLTOOL) - MESSAGE(FATAL_ERROR "Could not find dlltool command") - ENDIF (NOT DLLTOOL) -ENDIF(MINGW) - IF(NOT WIN32) # Set some pkg-config variables SET(prefix ${CMAKE_INSTALL_PREFIX}) @@ -178,17 +148,9 @@ IF(LIBUSB_INCLUDE_DIRS) SET(LIBUSB_FOUND TRUE) ENDIF(LIBUSB_INCLUDE_DIRS) -# version.rc for Windows IF(WIN32) # Date for filling in rc file information STRING(TIMESTAMP CURRENT_YEAR %Y) - SET(prefix ${CMAKE_INSTALL_PREFIX}) - SET(RC_COMMENT "${PACKAGE_NAME} library") - SET(RC_INTERNAL_NAME "${PACKAGE_NAME} ${WIN32_MODE}") - SET(RC_ORIGINAL_NAME ${PACKAGE_NAME}.dll) - # RC_FILE_TYPE: VFT_DLL - SET(RC_FILE_TYPE 0x00000002L) - CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/contrib/win32/version.rc.in ${CMAKE_CURRENT_BINARY_DIR}/windows/libnfc.rc @ONLY) ENDIF(WIN32) ADD_SUBDIRECTORY(libnfc) diff --git a/contrib/win32/libnfc.def.in b/contrib/win32/libnfc.def.in index e0ea1508..5f0f6011 100644 --- a/contrib/win32/libnfc.def.in +++ b/contrib/win32/libnfc.def.in @@ -1,3 +1,4 @@ +LIBRARY libnfc VERSION @VERSION_MAJOR@.@VERSION_MINOR@ EXPORTS diff --git a/contrib/win32/version.rc.in b/contrib/win32/version.rc.in index 30f7b838..93d11f2b 100644 --- a/contrib/win32/version.rc.in +++ b/contrib/win32/version.rc.in @@ -1,25 +1,25 @@ +#include + 1 VERSIONINFO FILEVERSION @VERSION_MAJOR@,@VERSION_MINOR@,@VERSION_PATCH@,0 PRODUCTVERSION @VERSION_MAJOR@,@VERSION_MINOR@,@VERSION_PATCH@,0 - FILEFLAGSMASK 0x3fL - FILEFLAGS 0x0L - FILEOS 0x00040004L + FILEFLAGSMASK VS_FFI_FILEFLAGSMASK + FILEFLAGS @RC_FILE_FLAGS@ + FILEOS VOS_NT FILETYPE @RC_FILE_TYPE@ - FILESUBTYPE 0x0L BEGIN BLOCK "StringFileInfo" BEGIN BLOCK "040904e4" BEGIN - VALUE "Comments", "@RC_COMMENT@\0" - VALUE "CompanyName", "libnfc.org\0" - VALUE "FileDescription", "\0" - VALUE "FileVersion", "@VERSION_MAJOR@.@VERSION_MINOR@.@VERSION_PATCH@.0\0" - VALUE "InternalName", "@RC_INTERNAL_NAME@ @WIN32_MODE@\0" - VALUE "LegalCopyright", "Copyright (C) @CURRENT_YEAR@\0" - VALUE "OriginalFilename", "@RC_ORIGINAL_NAME@\0" - VALUE "ProductName", "@PACKAGE_NAME@ @WIN32_MODE@\0" - VALUE "ProductVersion", "@VERSION_MAJOR@.@VERSION_MINOR@.@VERSION_PATCH@.0\0" + VALUE "Comments", "@RC_COMMENT@" + VALUE "CompanyName", "libnfc.org" + VALUE "FileVersion", "@VERSION@" + VALUE "InternalName", "@RC_INTERNAL_NAME@" + VALUE "LegalCopyright", "Copyright (C) @CURRENT_YEAR@" + VALUE "OriginalFilename", "@RC_ORIGINAL_NAME@" + VALUE "ProductName", "@PACKAGE_NAME@ @WIN32_MODE@" + VALUE "ProductVersion", "@VERSION@" END END BLOCK "VarFileInfo" diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index 01a93c9b..8241c3a0 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -24,12 +24,14 @@ FOREACH(source ${EXAMPLES-SOURCES}) SET(RC_COMMENT "${PACKAGE_NAME} example") SET(RC_INTERNAL_NAME ${source}) SET(RC_ORIGINAL_NAME ${source}.exe) - # RC_FILE_TYPE: VFT_APP - SET(RC_FILE_TYPE 0x00000001L) + SET(RC_FILE_TYPE VFT_APP) + SET(RC_FILE_FLAGS 0x0) + IF(LIBNFC_DEBUG_MODE) + SET(RC_FILE_FLAGS VS_FF_DEBUG) + ENDIF(LIBNFC_DEBUG_MODE) CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/version.rc.in ${CMAKE_CURRENT_BINARY_DIR}/../windows/${source}.rc @ONLY) LIST(APPEND TARGETS ${CMAKE_CURRENT_BINARY_DIR}/../windows/${source}.rc) - - + IF(${source} MATCHES "nfc-st25tb") LIST(APPEND TARGETS ${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/getopt.c) ENDIF() diff --git a/libnfc/CMakeLists.txt b/libnfc/CMakeLists.txt index bdb35d8b..f2bd8b41 100644 --- a/libnfc/CMakeLists.txt +++ b/libnfc/CMakeLists.txt @@ -1,11 +1,18 @@ -# Windows MinGW workarounds IF(WIN32) + # Windows workarounds SET(WINDOWS_SOURCES ../contrib/win32/stdlib.c) - INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32) - - # Add in the rc for version information in the dll - LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/../windows/libnfc.rc) + # def and rc files for Windows + SET(RC_COMMENT "${PACKAGE_NAME} library") + SET(RC_INTERNAL_NAME ${PACKAGE_NAME}) + SET(RC_ORIGINAL_NAME ${PACKAGE_NAME}.dll) + SET(RC_FILE_TYPE VFT_DLL) + SET(RC_FILE_FLAGS 0x0) + IF(LIBNFC_DEBUG_MODE) + SET(RC_FILE_FLAGS VS_FF_DEBUG) + ENDIF(LIBNFC_DEBUG_MODE) + CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/version.rc.in ${CMAKE_CURRENT_BINARY_DIR}/libnfc.rc) CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/libnfc.def.in ${CMAKE_CURRENT_BINARY_DIR}/libnfc.def) + LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/libnfc.rc) LIST(APPEND WINDOWS_SOURCES ${CMAKE_CURRENT_BINARY_DIR}/libnfc.def) ENDIF(WIN32) @@ -65,9 +72,6 @@ INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) IF(LIBNFC_LOG) IF(WIN32) - IF(MINGW) - SET(CMAKE_C_FLAGS "-fgnu89-inline ${CMAKE_C_FLAGS}") - ENDIF(MINGW) LIST(APPEND LIBRARY_SOURCES log.c ../contrib/win32/libnfc/log-internal.c) ELSE(WIN32) LIST(APPEND LIBRARY_SOURCES log.c log-internal.c) @@ -87,10 +91,10 @@ IF(LIBRT_FOUND) TARGET_LINK_LIBRARIES(nfc ${LIBRT_LIBRARIES}) ENDIF(LIBRT_FOUND) -SET_TARGET_PROPERTIES(nfc PROPERTIES SOVERSION 6 VERSION 6.0.0) - IF(WIN32) # Libraries that are windows specific TARGET_LINK_LIBRARIES(nfc wsock32) ENDIF(WIN32) + +SET_TARGET_PROPERTIES(nfc PROPERTIES PREFIX "lib" SOVERSION 6 VERSION 6.0.0) INSTALL(TARGETS nfc LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libraries) diff --git a/utils/CMakeLists.txt b/utils/CMakeLists.txt index b9c723ea..03c65e54 100644 --- a/utils/CMakeLists.txt +++ b/utils/CMakeLists.txt @@ -23,8 +23,11 @@ FOREACH(source ${UTILS-SOURCES}) SET(RC_COMMENT "${PACKAGE_NAME} utility") SET(RC_INTERNAL_NAME ${source}) SET(RC_ORIGINAL_NAME ${source}.exe) - # RC_FILE_TYPE: VFT_APP - SET(RC_FILE_TYPE 0x00000001L) + SET(RC_FILE_TYPE VFT_APP) + SET(RC_FILE_FLAGS 0x0) + IF(LIBNFC_DEBUG_MODE) + SET(RC_FILE_FLAGS VS_FF_DEBUG) + ENDIF(LIBNFC_DEBUG_MODE) CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/../contrib/win32/version.rc.in ${CMAKE_CURRENT_BINARY_DIR}/../windows/${source}.rc @ONLY) LIST(APPEND TARGETS ${CMAKE_CURRENT_BINARY_DIR}/../windows/${source}.rc) ENDIF(WIN32) From 72398dc8fbbae03deacc48eb19e7cfdac7b6bc7f Mon Sep 17 00:00:00 2001 From: Yang Kun <91833768+ikspress@users.noreply.github.com> Date: Wed, 19 Jun 2024 01:16:51 +0800 Subject: [PATCH 9/9] Add C99 standard back --- CMakeLists.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 96c97cdd..9a9ea8d8 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -95,6 +95,7 @@ ENDIF(NOT DEFINED SHARE_INSTALL_PREFIX) # Workarounds for libusb in C99 ADD_DEFINITIONS(-Du_int8_t=uint8_t -Du_int16_t=uint16_t) +SET(C_STANDARD 99) IF(NOT WIN32) # Set some pkg-config variables