feat:修复Mingw不能编译的问题;

编译动态库在命令中使用变量-DBUILD_SHARED_LIBS=true实现,默认静态链接
This commit is contained in:
overwri 2024-02-08 07:28:00 +08:00
parent adfc56ef59
commit 1052e74113
2 changed files with 20 additions and 30 deletions

View File

@ -5,7 +5,7 @@ project(ncmdump LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
option(BUILD_WIN32_STATIC "Build the program statically on Windows" ON)
add_subdirectory(taglib)
FILE(GLOB HEADERS ./*.h)
FILE(GLOB SOURCES ./*.cpp)
@ -13,22 +13,12 @@ add_executable(ncmdump
${HEADERS}
${SOURCES}
)
add_subdirectory(taglib)
target_link_libraries(ncmdump tag)
target_include_directories(ncmdump PRIVATE taglib)
target_include_directories(ncmdump PRIVATE taglib/taglib)
target_include_directories(ncmdump PRIVATE taglib/taglib/toolkit)
target_include_directories(ncmdump PRIVATE taglib/taglib/mpeg/id3v2)
if(WIN32)
if(CMAKE_COMPILER_IS_GNUCXX)
target_link_options(ncmdump PRIVATE -O2 -municode)
if(BUILD_WIN32_STATIC)
target_link_options(ncmdump PRIVATE -static)
endif()
endif()
endif()
include(GNUInstallDirs)
install(TARGETS ncmdump
BUNDLE DESTINATION .

View File

@ -5,7 +5,7 @@
#include <vector>
#include <filesystem>
#ifdef _WIN32
#if defined(_WIN32) && defined(_MSC_VER)
#include <Windows.h>
#endif
@ -47,15 +47,15 @@ void processFilesInFolder(const fs::path& folderPath) {
}
}
#ifdef _WIN32
#if defined(_WIN32) && defined(_MSC_VER)
int wmain(int argc, wchar_t* argv[])
#else
int main(int argc, char **argv)
#endif
{
#ifdef _WIN32
SetConsoleOutputCP(CP_UTF8);
#endif
#if defined(_WIN32) && defined(_MSC_VER)
SetConsoleOutputCP(CP_UTF8);
#endif
if (argc <= 1) {
displayHelp();
@ -67,17 +67,17 @@ int main(int argc, char **argv)
bool folderProvided = false;
#ifdef _WIN32
#define COMPARE_STR(s1, s2) (wcscmp(s1, s2) == 0)
#define HELP_SHORT L"-h"
#define HELP_LONG L"--help"
#define FOLDER L"-d"
#else
#define COMPARE_STR(s1, s2) (strcmp(s1, s2) == 0)
#define HELP_SHORT "-h"
#define HELP_LONG "--help"
#define FOLDER "-d"
#endif
#if defined(_WIN32) && defined(_MSC_VER)
#define COMPARE_STR(s1, s2) (wcscmp(s1, s2) == 0)
#define HELP_SHORT L"-h"
#define HELP_LONG L"--help"
#define FOLDER L"-d"
#else
#define COMPARE_STR(s1, s2) (strcmp(s1, s2) == 0)
#define HELP_SHORT "-h"
#define HELP_LONG "--help"
#define FOLDER "-d"
#endif
for (int i = 1; i < argc; ++i) {
if (COMPARE_STR(argv[i], HELP_SHORT) || COMPARE_STR(argv[i], HELP_LONG)) {
@ -95,14 +95,14 @@ int main(int argc, char **argv)
return 1;
}
} else {
#ifdef _WIN32
#if defined(_WIN32) && defined(_MSC_VER)
int multiByteStrSize = WideCharToMultiByte(CP_UTF8, 0, argv[1], -1, NULL, 0, NULL, NULL);
char *multiByteStr = new char[multiByteStrSize];
WideCharToMultiByte(CP_UTF8, 0, argv[i], -1, multiByteStr, multiByteStrSize, NULL, NULL);
fs::path path(multiByteStr);
#else
#else
fs::path path(argv[i]);
#endif
#endif
files.push_back(path);
}
}