2024-05-03 12:45:11 +00:00
|
|
|
|
|
|
|
<p align="center">
|
2024-05-07 16:37:14 +00:00
|
|
|
<img src="jecs_darkmode.svg#gh-dark-mode-only" width=50%/>
|
|
|
|
<img src="jecs_lightmode.svg#gh-light-mode-only" width=50%/>
|
2024-05-03 12:45:11 +00:00
|
|
|
</p>
|
|
|
|
|
|
|
|
[](LICENSE-APACHE)
|
|
|
|
[](https://wally.run/package/ukendio/jecs)
|
2024-04-23 16:12:46 +00:00
|
|
|
|
2024-04-23 15:10:49 +00:00
|
|
|
Just an ECS
|
|
|
|
|
2024-05-02 13:33:31 +00:00
|
|
|
jecs is a stupidly fast Entity Component System (ECS).
|
2024-04-23 16:12:46 +00:00
|
|
|
|
2024-05-10 16:09:34 +00:00
|
|
|
- Entity Relationships as first class citizens
|
2024-05-24 00:58:33 +00:00
|
|
|
- Iterate 350,000 entities at 60 frames per second
|
2024-05-10 16:09:34 +00:00
|
|
|
- Type-safe [Luau](https://luau-lang.org/) API
|
|
|
|
- Zero-dependency package
|
2024-04-23 16:12:46 +00:00
|
|
|
- Optimized for column-major operations
|
2024-05-02 13:33:31 +00:00
|
|
|
- Cache friendly archetype/SoA storage
|
2024-05-10 16:09:34 +00:00
|
|
|
- Unit tested for stability
|
2024-04-23 16:12:46 +00:00
|
|
|
|
|
|
|
### Example
|
|
|
|
|
|
|
|
```lua
|
2024-05-16 22:17:53 +00:00
|
|
|
local world = jecs.World.new()
|
|
|
|
local pair = jecs.pair
|
|
|
|
|
|
|
|
local ChildOf = world:component()
|
|
|
|
local Name = world:component()
|
|
|
|
|
|
|
|
local function parent(entity)
|
|
|
|
return world:target(entity, ChildOf)
|
2024-05-10 15:59:57 +00:00
|
|
|
end
|
2024-05-16 22:19:53 +00:00
|
|
|
local function name(entity)
|
|
|
|
return world:get(entity, Name)
|
|
|
|
end
|
2024-05-16 22:17:53 +00:00
|
|
|
|
|
|
|
local alice = world:entity()
|
|
|
|
world:set(alice, Name, "alice")
|
|
|
|
|
|
|
|
local bob = world:entity()
|
|
|
|
world:add(bob, pair(ChildOf, alice))
|
|
|
|
world:set(bob, Name, "bob")
|
|
|
|
|
|
|
|
local sara = world:entity()
|
|
|
|
world:add(sara, pair(ChildOf, alice))
|
|
|
|
world:set(sara, Name, "sara")
|
|
|
|
|
|
|
|
print(getName(parent(sara)))
|
2024-04-23 16:12:46 +00:00
|
|
|
|
2024-05-16 22:17:53 +00:00
|
|
|
for e in world:query(pair(ChildOf, alice)) do
|
|
|
|
print(getName(e), "is the child of alice")
|
2024-04-23 16:12:46 +00:00
|
|
|
end
|
|
|
|
|
2024-05-16 22:17:53 +00:00
|
|
|
-- Output
|
|
|
|
-- "alice"
|
|
|
|
-- bob is the child of alice
|
|
|
|
-- sara is the child of alice
|
2024-04-24 00:23:15 +00:00
|
|
|
```
|
2024-05-02 13:33:31 +00:00
|
|
|
|
2024-04-25 22:10:34 +00:00
|
|
|
125 archetypes, 4 random components queried.
|
2024-04-30 15:52:44 +00:00
|
|
|

|
|
|
|
Can be found under /benches/query.lua
|
|
|
|
|
|
|
|
Inserting 8 components to an entity and updating them over 50 times.
|
|
|
|

|
2024-05-02 13:33:31 +00:00
|
|
|
Can be found under /benches/insertions.lua
|