From b31b5ed66a1353d06ebc5ef5e4de703e3ec48155 Mon Sep 17 00:00:00 2001 From: Nadia Holmquist Pedersen Date: Wed, 1 May 2019 05:16:54 +0200 Subject: Revamp build system --- src/CMakeLists.txt | 29 ++++++++++++++++++ src/libui_sdl/CMakeLists.txt | 71 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 100 insertions(+) create mode 100644 src/CMakeLists.txt create mode 100644 src/libui_sdl/CMakeLists.txt (limited to 'src') diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt new file mode 100644 index 0000000..4b1149f --- /dev/null +++ b/src/CMakeLists.txt @@ -0,0 +1,29 @@ +project(core) + +add_library(core STATIC + ARM.cpp + ARMInterpreter.cpp + ARMInterpreter_ALU.cpp + ARMInterpreter_Branch.cpp + ARMInterpreter_LoadStore.cpp + Config.cpp + CP15.cpp + CRC32.cpp + DMA.cpp + GPU.cpp + GPU2D.cpp + GPU3D.cpp + GPU3D_Soft.cpp + NDS.cpp + NDSCart.cpp + RTC.cpp + Savestate.cpp + SPI.cpp + SPU.cpp + Wifi.cpp + WifiAP.cpp +) + +if (WIN32) + target_link_libraries(core ole32 comctl32 ws2_32) +endif() diff --git a/src/libui_sdl/CMakeLists.txt b/src/libui_sdl/CMakeLists.txt new file mode 100644 index 0000000..d703fb5 --- /dev/null +++ b/src/libui_sdl/CMakeLists.txt @@ -0,0 +1,71 @@ +project(libui_sdl) + +SET(SOURCES_LIBUI + main.cpp + Platform.cpp + PlatformConfig.cpp + LAN_Socket.cpp + LAN_PCap.cpp + DlgAudioSettings.cpp + DlgEmuSettings.cpp + DlgInputConfig.cpp + DlgWifiSettings.cpp + #libui/common/areaevents.c + #libui/common/control.c + #libui/common/debug.c + #libui/common/matrix.c + #libui/common/shouldquit.c + #libui/common/userbugs.c +) + +option(BUILD_SHARED_LIBS "Whether to build libui as a shared library or a static library" ON) +set(BUILD_SHARED_LIBS OFF) +add_subdirectory(libui) + +find_package(SDL2 REQUIRED) +include_directories(${SDL2_INCLUDE_DIR}) +#string(STRIP ${SDL2_LIBRARIES} SDL2_LIBRARIES) + +add_executable(melonDS ${SOURCES_LIBUI}) +target_link_libraries(melonDS + core ${SDL2_LIBRARIES} libui) + +if (UNIX) + find_package(PkgConfig REQUIRED) + pkg_check_modules(GTK3 REQUIRED gtk+-3.0) + pkg_check_modules(SDL2 REQUIRED sdl2) + + target_include_directories(melonDS + PRIVATE ${GTK3_INCLUDE_DIRS} ${SDL2_INCLUDE_DIRS} + ) + target_link_libraries(melonDS ${GTK3_LIBRARIES} ${SDL2_LIBRARIES}) + + ADD_DEFINITIONS(${GTK3_CFLAGS_OTHER}) + + # add_custom_command(OUTPUT melon_grc.c + # COMMAND glib-compile-resources + # --sourcedir="${CMAKE_SOURCE_DIR}" + # --target="${CMAKE_CURRENT_BINARY_DIR}/melon_grc.c" + # --generate-source --generate-header + # "${CMAKE_SOURCE_DIR}/melon_grc.xml" + # WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}) + add_custom_command(OUTPUT melon_grc.c + COMMAND glib-compile-resources --sourcedir="${CMAKE_SOURCE_DIR}" + --target="${CMAKE_CURRENT_BINARY_DIR}/melon_grc.c" + --generate-source "${CMAKE_SOURCE_DIR}/melon_grc.xml" + COMMAND glib-compile-resources --sourcedir="${CMAKE_SOURCE_DIR}" + --target="${CMAKE_CURRENT_BINARY_DIR}/melon_grc.h" + --generate-header "${CMAKE_SOURCE_DIR}/melon_grc.xml") + + if (CMAKE_SYSTEM_NAME STREQUAL "Linux") + target_link_libraries(melonDS dl) + endif () + + target_sources(melonDS PUBLIC melon_grc.c) +elseif (WIN32) + target_sources(melonDS PUBLIC "${CMAKE_SOURCE_DIR}/melon.rc") + target_include_directories(melonDS PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/..") + target_link_libraries(melonDS comctl32 d2d1 dwrite uxtheme ws2_32 iphlpapi) +endif () + +install(TARGETS melonDS RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/bin) -- cgit v1.2.3