Parallel-by-default game framework written in Zig
Go to file
kayomn 5f94d1ca5f
continuous-integration/drone/push Build is passing Details
Tidy up logical flow
2024-07-22 00:03:24 +01:00
.vscode
debug Implement CRT shader effect support 2024-07-21 18:59:28 +01:00
ext
src Tidy up logical flow 2024-07-22 00:03:24 +01:00
.drone.yml Merge build and test stages of new CI 2024-07-07 01:44:26 +02:00
.gitattributes
.gitignore
.gitmodules
build.zig Implement effects pipelining system 2024-07-20 13:46:06 +01:00
build.zig.zon
readme.md Update dependencies in readme 2024-07-20 15:23:47 +01:00

readme.md

Ona

Table of Contents

  1. Overview
  2. Goals
  3. Technical Details
    1. Requirements
    2. Building

Overview

Ona is a straightforward game engine with the aim of staying reasonably lightweight through a modular architecture.

Ona is also the Catalan word for "wave".

Goals

  • Fully-featured two-dimensional raster and vector rendering capabilities.

  • Support major computer gaming ecosystems; Namely Microsoft Windows, SteamOS, Unix-like systems, and the web.

  • Minimize external dependencies.

  • Provide utilities for handling rendering but otherwise leave the higher-level game logic and data structuring to the programmer.

  • Enforce an architecture that makes non-interdependent logic trivially parallelizable.

Technical Details

Requirements

Ona currently depends the following third-party tools to build it:

  • Platform support for SDL2 at version 2.0.20 or above.
  • SPIR-V shader compilation system utilities, namely glslangValidator.
  • Zig compiler toolchain.

As the project evolves, dependencies on libraries external to the project codebase will be minimized or removed outright to meet the goals of the project as closely as possible.

Building

Once all third-party tools and system-wide dependencies are satisfied, navigate to the root project folder and run zig build to build everything.