A fast, portable Entity Component System for Luau. https://ukendio.github.io/jecs/
Find a file
renyang19910211 9b57189c3a
Some checks are pending
analysis / Run Luau Analyze (push) Waiting to run
deploy-docs / build (push) Waiting to run
deploy-docs / Deploy (push) Blocked by required conditions
publish-npm / publish (push) Waiting to run
unit-testing / Run Luau Tests (push) Waiting to run
Fix receive_replication.luau removed issue (#243)
2025-06-30 22:41:29 +02:00
.github Optimize column access 2025-06-25 17:16:04 +02:00
addons Optimize column access 2025-06-25 17:16:04 +02:00
assets Optimize column access 2025-06-25 17:16:04 +02:00
benches Optimize column access 2025-06-25 17:16:04 +02:00
demo Fix receive_replication.luau removed issue (#243) 2025-06-30 22:41:29 +02:00
docs Optimize column access 2025-06-25 17:16:04 +02:00
examples Optimize column access 2025-06-25 17:16:04 +02:00
test Optimize moving archetype 2025-06-30 22:37:30 +02:00
thesis Optimize column access 2025-06-25 17:16:04 +02:00
tools Optimize column access 2025-06-25 17:16:04 +02:00
.gitattributes Optimize column access 2025-06-25 17:16:04 +02:00
.gitignore Optimize column access 2025-06-25 17:16:04 +02:00
.luaurc Optimize column access 2025-06-25 17:16:04 +02:00
.prettierrc Optimize column access 2025-06-25 17:16:04 +02:00
.stylua.toml Optimize column access 2025-06-25 17:16:04 +02:00
bench.project.json Optimize column access 2025-06-25 17:16:04 +02:00
CHANGELOG.md bump 2025-06-27 15:58:33 +02:00
default.project.json Optimize column access 2025-06-25 17:16:04 +02:00
jecs.d.ts 0.7.3 (#247) 2025-06-30 00:40:03 +02:00
jecs.luau Optimize moving archetype 2025-06-30 22:37:30 +02:00
LICENSE Optimize column access 2025-06-25 17:16:04 +02:00
mirror.luau Optimize column access 2025-06-25 17:16:04 +02:00
package-lock.json Optimize column access 2025-06-25 17:16:04 +02:00
package.json 0.7.3 (#247) 2025-06-30 00:40:03 +02:00
README.md Optimize column access 2025-06-25 17:16:04 +02:00
rokit.toml Optimize column access 2025-06-25 17:16:04 +02:00
tsconfig.json Optimize column access 2025-06-25 17:16:04 +02:00
wally.toml 0.7.3 (#247) 2025-06-30 00:40:03 +02:00

License: MIT Wally GitHub Actions Workflow Status

Just a stupidly fast Entity Component System

  • Entity Relationships as first class citizens
  • Iterate 800,000 entities at 60 frames per second
  • Type-safe Luau API
  • Zero-dependency package
  • Optimized for column-major operations
  • Cache friendly archetype/SoA storage
  • Rigorously unit tested for stability

Installation

With Wally:

jecs = "ukendio/jecs@0.6.0" # Inside wally.toml

With pesde:

pesde add wally#ukendio/jecs@0.6.0

With npm (roblox-ts):

npm i @rbxts/jecs

Example

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)))

for e, name in world:query(Name, pair(ChildOf, alice)) do
    print(name, "is the child of alice")
end

-- Output
-- "alice"
-- bob is the child of alice
-- sara is the child of alice

Benchmarks

21,000 entities 125 archetypes 4 random components queried. Queries Can be found under /benches/visual/query.luau

Inserting 8 components to an entity and updating them over 50 times. Insertions Can be found under /benches/visual/insertions.luau