]> git.lizzy.rs Git - nothing.git/blobdiff - CMakeLists.txt
Merge pull request #708 from tsoding/704
[nothing.git] / CMakeLists.txt
index bb03c0160ac586bb34e094221948458c10bdce6c..fdc9a47f643619254c529e5805af5c422e4cf24d 100644 (file)
@@ -12,6 +12,7 @@ set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
 find_package(SDL2 REQUIRED)
 find_package(SDL2_mixer REQUIRED)
 
+include_directories(${CMAKE_BINARY_DIR})
 include_directories(src/)
 
 if(APPLE)
@@ -22,182 +23,139 @@ endif()
 
 include_directories(${SDL2_MIXER_INCLUDE_DIR})
 
-add_executable(nothing 
-  src/color.c
-  src/game.c
-  src/game/camera.c
-  src/ui/edit_field.c
-  src/game/level.c
-  src/game/level/background.c
-  src/game/level/boxes.c
-  src/game/level/goals.c
-  src/game/level/labels.c
-  src/game/level/lava.c
-  src/game/level/lava/wavy_rect.c
-  src/game/level/physical_world.c
-  src/game/level/platforms.c
-  src/game/level/player.c
-  src/game/level/player/dying_rect.c
-  src/game/level/player/rigid_rect.c
-  src/game/level/solid.c
-  src/game/sound_samples.c
-  src/game/sprite_font.c
-  src/main.c
-  src/math/mat3x3.c
-  src/math/point.c
-  src/math/rand.c
-  src/math/rect.c
-  src/math/triangle.c
+add_library(system STATIC
+  src/system/line_stream.c
+  src/system/line_stream.h
+  src/system/log.c
+  src/system/log.h
+  src/system/log_script.c
+  src/system/log_script.h
+  src/system/lt.c
+  src/system/lt.h
+  src/system/lt/lt_adapters.c
+  src/system/lt/lt_adapters.h
+  src/system/lt/lt_slot.c
+  src/system/lt/lt_slot.h
+  src/system/nth_alloc.c
+  src/system/nth_alloc.h
+  src/system/stacktrace.c
+  src/system/stacktrace.h
+  src/system/str.c
+  src/system/str.h
+  )
+
+add_library(ebisp STATIC
+  src/ebisp/builtins.c
+  src/ebisp/builtins.h
   src/ebisp/expr.c
+  src/ebisp/expr.h
+  src/ebisp/gc.c
+  src/ebisp/gc.h
   src/ebisp/interpreter.c
+  src/ebisp/interpreter.h
   src/ebisp/parser.c
-  src/ebisp/tokenizer.c
-  src/ebisp/gc.c
+  src/ebisp/parser.h
   src/ebisp/scope.c
-  src/sdl/renderer.c
-  src/system/lt.c
-  src/system/lt/lt_adapters.c
-  src/system/lt/lt_slot.c
-  src/ui/console.c
-  src/ui/console_log.c
-  src/str.c
-  src/ui/history.c
-  src/game/level/regions.c
+  src/ebisp/scope.h
+  src/ebisp/std.c
+  src/ebisp/std.h
+  src/ebisp/tokenizer.c
+  src/ebisp/tokenizer.h
+  )
+
+add_executable(nothing 
+  broadcast_lisp.h
+  src/broadcast.c
+  src/broadcast.h
+  src/color.c
   src/color.h
+  src/game.c
   src/game.h
+  src/game/camera.c
   src/game/camera.h
-  src/ui/edit_field.h
+  src/game/level.c
   src/game/level.h
+  src/game/level/background.c
   src/game/level/background.h
+  src/game/level/boxes.c
   src/game/level/boxes.h
+  src/game/level/goals.c
   src/game/level/goals.h
+  src/game/level/labels.c
   src/game/level/labels.h
+  src/game/level/lava.c
   src/game/level/lava.h
+  src/game/level/lava/wavy_rect.c
   src/game/level/lava/wavy_rect.h
-  src/game/level/physical_world.c
+  src/game/level/platforms.c
   src/game/level/platforms.h
+  src/game/level/player.c
   src/game/level/player.h
-  src/game/level/player/dying_rect.h
-  src/game/level/player/rigid_rect.h
-  src/game/level/solid.h
+  src/game/level/explosion.c
+  src/game/level/explosion.h
+  src/game/level/regions.c
+  src/game/level/regions.h
+  src/game/level/rigid_bodies.c
+  src/game/level/rigid_bodies.h
+  src/game/level/script.c
+  src/game/level/script.h
+  src/game/level_picker.c
+  src/game/level_picker.h
+  src/game/sound_samples.c
   src/game/sound_samples.h
+  src/game/sprite_font.c
   src/game/sprite_font.h
+  src/main.c
+  src/math/extrema.c
+  src/math/extrema.h
+  src/math/mat3x3.c
   src/math/mat3x3.h
   src/math/pi.h
+  src/math/point.c
   src/math/point.h
+  src/math/rand.c
   src/math/rand.h
+  src/math/rect.c
   src/math/rect.h
+  src/math/triangle.c
   src/math/triangle.h
-  src/ebisp/builtins.c
-  src/ebisp/builtins.h
-  src/ebisp/expr.h
-  src/ebisp/gc.h
-  src/ebisp/scope.h
-  src/ebisp/interpreter.h
-  src/ebisp/parser.h
-  src/ebisp/tokenizer.h
+  src/sdl/renderer.c
   src/sdl/renderer.h
-  src/system/lt.h
-  src/system/lt/lt_adapters.h
-  src/system/lt/lt_slot.h
+  src/ui/console.c
   src/ui/console.h
+  src/ui/console_log.c
   src/ui/console_log.h
-  src/str.h
+  src/ui/edit_field.c
+  src/ui/edit_field.h
+  src/ui/history.c
   src/ui/history.h
-  src/game/level/regions.h
-  src/system/line_stream.h
-  src/system/line_stream.c
-  src/game/level/script.h
-  src/game/level/script.c
-  src/system/log.h
-  src/system/log.c
-  src/system/log_script.h
-  src/system/log_script.c
-  src/system/nth_alloc.h
-  src/system/nth_alloc.c
-  src/game/level_script.c
-  src/game/level_script.h
-  src/ebisp/std.h
-  src/ebisp/std.c
-  src/system/stacktrace.h
-  src/system/stacktrace.c
-  src/game/level_picker.h
-  src/game/level_picker.c
-  src/game_script.h
-  src/game_script.c
 )
 
+add_custom_command(
+  OUTPUT broadcast_lisp.h
+  COMMAND ${CMAKE_BINARY_DIR}/baker ${CMAKE_SOURCE_DIR}/src/broadcast.lisp broadcast_lisp.h broadcast_lisp_library
+  DEPENDS baker src/broadcast.lisp)
+
 add_executable(repl
-  src/ebisp/builtins.c
-  src/ebisp/builtins.h
-  src/ebisp/expr.c
-  src/ebisp/expr.h
-  src/ebisp/interpreter.c
-  src/ebisp/interpreter.h
-  src/ebisp/parser.c
-  src/ebisp/parser.h
-  src/ebisp/scope.c
-  src/ebisp/scope.h
-  src/ebisp/tokenizer.c
-  src/ebisp/tokenizer.h
   src/ebisp/repl.c
-  src/system/lt.c
-  src/system/lt.h
-  src/system/lt/lt_adapters.c
-  src/system/lt/lt_adapters.h
-  src/system/lt/lt_slot.c
-  src/system/lt/lt_slot.h
-  src/ebisp/gc.h
-  src/ebisp/gc.c
-  src/str.h
-  src/str.c
-  src/system/log.h
-  src/system/log.c
-  src/system/nth_alloc.h
-  src/system/nth_alloc.c
-  src/ebisp/repl_runtime.h
   src/ebisp/repl_runtime.c
-  src/ebisp/std.h
-  src/ebisp/std.c
-  src/system/stacktrace.h
-  src/system/stacktrace.c
   )
+
+add_executable(baker
+  src/ebisp/baker.c
+  )
+
 add_executable(nothing_test
-  src/ebisp/builtins.c
-  src/ebisp/builtins.h
-  src/ebisp/expr.c
-  src/ebisp/expr.h
-  src/ebisp/interpreter.c
-  src/ebisp/interpreter.h
-  src/ebisp/parser.c
-  src/ebisp/parser.h
-  src/ebisp/scope.c
-  src/ebisp/scope.h
-  src/ebisp/tokenizer.c
-  src/ebisp/tokenizer.h
-  src/ebisp/gc.h
-  src/ebisp/gc.c
-  src/system/lt.c
-  src/system/lt.h
-  src/system/lt/lt_adapters.c
-  src/system/lt/lt_adapters.h
-  src/system/lt/lt_slot.c
-  src/system/lt/lt_slot.h
-  src/str.h
-  src/str.c
   test/main.c
   test/test.h
   test/tokenizer_suite.h
-  src/system/log.h
-  src/system/log.c
-  src/system/nth_alloc.h
-  src/system/nth_alloc.c
-  src/system/stacktrace.h
-  src/system/stacktrace.c
   )
-target_link_libraries(nothing ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m)
-target_link_libraries(nothing_test ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m)
-target_link_libraries(repl ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m)
+
+target_link_libraries(nothing ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m system ebisp)
+target_link_libraries(nothing_test ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m system ebisp)
+target_link_libraries(repl ${SDL2_LIBRARY} ${SDL2_MIXER_LIBRARY} m system ebisp)
+target_link_libraries(ebisp system)
+target_link_libraries(baker m system ebisp)
 
 if(("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU") OR ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "CLANG"))
   set(CMAKE_C_FLAGS