jecs/README.md

50 lines
1.2 KiB
Markdown
Raw Normal View History

2025-06-10 22:53:32 +00:00
jecs jit
----------------------------------------------
2024-11-23 03:42:54 +00:00
2025-06-10 22:53:32 +00:00
Standalone ecs module in luajit that can iterate 800,000 entities at 60 frames per second with pure lua. Comes with support for entity relationships, zero-sized-tags, query caching and more.
2024-11-23 03:42:54 +00:00
2025-05-24 20:38:53 +00:00
### Installation
2025-06-10 22:53:32 +00:00
If you are on the luajit branch, the recommended approach to install the library is just copy-pasting the source at jecs.lua
2025-05-24 20:38:53 +00:00
2024-11-23 03:42:54 +00:00
### Example
```lua
local world = jecs.World.new()
local pair = jecs.pair
-- These components and functions are actually already builtin
-- but have been illustrated for demonstration purposes
local ChildOf = world:component()
local Name = world:component()
local function parent(entity)
return world:target(entity, ChildOf)
end
local function getName(entity)
return world:get(entity, Name)
end
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)))
2025-06-12 23:04:06 +00:00
for e, name in world:query(Name, pair(ChildOf, alice)) do
print(name, "is the child of alice")
2024-11-23 03:42:54 +00:00
end
-- Output
-- "alice"
-- bob is the child of alice
-- sara is the child of alice
```