blob: b9b8a9339c1a18a220c86377cc59d2460ac0efaf (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
Daw
===
This branch contains the work of moving the engine to OpenGL, using GLFW & GLEW.
Major changes are made to the structure and will require changes to downstream
projects once done.
---
Daw is yet another hobby WIP game engine.
It is written in C99 and can be compiled and linked to easily in any CMake
project.
Currently it supports a very limited set of features:
* IO handling using input layers
* Window creation & 2D rendering (using SDL2 at the moment)
* Hot reloading
* Resource handling
* Memory handling
* UI (the input types are limited to buttons only at the moment)
* Logging
As well as a limited set of 2D grid-based game utilities:
* Pathfinding
* FOV calculations using shadowcasting
The engine is build around states. This means the developer needs to provide
initialize, update, and cleanup functions for each game state (states such as
"title screen", "game running", and such).
The whole project is made to be easily managed using CMake (yes, I too wonder
why sometimes).
Currently the only "supported" platform is linux. I do plan on adding windows
support in the future.
I plan on documenting how to use the engine as soon as I stop modifying the API,
and plan out a more solid organizational strategy for the project as a whole.
See [this CMakeLists.txt][0] to get an idea of how to use this project.
## Building
_At the moment building with statically linking is borked._
### Dependencies
These are the dependencies that you likely need to install yourself.
* assimp
* glad
* glfw
* stb
Other dependencies are pulled automatically.
### Building fr
Generate the build files using
```
cmake -S . -B build
```
And build the project with
```
cmake --build build
```
This should, in theory, build the engine as a shared library and run without any
warnings nor errors.
The way the engine is designed, it is very useless as a shared library, and does
nothing if it is not configured as a subproject of the "game" itself.
See [tools/cmake/DawAddState.cmake](tools/cmake/DawAddState.cmake) for more information.
## Planned features
This is an incomplete list of features that are either under development or
planned to implement.
* Audio
* GLFW & OpenGL
* Better cross platform support (ie. windows)
[0]: https://github.com/0undefined/rogue/blob/a947b0092d91920d56eb9af6a39bd1bd05e145fc/CMakeLists.txt
|