mirror of
https://github.com/Ukendio/jecs.git
synced 2025-09-23 08:39:16 +00:00
Compare commits
4 commits
201cf6454c
...
5bf0d80ca4
Author | SHA1 | Date | |
---|---|---|---|
|
5bf0d80ca4 | ||
|
51b09549db | ||
|
a6c2d7152e | ||
|
f912866fcb |
2 changed files with 25 additions and 1 deletions
12
jecs.d.ts
vendored
12
jecs.d.ts
vendored
|
@ -338,10 +338,20 @@ export type ComponentRecord = {
|
||||||
|
|
||||||
export function component_record(world: World, id: Id): ComponentRecord;
|
export function component_record(world: World, id: Id): ComponentRecord;
|
||||||
|
|
||||||
|
type TagToUndefined<T> = T extends TagDiscriminator ? undefined : T
|
||||||
|
|
||||||
export function bulk_insert<const C extends Id[]>(
|
export function bulk_insert<const C extends Id[]>(
|
||||||
world: World,
|
world: World,
|
||||||
entity: Entity,
|
entity: Entity,
|
||||||
ids: C,
|
ids: C,
|
||||||
values: InferComponents<C>,
|
values: { [K in keyof C]: TagToUndefined<InferComponent<C[K]>> },
|
||||||
): void;
|
): void;
|
||||||
export function bulk_remove(world: World, entity: Entity, ids: Id[]): void;
|
export function bulk_remove(world: World, entity: Entity, ids: Id[]): void;
|
||||||
|
|
||||||
|
export type EntityRecord<T extends Id[]> = {
|
||||||
|
archetype: Archetype<T>,
|
||||||
|
row: number,
|
||||||
|
dense: number,
|
||||||
|
};
|
||||||
|
|
||||||
|
export function record<T extends Id[] = []>(world: World, entity: Entity): EntityRecord<T>;
|
||||||
|
|
14
jecs.luau
14
jecs.luau
|
@ -126,6 +126,8 @@ type world = {
|
||||||
|
|
||||||
max_component_id: number,
|
max_component_id: number,
|
||||||
max_archetype_id: number,
|
max_archetype_id: number,
|
||||||
|
start_component_id: number,
|
||||||
|
start_tag_id: number,
|
||||||
|
|
||||||
observable: Map<i53, Map<i53, { Observer }>>,
|
observable: Map<i53, Map<i53, { Observer }>>,
|
||||||
|
|
||||||
|
@ -163,6 +165,8 @@ export type World = {
|
||||||
|
|
||||||
max_component_id: number,
|
max_component_id: number,
|
||||||
max_archetype_id: number,
|
max_archetype_id: number,
|
||||||
|
start_component_id: number,
|
||||||
|
start_tag_id: number,
|
||||||
|
|
||||||
observable: Map<Id, Map<Id, { Observer }>>,
|
observable: Map<Id, Map<Id, { Observer }>>,
|
||||||
|
|
||||||
|
@ -760,6 +764,12 @@ local function ECS_ID_IS_WILDCARD(e: i53): boolean
|
||||||
return first == EcsWildcard or second == EcsWildcard
|
return first == EcsWildcard or second == EcsWildcard
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function get_max_ids_difference(world: World): (number, number)
|
||||||
|
local diff_components = world.start_component_id - ecs_max_component_id
|
||||||
|
local diff_tags = world.start_tag_id - ecs_max_tag_id
|
||||||
|
return diff_components, diff_tags
|
||||||
|
end
|
||||||
|
|
||||||
local function id_record_get(world: World, id: Entity): ComponentRecord?
|
local function id_record_get(world: World, id: Entity): ComponentRecord?
|
||||||
local component_index = world.component_index
|
local component_index = world.component_index
|
||||||
local idr: ComponentRecord = component_index[id]
|
local idr: ComponentRecord = component_index[id]
|
||||||
|
@ -2264,6 +2274,9 @@ local function world_new()
|
||||||
max_archetype_id = 0,
|
max_archetype_id = 0,
|
||||||
max_component_id = ecs_max_component_id,
|
max_component_id = ecs_max_component_id,
|
||||||
|
|
||||||
|
start_component_id = ecs_max_component_id,
|
||||||
|
start_tag_id = ecs_max_tag_id,
|
||||||
|
|
||||||
observable = observable,
|
observable = observable,
|
||||||
signals = signals,
|
signals = signals,
|
||||||
} :: world
|
} :: world
|
||||||
|
@ -3365,6 +3378,7 @@ return {
|
||||||
pair_first = ecs_pair_first :: <P, O>(world: World, pair: Pair<P, O>) -> Id<P>,
|
pair_first = ecs_pair_first :: <P, O>(world: World, pair: Pair<P, O>) -> Id<P>,
|
||||||
pair_second = ecs_pair_second :: <P, O>(world: World, pair: Pair<P, O>) -> Id<O>,
|
pair_second = ecs_pair_second :: <P, O>(world: World, pair: Pair<P, O>) -> Id<O>,
|
||||||
entity_index_get_alive = entity_index_get_alive,
|
entity_index_get_alive = entity_index_get_alive,
|
||||||
|
get_max_ids_difference = get_max_ids_difference,
|
||||||
|
|
||||||
archetype_append_to_records = archetype_append_to_records,
|
archetype_append_to_records = archetype_append_to_records,
|
||||||
id_record_ensure = id_record_ensure :: (World, Id) -> ComponentRecord,
|
id_record_ensure = id_record_ensure :: (World, Id) -> ComponentRecord,
|
||||||
|
|
Loading…
Reference in a new issue