mirror of
https://github.com/BlackMATov/evolved.lua.git
synced 2025-12-16 14:11:16 +07:00
Merge branch 'dev'
This commit is contained in:
13
README.md
13
README.md
@@ -36,6 +36,7 @@ ON_INSERT :: fragment
|
|||||||
ON_REMOVE :: fragment
|
ON_REMOVE :: fragment
|
||||||
|
|
||||||
PHASE :: fragment
|
PHASE :: fragment
|
||||||
|
GROUP :: fragment
|
||||||
AFTER :: fragment
|
AFTER :: fragment
|
||||||
|
|
||||||
QUERY :: fragment
|
QUERY :: fragment
|
||||||
@@ -148,6 +149,15 @@ query_builder:exclude :: fragment... -> query_builder
|
|||||||
query_builder:build :: query, boolean
|
query_builder:build :: query, boolean
|
||||||
```
|
```
|
||||||
|
|
||||||
|
```
|
||||||
|
group :: group_builder
|
||||||
|
group_builder:name :: string -> group_builder
|
||||||
|
group_builder:single :: component -> group_builder
|
||||||
|
group_builder:phase :: phase -> group_builder
|
||||||
|
group_builder:after :: group... -> group_builder
|
||||||
|
group_builder:build :: group, boolean
|
||||||
|
```
|
||||||
|
|
||||||
```
|
```
|
||||||
phase :: phase_builder
|
phase :: phase_builder
|
||||||
phase_builder:name :: string -> phase_builder
|
phase_builder:name :: string -> phase_builder
|
||||||
@@ -159,8 +169,7 @@ phase_builder:build :: phase, boolean
|
|||||||
system :: system_builder
|
system :: system_builder
|
||||||
system_builder:name :: string -> system_builder
|
system_builder:name :: string -> system_builder
|
||||||
system_builder:single :: component -> system_builder
|
system_builder:single :: component -> system_builder
|
||||||
system_builder:phase :: phase -> system_builder
|
system_builder:group :: group -> system_builder
|
||||||
system_builder:after :: system... -> system_builder
|
|
||||||
system_builder:query :: query -> system_builder
|
system_builder:query :: query -> system_builder
|
||||||
system_builder:execute :: {chunk, entity[], integer} -> system_builder
|
system_builder:execute :: {chunk, entity[], integer} -> system_builder
|
||||||
system_builder:prologue :: {} -> system_builder
|
system_builder:prologue :: {} -> system_builder
|
||||||
|
|||||||
@@ -3,10 +3,13 @@
|
|||||||
## Backlog
|
## Backlog
|
||||||
|
|
||||||
- should set/assign/insert return a constructed component?
|
- should set/assign/insert return a constructed component?
|
||||||
|
- enable/disable systems and groups
|
||||||
|
- should systems support multiple groups?
|
||||||
|
- should groups support multiple phases?
|
||||||
|
|
||||||
## After first release
|
## After first release
|
||||||
|
|
||||||
- add system groups
|
- cached queries
|
||||||
- observers and events
|
- observers and events
|
||||||
- add INDEX fragment trait
|
- add INDEX fragment trait
|
||||||
- add REQUIRES fragment trait
|
- add REQUIRES fragment trait
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
require 'develop.example'
|
require 'develop.example'
|
||||||
-- require 'develop.unbench'
|
require 'develop.unbench'
|
||||||
require 'develop.untests'
|
require 'develop.untests'
|
||||||
-- require 'develop.usbench'
|
require 'develop.usbench'
|
||||||
|
|||||||
@@ -22,6 +22,13 @@ local phases = {
|
|||||||
shutdown = evo.phase():build(),
|
shutdown = evo.phase():build(),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local groups = {
|
||||||
|
awake = evo.group():phase(phases.awake):build(),
|
||||||
|
physics = evo.group():phase(phases.physics):build(),
|
||||||
|
graphics = evo.group():phase(phases.graphics):build(),
|
||||||
|
shutdown = evo.group():phase(phases.shutdown):build(),
|
||||||
|
}
|
||||||
|
|
||||||
local singles = {
|
local singles = {
|
||||||
delta_time = evo.fragment():single(0.016):build(),
|
delta_time = evo.fragment():single(0.016):build(),
|
||||||
physics_gravity = evo.fragment():single(vector2(0, 9.81)):build(),
|
physics_gravity = evo.fragment():single(vector2(0, 9.81)):build(),
|
||||||
@@ -40,7 +47,7 @@ local queries = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local awake_system = evo.system()
|
local awake_system = evo.system()
|
||||||
:phase(phases.awake)
|
:group(groups.awake)
|
||||||
:prologue(function()
|
:prologue(function()
|
||||||
print '-= | Awake | =-'
|
print '-= | Awake | =-'
|
||||||
evo.entity()
|
evo.entity()
|
||||||
@@ -51,7 +58,7 @@ local awake_system = evo.system()
|
|||||||
end):build()
|
end):build()
|
||||||
|
|
||||||
local integrate_forces_system = evo.system()
|
local integrate_forces_system = evo.system()
|
||||||
:phase(phases.physics)
|
:group(groups.physics)
|
||||||
:query(queries.physics_bodies)
|
:query(queries.physics_bodies)
|
||||||
:execute(function(chunk, entities, entity_count)
|
:execute(function(chunk, entities, entity_count)
|
||||||
---@type number, evolved.vector2
|
---@type number, evolved.vector2
|
||||||
@@ -72,8 +79,7 @@ local integrate_forces_system = evo.system()
|
|||||||
end):build()
|
end):build()
|
||||||
|
|
||||||
local integrate_velocities_system = evo.system()
|
local integrate_velocities_system = evo.system()
|
||||||
:phase(phases.physics)
|
:group(groups.physics)
|
||||||
:after(integrate_forces_system)
|
|
||||||
:query(queries.physics_bodies)
|
:query(queries.physics_bodies)
|
||||||
:execute(function(chunk, entities, entity_count)
|
:execute(function(chunk, entities, entity_count)
|
||||||
---@type number
|
---@type number
|
||||||
@@ -96,7 +102,7 @@ local integrate_velocities_system = evo.system()
|
|||||||
end):build()
|
end):build()
|
||||||
|
|
||||||
local graphics_system = evo.system()
|
local graphics_system = evo.system()
|
||||||
:phase(phases.graphics)
|
:group(groups.graphics)
|
||||||
:query(queries.physics_bodies)
|
:query(queries.physics_bodies)
|
||||||
:execute(function(chunk, entities, entity_count)
|
:execute(function(chunk, entities, entity_count)
|
||||||
---@type evolved.vector2[]
|
---@type evolved.vector2[]
|
||||||
@@ -113,7 +119,7 @@ local graphics_system = evo.system()
|
|||||||
end):build()
|
end):build()
|
||||||
|
|
||||||
local shutdown_system = evo.system()
|
local shutdown_system = evo.system()
|
||||||
:phase(phases.shutdown)
|
:group(groups.shutdown)
|
||||||
:epilogue(function()
|
:epilogue(function()
|
||||||
print '-= | Shutdown | =-'
|
print '-= | Shutdown | =-'
|
||||||
evo.batch_destroy(queries.physics_bodies)
|
evo.batch_destroy(queries.physics_bodies)
|
||||||
|
|||||||
@@ -6569,26 +6569,6 @@ do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
do
|
|
||||||
local s1 = evo.system():build()
|
|
||||||
do
|
|
||||||
local after = evo.get(s1, evo.AFTER)
|
|
||||||
assert(after == nil)
|
|
||||||
end
|
|
||||||
|
|
||||||
local s2 = evo.system():after(s1):build()
|
|
||||||
do
|
|
||||||
local after = evo.get(s2, evo.AFTER)
|
|
||||||
assert(#after == 1 and after[1] == s1)
|
|
||||||
end
|
|
||||||
|
|
||||||
local s3 = evo.system():after(s1, s2):build()
|
|
||||||
do
|
|
||||||
local after = evo.get(s3, evo.AFTER)
|
|
||||||
assert(#after == 2 and after[1] == s1 and after[2] == s2)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
do
|
do
|
||||||
local f1, f2 = evo.id(2)
|
local f1, f2 = evo.id(2)
|
||||||
|
|
||||||
@@ -8202,3 +8182,43 @@ do
|
|||||||
assert(not evo.is_alive_any(e1a, e1b, e12a, e12b))
|
assert(not evo.is_alive_any(e1a, e1b, e12a, e12b))
|
||||||
assert(evo.is_empty_all(e1a, e1b, e12a, e12b))
|
assert(evo.is_empty_all(e1a, e1b, e12a, e12b))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
do
|
||||||
|
local gb = evo.group()
|
||||||
|
|
||||||
|
local g1 = gb:build()
|
||||||
|
local g2 = gb:name('g2'):build()
|
||||||
|
local g3 = gb:single(42):build()
|
||||||
|
local g4 = gb:name('g4'):single(43):build()
|
||||||
|
|
||||||
|
assert(not evo.has(g1, evo.NAME) and not evo.has(g1, g1))
|
||||||
|
assert(evo.get(g2, evo.NAME) == 'g2' and not evo.has(g2, g2))
|
||||||
|
assert(not evo.has(g3, evo.NAME) and evo.get(g3, g3) == 42)
|
||||||
|
assert(evo.get(g4, evo.NAME) == 'g4' and evo.get(g4, g4) == 43)
|
||||||
|
end
|
||||||
|
|
||||||
|
do
|
||||||
|
local g = evo.group():build()
|
||||||
|
local s = evo.system():group(g):build()
|
||||||
|
assert(evo.get(s, evo.GROUP) == g)
|
||||||
|
end
|
||||||
|
|
||||||
|
do
|
||||||
|
local s1 = evo.group():build()
|
||||||
|
do
|
||||||
|
local after = evo.get(s1, evo.AFTER)
|
||||||
|
assert(after == nil)
|
||||||
|
end
|
||||||
|
|
||||||
|
local g2 = evo.group():after(s1):build()
|
||||||
|
do
|
||||||
|
local after = evo.get(g2, evo.AFTER)
|
||||||
|
assert(#after == 1 and after[1] == s1)
|
||||||
|
end
|
||||||
|
|
||||||
|
local g3 = evo.group():after(s1, g2):build()
|
||||||
|
do
|
||||||
|
local after = evo.get(g3, evo.AFTER)
|
||||||
|
assert(#after == 2 and after[1] == s1 and after[2] == g2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|||||||
819
evolved.lua
819
evolved.lua
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user