diff options
| author | Nadia Holmquist Pedersen <nadia@nhp.sh> | 2019-05-01 05:16:54 +0200 | 
|---|---|---|
| committer | Nadia Holmquist Pedersen <nadia@nhp.sh> | 2019-05-01 05:16:54 +0200 | 
| commit | b31b5ed66a1353d06ebc5ef5e4de703e3ec48155 (patch) | |
| tree | 91a3ac7556c6e0483141d691655a7746c2f604ba /src | |
| parent | 85b3bdebd1258a13b3d28eeff5a7eef2d22fb5d9 (diff) | |
Revamp build system
Diffstat (limited to 'src')
| -rw-r--r-- | src/CMakeLists.txt | 29 | ||||
| -rw-r--r-- | src/libui_sdl/CMakeLists.txt | 71 | 
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)  |