From 829ff4780c14ec4c881b6f4b5bb5a1f25964e564 Mon Sep 17 00:00:00 2001 From: veclavtalica Date: Mon, 10 Mar 2025 09:54:51 +0300 Subject: [PATCH] zig template --- CMakeLists.txt | 18 ++++++++++ apps/templates/zig/CMakeLists.txt | 24 +++++++++++++ apps/templates/zig/build.zig | 58 +++++++++++++++++++++++++++++++ apps/templates/zig/data/twn.toml | 27 ++++++++++++++ apps/templates/zig/src/root.zig | 24 +++++++++++++ apps/twnlua/CMakeLists.txt | 4 --- 6 files changed, 151 insertions(+), 4 deletions(-) create mode 100644 apps/templates/zig/CMakeLists.txt create mode 100644 apps/templates/zig/build.zig create mode 100644 apps/templates/zig/data/twn.toml create mode 100644 apps/templates/zig/src/root.zig diff --git a/CMakeLists.txt b/CMakeLists.txt index c3c452a..118a5cc 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -287,6 +287,24 @@ function(link_deps target) endfunction() +function(put_townengine output_directory) + cmake_path(GET TWN_OUT_DIR STEM LAST_ONLY target) + + add_executable(${target} ${TWN_ROOT_DIR}/src/twn_main.c) + target_link_options(${target} PRIVATE $<$:-Wl,-rpath,$ORIGIN/>) + set_target_properties(${TWN_TARGET} PROPERTIES + LIBRARY_OUTPUT_DIRECTORY ${output_directory}) + set_target_properties(${target} PROPERTIES + OUTPUT_NAME ${target} + LIBRARY_OUTPUT_DIRECTORY ${output_directory} + RUNTIME_OUTPUT_DIRECTORY ${output_directory}) + give_options(${target}) + include_deps(${target}) + link_deps(${target}) + target_link_libraries(${target} PUBLIC ${TWN_TARGET}) +endfunction() + + function(use_townengine sources output_directory) cmake_path(GET TWN_OUT_DIR STEM LAST_ONLY target) diff --git a/apps/templates/zig/CMakeLists.txt b/apps/templates/zig/CMakeLists.txt new file mode 100644 index 0000000..4b2a38e --- /dev/null +++ b/apps/templates/zig/CMakeLists.txt @@ -0,0 +1,24 @@ +cmake_minimum_required(VERSION 3.21) +project(twngame LANGUAGES C) + +if(NOT CMAKE_BUILD_TYPE) + set(CMAKE_BUILD_TYPE Debug) +endif() + +add_subdirectory($ENV{TWNROOT} ${CMAKE_BINARY_DIR}/twn) + +cmake_path(GET CMAKE_SOURCE_DIR STEM LAST_ONLY GAME_PROJECT_NAME) +put_townengine(${CMAKE_CURRENT_SOURCE_DIR}) + +# TODO: support static build +# TODO: propagate release switches +add_custom_command( + OUTPUT ${CMAKE_CURRENT_SOURCE_DIR}/libgame.so + COMMAND env zig build + DEPENDS ${TWN_TARGET} +) + +add_custom_target( + zig-step ALL + DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/libgame.so +) diff --git a/apps/templates/zig/build.zig b/apps/templates/zig/build.zig new file mode 100644 index 0000000..42cd7d0 --- /dev/null +++ b/apps/templates/zig/build.zig @@ -0,0 +1,58 @@ +const std = @import("std"); + +// Although this function looks imperative, note that its job is to +// declaratively construct a build graph that will be executed by an external +// runner. +pub fn build(b: *std.Build) void { + // Standard target options allows the person running `zig build` to choose + // what target to build for. Here we do not override the defaults, which + // means any target is allowed, and the default is native. Other options + // for restricting supported target set are available. + const target = b.standardTargetOptions(.{}); + + // Standard optimization options allow the person running `zig build` to select + // between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall. Here we do not + // set a preferred release mode, allowing the user to decide how to optimize. + const optimize = b.standardOptimizeOption(.{}); + + // This creates a "module", which represents a collection of source files alongside + // some compilation options, such as optimization mode and linked system libraries. + // Every executable or library we compile will be based on one or more modules. + const lib_mod = b.createModule(.{ + // `root_source_file` is the Zig "entry point" of the module. If a module + // only contains e.g. external object files, you can make this `null`. + // In this case the main source file is merely a path, however, in more + // complicated build scripts, this could be a generated file. + .root_source_file = b.path("src/root.zig"), + .target = target, + .optimize = optimize, + .link_libc = true, + }); + + lib_mod.addIncludePath(b.path("../../../")); + lib_mod.addIncludePath(b.path("../../../include/")); + lib_mod.addLibraryPath(b.path("./")); + + // Now, we will create a static library based on the module we created above. + // This creates a `std.Build.Step.Compile`, which is the build step responsible + // for actually invoking the compiler. + const lib = b.addLibrary(.{ + .linkage = .dynamic, + .name = "game", + .root_module = lib_mod, + }); + + lib.linkSystemLibrary("townengine"); + + // This declares intent for the library to be installed into the standard + // location when the user invokes the "install" step (the default step when + // running `zig build`). + const install_artifact = b.addInstallArtifact(lib, .{ + .dest_dir = .{ + .override = .{ + .custom = "../", + }, + }, + }); + b.getInstallStep().dependOn(&install_artifact.step); +} diff --git a/apps/templates/zig/data/twn.toml b/apps/templates/zig/data/twn.toml new file mode 100644 index 0000000..025f5ea --- /dev/null +++ b/apps/templates/zig/data/twn.toml @@ -0,0 +1,27 @@ +# This file contains everything about the engine and your game that can be +# configured before it runs. +# +# Optional settings are commented out, with their default values shown. +# Invalid values in these settings will be ignored. + +# Data about your game as an application +[about] +title = "Zig Awesomeness" +developer = "notwanp" +app_id = "yourzigthing" +dev_id = "definatelynotwanp" + +# Game runtime details +[game] +resolution = [ 640, 480 ] +background_color = [ 255, 125, 0, 255 ] +#debug = true + +# Engine tweaks. You probably don't need to change these +[engine] +#ticks_per_second = 60 # minimum of 8 +#keybind_slots = 3 # minimum of 1 +#texture_atlas_size = 2048 # minimum of 32 +#font_texture_size = 2048 # minimum of 1024 +#font_oversampling = 4 # minimum of 0 +#font_filtering = "linear" # possible values: "nearest", "linear" diff --git a/apps/templates/zig/src/root.zig b/apps/templates/zig/src/root.zig new file mode 100644 index 0000000..2b532d4 --- /dev/null +++ b/apps/templates/zig/src/root.zig @@ -0,0 +1,24 @@ +const std = @import("std"); +const c = @cImport({ + @cInclude("twn_game_api.h"); +}); + +export fn game_tick() void { + tick() catch |err| { + std.log.err(@errorName(err)); + }; +} + +export fn game_end() void { + end() catch |err| { + std.log.err(@errorName(err)); + }; +} + +fn tick() !void { + if (c.ctx.initialization_needed) { + std.debug.print("lmao\n", .{}); + } +} + +fn end() !void {} diff --git a/apps/twnlua/CMakeLists.txt b/apps/twnlua/CMakeLists.txt index d3fb9c8..d56e38f 100644 --- a/apps/twnlua/CMakeLists.txt +++ b/apps/twnlua/CMakeLists.txt @@ -9,10 +9,6 @@ endif() add_subdirectory($ENV{TWNROOT} ${CMAKE_BINARY_DIR}/twn) -set(FLAGS - $<$>:--no-dynlib-game> -) - add_custom_command( OUTPUT ${CMAKE_CURRENT_SOURCE_DIR}/game.c COMMAND ${Python3_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/bindgen.py $ENV{TWNROOT}/share/twn_api.json ${FLAGS} > ${CMAKE_CURRENT_SOURCE_DIR}/luabind.c