summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authoromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-10-17 16:49:11 +1100
committeromniscient <17525998+omnisci3nce@users.noreply.github.com>2024-10-17 16:49:11 +1100
commit3e1aea0243f54e0b68baa3b19ac19f3d965484e0 (patch)
tree9f6e6d691be59ed328ffd716a0f56a2e33dbdf3d /include
parent16afbddeada7161e931dc261d3404bb5bbc1743d (diff)
start on metal backend
Diffstat (limited to 'include')
-rw-r--r--include/celeritas.h19
1 files changed, 18 insertions, 1 deletions
diff --git a/include/celeritas.h b/include/celeritas.h
index 0437e15..c157918 100644
--- a/include/celeritas.h
+++ b/include/celeritas.h
@@ -78,6 +78,7 @@ struct GLFWwindow* get_window();
struct core {
const char* app_name;
struct GLFWwindow* window;
+ bool should_exit;
renderer* renderer;
input_state* input;
};
@@ -238,7 +239,6 @@ DEFINE_HANDLE(pipeline_handle);
#define MAX_SHADER_BINDINGS 16
// Backend-specific structs
-typedef struct gpu_device gpu_device;
typedef struct gpu_swapchain gpu_swapchain;
typedef struct gpu_compute_pipeline gpu_compute_pipeline;
typedef struct gpu_gfx_pipeline gpu_gfx_pipeline;
@@ -341,11 +341,21 @@ typedef struct gfx_pipeline_desc {
} gfx_pipeline_desc;
// --- RAL Functions
+
+// Resources
buf_handle ral_buffer_create(u64 size, const void* data);
void ral_buffer_destroy(buf_handle handle);
tex_handle ral_texture_create(texture_desc desc, bool create_view, const void* data);
void ral_texture_destroy(tex_handle handle);
+// Backend lifecycle
+void ral_backend_init(const char* window_name, struct GLFWwindow* window);
+void ral_backend_shutdown();
+
+// Frame lifecycle
+void ral_frame_start();
+void ral_frame_end();
+
// --- Containers (Forward declared as internals are unnecessary for external header)
typedef struct u32_darray u32_darray;
@@ -381,6 +391,11 @@ geometry geo_cone(f32 radius, f32 height, u32 resolution);
geometry geo_uv_sphere(f32 radius, u32 north_south_lines, u32 east_west_lines);
geometry geo_ico_sphere(f32 radius, f32 n_subdivisions);
+// --- Renderer
+
+// void renderer_init(renderer* rend);
+// void renderer_shutdown(renderer* rend);
+
// --- Scene / Transform Hierarchy
// --- Gameplay
@@ -407,6 +422,8 @@ model_handle model_load_from_gltf(const char* path);
// --- Animation
+// Compute shader approach so we only need one kind of vertex format
+
// --- Collisions
// --- Physics