aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNadia Holmquist Pedersen <nadia@nhp.sh>2019-05-01 05:16:54 +0200
committerNadia Holmquist Pedersen <nadia@nhp.sh>2019-05-01 05:16:54 +0200
commitb31b5ed66a1353d06ebc5ef5e4de703e3ec48155 (patch)
tree91a3ac7556c6e0483141d691655a7746c2f604ba /src
parent85b3bdebd1258a13b3d28eeff5a7eef2d22fb5d9 (diff)
Revamp build system
Diffstat (limited to 'src')
-rw-r--r--src/CMakeLists.txt29
-rw-r--r--src/libui_sdl/CMakeLists.txt71
2 files changed, 100 insertions, 0 deletions
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)