Skip to content

Commit

Permalink
Split table data from table implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
SanderMertens committed Sep 21, 2023
1 parent b1b4346 commit cd1fe3e
Show file tree
Hide file tree
Showing 11 changed files with 2,166 additions and 1,676 deletions.
1,919 changes: 1,082 additions & 837 deletions flecs.c

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion flecs.h
Original file line number Diff line number Diff line change
Expand Up @@ -3116,7 +3116,7 @@ extern "C" {
typedef struct ecs_stage_t ecs_stage_t;

/** Table data */
typedef struct ecs_data_t ecs_data_t;
typedef struct ecs_table_data_t ecs_table_data_t;

/* Switch list */
typedef struct ecs_switch_t ecs_switch_t;
Expand Down
2 changes: 1 addition & 1 deletion include/flecs/private/api_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ extern "C" {
typedef struct ecs_stage_t ecs_stage_t;

/** Table data */
typedef struct ecs_data_t ecs_data_t;
typedef struct ecs_table_data_t ecs_table_data_t;

/* Switch list */
typedef struct ecs_switch_t ecs_switch_t;
Expand Down
2 changes: 1 addition & 1 deletion src/bootstrap.c
Original file line number Diff line number Diff line change
Expand Up @@ -541,7 +541,7 @@ ecs_table_t* flecs_bootstrap_component_table(
};

ecs_table_t *result = flecs_table_find_or_create(world, &array);
ecs_data_t *data = flecs_table_data(result);
ecs_table_data_t *data = flecs_table_data(result);

/* Preallocate enough memory for initial components */
ecs_allocator_t *a = &world->allocator;
Expand Down
10 changes: 5 additions & 5 deletions src/entity.c
Original file line number Diff line number Diff line change
Expand Up @@ -260,7 +260,7 @@ void flecs_instantiate_children(
}

ecs_type_t type = child_table->type;
ecs_data_t *child_data = flecs_table_data(child_table);
ecs_table_data_t *child_data = flecs_table_data(child_table);

ecs_entity_t slot_of = 0;
ecs_entity_t *ids = type.array;
Expand Down Expand Up @@ -765,7 +765,7 @@ const ecs_entity_t* flecs_bulk_new(
component_array.count = type.count;
}

ecs_data_t *data = flecs_table_data(table);
ecs_table_data_t *data = flecs_table_data(table);
int32_t row = flecs_table_appendn(world, table, count, entities);

/* Update entity index. */
Expand Down Expand Up @@ -988,7 +988,7 @@ void flecs_notify_on_set(
bool owned)
{
ecs_assert(ids != NULL, ECS_INTERNAL_ERROR, NULL);
ecs_data_t *data = flecs_table_data(table);
ecs_table_data_t *data = flecs_table_data(table);

ecs_entity_t *entities = &flecs_table_entities_array(table)[row];
ecs_assert(entities != NULL, ECS_INTERNAL_ERROR, NULL);
Expand Down Expand Up @@ -3153,7 +3153,7 @@ void ecs_enable_id(
ecs_assert(index >= 0, ECS_INTERNAL_ERROR, NULL);

/* Data cannot be NULl, since entity is stored in the table */
ecs_bitset_t *bs = &flecs_table_data(table)->bs_columns[index];
ecs_bitset_t *bs = &flecs_table_data(table)->bitsets[index].data;
ecs_assert(bs != NULL, ECS_INTERNAL_ERROR, NULL);

flecs_bitset_set(bs, ECS_RECORD_TO_ROW(r->row), enable);
Expand Down Expand Up @@ -3191,7 +3191,7 @@ bool ecs_is_enabled_id(
ecs_assert(table->_ != NULL, ECS_INTERNAL_ERROR, NULL);
index -= flecs_table_data(table)->bs_offset;
ecs_assert(index >= 0, ECS_INTERNAL_ERROR, NULL);
ecs_bitset_t *bs = &flecs_table_data(table)->bs_columns[index];
ecs_bitset_t *bs = &flecs_table_data(table)->bitsets[index].data;

return flecs_bitset_get(bs, ECS_RECORD_TO_ROW(r->row));
error:
Expand Down
2 changes: 1 addition & 1 deletion src/entity_filter.c
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ int flecs_entity_filter_bitset_next(
if (!bs) {
int32_t index = column->column_index;
ecs_assert((index - bs_offset >= 0), ECS_INTERNAL_ERROR, NULL);
bs = &flecs_table_data(table)->bs_columns[index - bs_offset];
bs = &flecs_table_data(table)->bitsets[index - bs_offset].data;
terms[i].bs_column = bs;
}

Expand Down
2 changes: 1 addition & 1 deletion src/observable.c
Original file line number Diff line number Diff line change
Expand Up @@ -1056,7 +1056,7 @@ void flecs_emit(
const ecs_event_record_t *er_onset = flecs_event_record_get_if(observable, EcsOnSet);
const ecs_event_record_t *er_unset = flecs_event_record_get_if(observable, EcsUnSet);

ecs_data_t *storage = NULL;
ecs_table_data_t *storage = NULL;
ecs_column_t *columns = NULL;
if (count) {
storage = table->data;
Expand Down
Loading

0 comments on commit cd1fe3e

Please sign in to comment.