mirror of
https://github.com/taurusxin/ncmdump.git
synced 2025-07-15 05:52:11 +08:00
feat:修复Mingw不能编译的问题;
编译动态库在命令中使用变量-DBUILD_SHARED_LIBS=true实现,默认静态链接
This commit is contained in:
parent
adfc56ef59
commit
1052e74113
@ -5,7 +5,7 @@ project(ncmdump LANGUAGES CXX)
|
|||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
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 HEADERS ./*.h)
|
||||||
FILE(GLOB SOURCES ./*.cpp)
|
FILE(GLOB SOURCES ./*.cpp)
|
||||||
@ -13,22 +13,12 @@ add_executable(ncmdump
|
|||||||
${HEADERS}
|
${HEADERS}
|
||||||
${SOURCES}
|
${SOURCES}
|
||||||
)
|
)
|
||||||
add_subdirectory(taglib)
|
|
||||||
target_link_libraries(ncmdump tag)
|
target_link_libraries(ncmdump tag)
|
||||||
target_include_directories(ncmdump PRIVATE taglib)
|
target_include_directories(ncmdump PRIVATE taglib)
|
||||||
target_include_directories(ncmdump PRIVATE taglib/taglib)
|
target_include_directories(ncmdump PRIVATE taglib/taglib)
|
||||||
target_include_directories(ncmdump PRIVATE taglib/taglib/toolkit)
|
target_include_directories(ncmdump PRIVATE taglib/taglib/toolkit)
|
||||||
target_include_directories(ncmdump PRIVATE taglib/taglib/mpeg/id3v2)
|
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)
|
include(GNUInstallDirs)
|
||||||
install(TARGETS ncmdump
|
install(TARGETS ncmdump
|
||||||
BUNDLE DESTINATION .
|
BUNDLE DESTINATION .
|
||||||
|
38
main.cpp
38
main.cpp
@ -5,7 +5,7 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
|
|
||||||
#ifdef _WIN32
|
#if defined(_WIN32) && defined(_MSC_VER)
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
#endif
|
#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[])
|
int wmain(int argc, wchar_t* argv[])
|
||||||
#else
|
#else
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
#ifdef _WIN32
|
#if defined(_WIN32) && defined(_MSC_VER)
|
||||||
SetConsoleOutputCP(CP_UTF8);
|
SetConsoleOutputCP(CP_UTF8);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (argc <= 1) {
|
if (argc <= 1) {
|
||||||
displayHelp();
|
displayHelp();
|
||||||
@ -67,17 +67,17 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
bool folderProvided = false;
|
bool folderProvided = false;
|
||||||
|
|
||||||
#ifdef _WIN32
|
#if defined(_WIN32) && defined(_MSC_VER)
|
||||||
#define COMPARE_STR(s1, s2) (wcscmp(s1, s2) == 0)
|
#define COMPARE_STR(s1, s2) (wcscmp(s1, s2) == 0)
|
||||||
#define HELP_SHORT L"-h"
|
#define HELP_SHORT L"-h"
|
||||||
#define HELP_LONG L"--help"
|
#define HELP_LONG L"--help"
|
||||||
#define FOLDER L"-d"
|
#define FOLDER L"-d"
|
||||||
#else
|
#else
|
||||||
#define COMPARE_STR(s1, s2) (strcmp(s1, s2) == 0)
|
#define COMPARE_STR(s1, s2) (strcmp(s1, s2) == 0)
|
||||||
#define HELP_SHORT "-h"
|
#define HELP_SHORT "-h"
|
||||||
#define HELP_LONG "--help"
|
#define HELP_LONG "--help"
|
||||||
#define FOLDER "-d"
|
#define FOLDER "-d"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (int i = 1; i < argc; ++i) {
|
for (int i = 1; i < argc; ++i) {
|
||||||
if (COMPARE_STR(argv[i], HELP_SHORT) || COMPARE_STR(argv[i], HELP_LONG)) {
|
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;
|
return 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
#ifdef _WIN32
|
#if defined(_WIN32) && defined(_MSC_VER)
|
||||||
int multiByteStrSize = WideCharToMultiByte(CP_UTF8, 0, argv[1], -1, NULL, 0, NULL, NULL);
|
int multiByteStrSize = WideCharToMultiByte(CP_UTF8, 0, argv[1], -1, NULL, 0, NULL, NULL);
|
||||||
char *multiByteStr = new char[multiByteStrSize];
|
char *multiByteStr = new char[multiByteStrSize];
|
||||||
WideCharToMultiByte(CP_UTF8, 0, argv[i], -1, multiByteStr, multiByteStrSize, NULL, NULL);
|
WideCharToMultiByte(CP_UTF8, 0, argv[i], -1, multiByteStr, multiByteStrSize, NULL, NULL);
|
||||||
fs::path path(multiByteStr);
|
fs::path path(multiByteStr);
|
||||||
#else
|
#else
|
||||||
fs::path path(argv[i]);
|
fs::path path(argv[i]);
|
||||||
#endif
|
#endif
|
||||||
files.push_back(path);
|
files.push_back(path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user