Flecs v4.0
A fast entity component system (ECS) for C & C++
Loading...
Searching...
No Matches
flecs.h
Go to the documentation of this file.
1
8#ifndef FLECS_H
9#define FLECS_H
10
33/* Flecs version macros */
34#define FLECS_VERSION_MAJOR 4
35#define FLECS_VERSION_MINOR 1
36#define FLECS_VERSION_PATCH 0
39#define FLECS_VERSION FLECS_VERSION_IMPL(\
40 FLECS_VERSION_MAJOR, FLECS_VERSION_MINOR, FLECS_VERSION_PATCH)
41
45#ifdef FLECS_CONFIG_HEADER
46#include "flecs_config.h"
47#endif
48
51#ifndef ecs_float_t
52#define ecs_float_t float
53#endif
54
58#ifndef ecs_ftime_t
59#define ecs_ftime_t ecs_float_t
60#endif
61
65// #define FLECS_LEGACY
66
72// #define FLECS_ACCURATE_COUNTERS
73
79// #define FLECS_DISABLE_COUNTERS
80
81/* Make sure provided configuration is valid */
82#if defined(FLECS_DEBUG) && defined(FLECS_NDEBUG)
83#warning "invalid configuration: cannot both define FLECS_DEBUG and FLECS_NDEBUG"
84#endif
85#if defined(FLECS_DEBUG) && defined(NDEBUG)
86#warning "invalid configuration: cannot both define FLECS_DEBUG and NDEBUG"
87#endif
88
93#if !defined(FLECS_DEBUG) && !defined(FLECS_NDEBUG)
94#if defined(NDEBUG)
95#define FLECS_NDEBUG
96#else
97#define FLECS_DEBUG
98#endif
99#endif
100
105#ifdef FLECS_SANITIZE
106#ifndef FLECS_DEBUG
107#define FLECS_DEBUG /* If sanitized mode is enabled, so is debug mode */
108#endif
109#endif
110
115#ifdef FLECS_DEBUG
116#ifndef FLECS_DEBUG_INFO
117#define FLECS_DEBUG_INFO
118#endif
119#endif
120
121/* Tip: if you see weird behavior that you think might be a bug, make sure to
122 * test with the FLECS_DEBUG or FLECS_SANITIZE flags enabled. There's a good
123 * chance that this gives you more information about the issue! */
124
138// #define FLECS_SOFT_ASSERT
139
145// #define FLECS_KEEP_ASSERT
146
153// #define FLECS_DEFAULT_TO_UNCACHED_QUERIES
154
163// #define FLECS_CPP_NO_AUTO_REGISTRATION
164
172// #define FLECS_CPP_NO_ENUM_REFLECTION
173
178// #define FLECS_NO_ALWAYS_INLINE
179
207// #define FLECS_CUSTOM_BUILD
208
209#ifndef FLECS_CUSTOM_BUILD
210#define FLECS_ALERTS
211#define FLECS_APP
212// #define FLECS_C /**< C API convenience macros, always enabled */
213#define FLECS_CPP
214#define FLECS_DOC
215// #define FLECS_JOURNAL /**< Journaling addon */
216#define FLECS_JSON
217#define FLECS_HTTP
218#define FLECS_LOG
219#define FLECS_META
220#define FLECS_METRICS
221#define FLECS_MODULE
222#define FLECS_OS_API_IMPL
223// #define FLECS_PERF_TRACE /**< Enable performance tracing */
224#define FLECS_PIPELINE
225#define FLECS_REST
226#define FLECS_PARSER
227#define FLECS_QUERY_DSL
228#define FLECS_SCRIPT
229// #define FLECS_SCRIPT_MATH /**< Math functions for flecs script (may require linking with libm) */
230#define FLECS_SYSTEM
231#define FLECS_STATS
232#define FLECS_TIMER
233#define FLECS_UNITS
234#endif // ifndef FLECS_CUSTOM_BUILD
235
239// #define FLECS_LOW_FOOTPRINT
240#ifdef FLECS_LOW_FOOTPRINT
241#define FLECS_HI_COMPONENT_ID (16)
242#define FLECS_HI_ID_RECORD_ID (16)
243#define FLECS_ENTITY_PAGE_BITS (6)
244#define FLECS_USE_OS_ALLOC
245#define FLECS_DEFAULT_TO_UNCACHED_QUERIES
246#endif
247
262#ifndef FLECS_HI_COMPONENT_ID
263#define FLECS_HI_COMPONENT_ID (256)
264#endif
265
272#ifndef FLECS_HI_ID_RECORD_ID
273#define FLECS_HI_ID_RECORD_ID (1024)
274#endif
275
281#ifndef FLECS_SPARSE_PAGE_BITS
282#define FLECS_SPARSE_PAGE_BITS (6)
283#endif
284
287#ifndef FLECS_ENTITY_PAGE_BITS
288#define FLECS_ENTITY_PAGE_BITS (10)
289#endif
290
295// #define FLECS_USE_OS_ALLOC
296
299#ifndef FLECS_ID_DESC_MAX
300#define FLECS_ID_DESC_MAX (32)
301#endif
302
305#ifndef FLECS_EVENT_DESC_MAX
306#define FLECS_EVENT_DESC_MAX (8)
307#endif
308
311#define FLECS_VARIABLE_COUNT_MAX (64)
312
315#ifndef FLECS_TERM_COUNT_MAX
316#define FLECS_TERM_COUNT_MAX 32
317#endif
318
321#ifndef FLECS_TERM_ARG_COUNT_MAX
322#define FLECS_TERM_ARG_COUNT_MAX (16)
323#endif
324
327#ifndef FLECS_QUERY_VARIABLE_COUNT_MAX
328#define FLECS_QUERY_VARIABLE_COUNT_MAX (64)
329#endif
330
333#ifndef FLECS_QUERY_SCOPE_NESTING_MAX
334#define FLECS_QUERY_SCOPE_NESTING_MAX (8)
335#endif
336
341#ifndef FLECS_DAG_DEPTH_MAX
342#define FLECS_DAG_DEPTH_MAX (128)
343#endif
344
347#include "flecs/private/api_defines.h"
348
358typedef uint64_t ecs_id_t;
359
366
382typedef struct {
384 int32_t count;
385} ecs_type_t;
386
410
413
416
418typedef struct ecs_term_t ecs_term_t;
419
422
441
446
451typedef struct ecs_iter_t ecs_iter_t;
452
461typedef struct ecs_ref_t ecs_ref_t;
462
467
472
475
478
498typedef void ecs_poly_t;
499
502
509
510typedef struct ecs_table_record_t ecs_table_record_t;
511
514#include "flecs/datastructures/vec.h" /* Vector datatype */
515#include "flecs/datastructures/sparse.h" /* Sparse set */
516#include "flecs/datastructures/block_allocator.h" /* Block allocator */
517#include "flecs/datastructures/stack_allocator.h" /* Stack allocator */
518#include "flecs/datastructures/map.h" /* Map */
519#include "flecs/datastructures/allocator.h" /* Allocator */
520#include "flecs/datastructures/strbuf.h" /* String builder */
521#include "flecs/os_api.h" /* Abstraction for operating system functions */
522
523#ifdef __cplusplus
524extern "C" {
525#endif
526
551typedef void (*ecs_run_action_t)(
552 ecs_iter_t *it);
553
560typedef void (*ecs_iter_action_t)(
561 ecs_iter_t *it);
562
571 ecs_iter_t *it);
572
579 ecs_iter_t *it);
580
583 ecs_entity_t e1,
584 const void *ptr1,
585 ecs_entity_t e2,
586 const void *ptr2);
587
590 ecs_world_t* world,
591 ecs_table_t* table,
592 ecs_entity_t* entities,
593 void* ptr,
594 int32_t size,
595 int32_t lo,
596 int32_t hi,
597 ecs_order_by_action_t order_by);
598
600typedef uint64_t (*ecs_group_by_action_t)(
601 ecs_world_t *world,
602 ecs_table_t *table,
603 ecs_id_t group_id,
604 void *ctx);
605
607typedef void* (*ecs_group_create_action_t)(
608 ecs_world_t *world,
609 uint64_t group_id,
610 void *group_by_ctx); /* from ecs_query_desc_t */
611
614 ecs_world_t *world,
615 uint64_t group_id,
616 void *group_ctx, /* return value from ecs_group_create_action_t */
617 void *group_by_ctx); /* from ecs_query_desc_t */
618
620typedef void (*ecs_module_action_t)(
621 ecs_world_t *world);
622
624typedef void (*ecs_fini_action_t)(
625 ecs_world_t *world,
626 void *ctx);
627
629typedef void (*ecs_ctx_free_t)(
630 void *ctx);
631
633typedef int (*ecs_compare_action_t)(
634 const void *ptr1,
635 const void *ptr2);
636
638typedef uint64_t (*ecs_hash_value_action_t)(
639 const void *ptr);
640
642typedef void (*ecs_xtor_t)(
643 void *ptr,
644 int32_t count,
645 const ecs_type_info_t *type_info);
646
648typedef void (*ecs_copy_t)(
649 void *dst_ptr,
650 const void *src_ptr,
651 int32_t count,
652 const ecs_type_info_t *type_info);
653
655typedef void (*ecs_move_t)(
656 void *dst_ptr,
657 void *src_ptr,
658 int32_t count,
659 const ecs_type_info_t *type_info);
660
662typedef int (*ecs_cmp_t)(
663 const void *a_ptr,
664 const void *b_ptr,
665 const ecs_type_info_t *type_info);
666
668typedef bool (*ecs_equals_t)(
669 const void *a_ptr,
670 const void *b_ptr,
671 const ecs_type_info_t *type_info);
672
674typedef void (*flecs_poly_dtor_t)(
675 ecs_poly_t *poly);
676
695
706
714
715/* Term id flags */
716
721#define EcsSelf (1llu << 63)
722
727#define EcsUp (1llu << 62)
728
733#define EcsTrav (1llu << 61)
734
739#define EcsCascade (1llu << 60)
740
745#define EcsDesc (1llu << 59)
746
751#define EcsIsVariable (1llu << 58)
752
757#define EcsIsEntity (1llu << 57)
758
763#define EcsIsName (1llu << 56)
764
769#define EcsTraverseFlags (EcsSelf|EcsUp|EcsTrav|EcsCascade|EcsDesc)
770
775#define EcsTermRefFlags (EcsTraverseFlags|EcsIsVariable|EcsIsEntity|EcsIsName)
776
791
813
821 int32_t *sizes;
824 uint64_t bloom_filter;
825 ecs_flags32_t flags;
826 int8_t var_count;
827 int8_t term_count;
828 int8_t field_count;
830 /* Bitmasks for quick field information lookups */
831 ecs_termset_t fixed_fields;
832 ecs_termset_t var_fields;
833 ecs_termset_t static_id_fields;
834 ecs_termset_t data_fields;
835 ecs_termset_t write_fields;
836 ecs_termset_t read_fields;
837 ecs_termset_t row_fields;
839 ecs_termset_t set_fields;
843 char **vars;
845 void *ctx;
852 int32_t eval_count;
853};
854
883
891/* Flags that can be used to check which hooks a type has set */
892#define ECS_TYPE_HOOK_CTOR ECS_CAST(ecs_flags32_t, 1 << 0)
893#define ECS_TYPE_HOOK_DTOR ECS_CAST(ecs_flags32_t, 1 << 1)
894#define ECS_TYPE_HOOK_COPY ECS_CAST(ecs_flags32_t, 1 << 2)
895#define ECS_TYPE_HOOK_MOVE ECS_CAST(ecs_flags32_t, 1 << 3)
896#define ECS_TYPE_HOOK_COPY_CTOR ECS_CAST(ecs_flags32_t, 1 << 4)
897#define ECS_TYPE_HOOK_MOVE_CTOR ECS_CAST(ecs_flags32_t, 1 << 5)
898#define ECS_TYPE_HOOK_CTOR_MOVE_DTOR ECS_CAST(ecs_flags32_t, 1 << 6)
899#define ECS_TYPE_HOOK_MOVE_DTOR ECS_CAST(ecs_flags32_t, 1 << 7)
900#define ECS_TYPE_HOOK_CMP ECS_CAST(ecs_flags32_t, 1 << 8)
901#define ECS_TYPE_HOOK_EQUALS ECS_CAST(ecs_flags32_t, 1 << 9)
902
903
904/* Flags that can be used to set/check which hooks of a type are invalid */
905#define ECS_TYPE_HOOK_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 10)
906#define ECS_TYPE_HOOK_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 12)
907#define ECS_TYPE_HOOK_COPY_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 13)
908#define ECS_TYPE_HOOK_MOVE_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 14)
909#define ECS_TYPE_HOOK_COPY_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 15)
910#define ECS_TYPE_HOOK_MOVE_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 16)
911#define ECS_TYPE_HOOK_CTOR_MOVE_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 17)
912#define ECS_TYPE_HOOK_MOVE_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 18)
913#define ECS_TYPE_HOOK_CMP_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 19)
914#define ECS_TYPE_HOOK_EQUALS_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 20)
915
916
917/* All valid hook flags */
918#define ECS_TYPE_HOOKS (ECS_TYPE_HOOK_CTOR|ECS_TYPE_HOOK_DTOR|\
919 ECS_TYPE_HOOK_COPY|ECS_TYPE_HOOK_MOVE|ECS_TYPE_HOOK_COPY_CTOR|\
920 ECS_TYPE_HOOK_MOVE_CTOR|ECS_TYPE_HOOK_CTOR_MOVE_DTOR|\
921 ECS_TYPE_HOOK_MOVE_DTOR|ECS_TYPE_HOOK_CMP|ECS_TYPE_HOOK_EQUALS)
922
923/* All invalid hook flags */
924#define ECS_TYPE_HOOKS_ILLEGAL (ECS_TYPE_HOOK_CTOR_ILLEGAL|\
925 ECS_TYPE_HOOK_DTOR_ILLEGAL|ECS_TYPE_HOOK_COPY_ILLEGAL|\
926 ECS_TYPE_HOOK_MOVE_ILLEGAL|ECS_TYPE_HOOK_COPY_CTOR_ILLEGAL|\
927 ECS_TYPE_HOOK_MOVE_CTOR_ILLEGAL|ECS_TYPE_HOOK_CTOR_MOVE_DTOR_ILLEGAL|\
928 ECS_TYPE_HOOK_MOVE_DTOR_ILLEGAL|ECS_TYPE_HOOK_CMP_ILLEGAL|\
929 ECS_TYPE_HOOK_EQUALS_ILLEGAL)
995
1007
1008#include "flecs/private/api_types.h" /* Supporting API types */
1009#include "flecs/private/api_support.h" /* Supporting API functions */
1010#include "flecs/datastructures/hashmap.h" /* Hashmap */
1011#include "flecs/private/api_internals.h" /* Supporting API functions */
1012
1018
1023typedef struct ecs_entity_desc_t {
1024 int32_t _canary;
1030 const char *name;
1035 const char *sep;
1039 const char *root_sep;
1041 const char *symbol;
1057
1060
1062 const char *add_expr;
1064
1094
1108
1148 /* World */
1152 /* Matched data */
1153 int32_t offset;
1154 int32_t count;
1156 void **ptrs;
1157 const ecs_table_record_t **trs;
1158 const ecs_size_t *sizes;
1163 ecs_flags64_t constrained_vars;
1164 ecs_termset_t set_fields;
1165 ecs_termset_t ref_fields;
1166 ecs_termset_t row_fields;
1167 ecs_termset_t up_fields;
1169 /* Input information */
1173 int32_t event_cur;
1175 /* Query information */
1177 int8_t term_index;
1182 /* Context */
1183 void *param;
1184 void *ctx;
1187 void *run_ctx;
1189 /* Time */
1193 /* Iterator counters */
1196 /* Misc */
1197 ecs_flags32_t flags;
1199 ecs_iter_private_t priv_;
1201 /* Chained iterators */
1206};
1207
1208
1213#define EcsQueryMatchPrefab (1u << 1u)
1214
1219#define EcsQueryMatchDisabled (1u << 2u)
1220
1225#define EcsQueryMatchEmptyTables (1u << 3u)
1226
1231#define EcsQueryAllowUnresolvedByName (1u << 6u)
1232
1237#define EcsQueryTableOnly (1u << 7u)
1238
1249#define EcsQueryDetectChanges (1u << 8u)
1250
1251
1325
1387
1392typedef struct ecs_event_desc_t {
1395
1400
1403
1407
1409 int32_t offset;
1410
1414 int32_t count;
1415
1418
1423 void *param;
1424
1428 const void *const_param;
1429
1432
1434 ecs_flags32_t flags;
1436
1437
1446typedef struct ecs_build_info_t {
1447 const char *compiler;
1448 const char **addons;
1449 const char *version;
1453 bool debug;
1457
1516
1519 uint64_t id;
1520 int32_t match_count;
1521 int32_t table_count;
1522 void *ctx;
1524
1535typedef struct EcsIdentifier {
1536 char *value;
1537 ecs_size_t length;
1538 uint64_t hash;
1539 uint64_t index_hash;
1540 ecs_hashmap_t *index;
1542
1544typedef struct EcsComponent {
1545 ecs_size_t size;
1546 ecs_size_t alignment;
1548
1553
1562
1566/* Only include deprecated definitions if deprecated addon is required */
1567#ifdef FLECS_DEPRECATED
1569#endif
1570
1586FLECS_API extern const ecs_id_t ECS_PAIR;
1587
1589FLECS_API extern const ecs_id_t ECS_AUTO_OVERRIDE;
1590
1592FLECS_API extern const ecs_id_t ECS_TOGGLE;
1593
1601/* Builtin component ids */
1602
1604FLECS_API extern const ecs_entity_t ecs_id(EcsComponent);
1605
1607FLECS_API extern const ecs_entity_t ecs_id(EcsIdentifier);
1608
1610FLECS_API extern const ecs_entity_t ecs_id(EcsPoly);
1611
1613FLECS_API extern const ecs_entity_t ecs_id(EcsDefaultChildComponent);
1614
1616FLECS_API extern const ecs_entity_t EcsQuery;
1617
1619FLECS_API extern const ecs_entity_t EcsObserver;
1620
1622FLECS_API extern const ecs_entity_t EcsSystem;
1623
1625FLECS_API extern const ecs_entity_t ecs_id(EcsTickSource);
1626
1628FLECS_API extern const ecs_entity_t ecs_id(EcsPipelineQuery);
1629
1631FLECS_API extern const ecs_entity_t ecs_id(EcsTimer);
1632
1634FLECS_API extern const ecs_entity_t ecs_id(EcsRateFilter);
1635
1637FLECS_API extern const ecs_entity_t EcsFlecs;
1638
1640FLECS_API extern const ecs_entity_t EcsFlecsCore;
1641
1643FLECS_API extern const ecs_entity_t EcsWorld;
1644
1646FLECS_API extern const ecs_entity_t EcsWildcard;
1647
1649FLECS_API extern const ecs_entity_t EcsAny;
1650
1652FLECS_API extern const ecs_entity_t EcsThis;
1653
1655FLECS_API extern const ecs_entity_t EcsVariable;
1656
1664FLECS_API extern const ecs_entity_t EcsTransitive;
1665
1673FLECS_API extern const ecs_entity_t EcsReflexive;
1674
1685FLECS_API extern const ecs_entity_t EcsFinal;
1686
1692FLECS_API extern const ecs_entity_t EcsInheritable;
1693
1695FLECS_API extern const ecs_entity_t EcsOnInstantiate;
1696
1700FLECS_API extern const ecs_entity_t EcsOverride;
1701
1705FLECS_API extern const ecs_entity_t EcsInherit;
1706
1711FLECS_API extern const ecs_entity_t EcsDontInherit;
1712
1720FLECS_API extern const ecs_entity_t EcsSymmetric;
1721
1731FLECS_API extern const ecs_entity_t EcsExclusive;
1732
1734FLECS_API extern const ecs_entity_t EcsAcyclic;
1735
1738FLECS_API extern const ecs_entity_t EcsTraversable;
1739
1749FLECS_API extern const ecs_entity_t EcsWith;
1750
1760FLECS_API extern const ecs_entity_t EcsOneOf;
1761
1763FLECS_API extern const ecs_entity_t EcsCanToggle;
1764
1768FLECS_API extern const ecs_entity_t EcsTrait;
1769
1779FLECS_API extern const ecs_entity_t EcsRelationship;
1780
1790FLECS_API extern const ecs_entity_t EcsTarget;
1791
1794FLECS_API extern const ecs_entity_t EcsPairIsTag;
1795
1797FLECS_API extern const ecs_entity_t EcsName;
1798
1800FLECS_API extern const ecs_entity_t EcsSymbol;
1801
1803FLECS_API extern const ecs_entity_t EcsAlias;
1804
1806FLECS_API extern const ecs_entity_t EcsChildOf;
1807
1809FLECS_API extern const ecs_entity_t EcsIsA;
1810
1812FLECS_API extern const ecs_entity_t EcsDependsOn;
1813
1815FLECS_API extern const ecs_entity_t EcsSlotOf;
1816
1818FLECS_API extern const ecs_entity_t EcsOrderedChildren;
1819
1821FLECS_API extern const ecs_entity_t EcsModule;
1822
1824FLECS_API extern const ecs_entity_t EcsPrivate;
1825
1828FLECS_API extern const ecs_entity_t EcsPrefab;
1829
1832FLECS_API extern const ecs_entity_t EcsDisabled;
1833
1837FLECS_API extern const ecs_entity_t EcsNotQueryable;
1838
1840FLECS_API extern const ecs_entity_t EcsOnAdd;
1841
1843FLECS_API extern const ecs_entity_t EcsOnRemove;
1844
1846FLECS_API extern const ecs_entity_t EcsOnSet;
1847
1849FLECS_API extern const ecs_entity_t EcsMonitor;
1850
1852FLECS_API extern const ecs_entity_t EcsOnTableCreate;
1853
1855FLECS_API extern const ecs_entity_t EcsOnTableDelete;
1856
1858FLECS_API extern const ecs_entity_t EcsOnDelete;
1859
1862FLECS_API extern const ecs_entity_t EcsOnDeleteTarget;
1863
1866FLECS_API extern const ecs_entity_t EcsRemove;
1867
1870FLECS_API extern const ecs_entity_t EcsDelete;
1871
1874FLECS_API extern const ecs_entity_t EcsPanic;
1875
1878FLECS_API extern const ecs_entity_t EcsSingleton;
1879
1881FLECS_API extern const ecs_entity_t EcsSparse;
1882
1884FLECS_API extern const ecs_entity_t EcsDontFragment;
1885
1887FLECS_API extern const ecs_entity_t EcsPredEq;
1888
1890FLECS_API extern const ecs_entity_t EcsPredMatch;
1891
1893FLECS_API extern const ecs_entity_t EcsPredLookup;
1894
1896FLECS_API extern const ecs_entity_t EcsScopeOpen;
1897
1899FLECS_API extern const ecs_entity_t EcsScopeClose;
1900
1905FLECS_API extern const ecs_entity_t EcsEmpty;
1906
1907FLECS_API extern const ecs_entity_t ecs_id(EcsPipeline);
1908FLECS_API extern const ecs_entity_t EcsOnStart;
1909FLECS_API extern const ecs_entity_t EcsPreFrame;
1910FLECS_API extern const ecs_entity_t EcsOnLoad;
1911FLECS_API extern const ecs_entity_t EcsPostLoad;
1912FLECS_API extern const ecs_entity_t EcsPreUpdate;
1913FLECS_API extern const ecs_entity_t EcsOnUpdate;
1914FLECS_API extern const ecs_entity_t EcsOnValidate;
1915FLECS_API extern const ecs_entity_t EcsPostUpdate;
1916FLECS_API extern const ecs_entity_t EcsPreStore;
1917FLECS_API extern const ecs_entity_t EcsOnStore;
1918FLECS_API extern const ecs_entity_t EcsPostFrame;
1919FLECS_API extern const ecs_entity_t EcsPhase;
1921FLECS_API extern const ecs_entity_t EcsConstant;
1925#define EcsLastInternalComponentId (ecs_id(EcsPoly))
1926
1929#define EcsFirstUserComponentId (8)
1930
1933#define EcsFirstUserEntityId (FLECS_HI_COMPONENT_ID + 128)
1934
1935/* When visualized the reserved id ranges look like this:
1936 * - [1..8]: Builtin components
1937 * - [9..FLECS_HI_COMPONENT_ID]: Low ids reserved for application components
1938 * - [FLECS_HI_COMPONENT_ID + 1..EcsFirstUserEntityId]: Builtin entities
1939 */
1940
1962FLECS_API
1964
1971FLECS_API
1973
1981FLECS_API
1983 int argc,
1984 char *argv[]);
1985
1992FLECS_API
1994 ecs_world_t *world);
1995
2003FLECS_API
2005 const ecs_world_t *world);
2006
2014FLECS_API
2016 ecs_world_t *world,
2017 ecs_fini_action_t action,
2018 void *ctx);
2019
2026
2053FLECS_API
2055 const ecs_world_t *world);
2056
2064FLECS_API
2066 const ecs_world_t *world);
2067
2093FLECS_API
2095 ecs_world_t *world,
2096 ecs_ftime_t delta_time);
2097
2104FLECS_API
2106 ecs_world_t *world);
2107
2115FLECS_API
2117 ecs_world_t *world,
2118 ecs_fini_action_t action,
2119 void *ctx);
2120
2127FLECS_API
2129 ecs_world_t *world);
2130
2137FLECS_API
2139 const ecs_world_t *world);
2140
2153 ecs_world_t *world,
2154 bool enable);
2155
2167 ecs_world_t *world,
2168 bool enable);
2169
2185FLECS_API
2187 ecs_world_t *world,
2188 ecs_ftime_t fps);
2189
2203FLECS_API
2205 ecs_world_t *world,
2206 ecs_flags32_t flags);
2207
2284FLECS_API
2286 ecs_world_t *world,
2287 bool multi_threaded);
2288
2296FLECS_API
2298 ecs_world_t *world);
2299
2310FLECS_API
2312 ecs_world_t *world);
2313
2329FLECS_API
2331 ecs_world_t *world);
2332
2343FLECS_API
2345 const ecs_world_t *world);
2346
2360FLECS_API
2362 ecs_world_t *world);
2363
2378FLECS_API
2380 ecs_world_t *world);
2381
2392FLECS_API
2394 ecs_world_t *world);
2395
2409FLECS_API
2411 ecs_world_t *world,
2412 int32_t stages);
2413
2420FLECS_API
2422 const ecs_world_t *world);
2423
2439FLECS_API
2441 const ecs_world_t *world,
2442 int32_t stage_id);
2443
2451FLECS_API
2453 const ecs_world_t *world);
2454
2462FLECS_API
2464 ecs_world_t *world);
2465
2470FLECS_API
2472 ecs_world_t *stage);
2473
2481FLECS_API
2483 const ecs_world_t *world);
2484
2500FLECS_API
2502 ecs_world_t *world,
2503 void *ctx,
2504 ecs_ctx_free_t ctx_free);
2505
2514FLECS_API
2516 ecs_world_t *world,
2517 void *ctx,
2518 ecs_ctx_free_t ctx_free);
2519
2527FLECS_API
2529 const ecs_world_t *world);
2530
2538FLECS_API
2540 const ecs_world_t *world);
2541
2547FLECS_API
2549
2555FLECS_API
2557 const ecs_world_t *world);
2558
2567FLECS_API
2569 ecs_world_t *world,
2570 int32_t entity_count);
2571
2586FLECS_API
2588 ecs_world_t *world);
2589
2605FLECS_API
2607 ecs_world_t *world,
2608 ecs_entity_t id_start,
2609 ecs_entity_t id_end);
2610
2621FLECS_API
2623 ecs_world_t *world,
2624 bool enable);
2625
2631FLECS_API
2633 const ecs_world_t *world);
2634
2648FLECS_API
2650 ecs_world_t *world,
2651 ecs_flags32_t flags);
2652
2664
2694FLECS_API
2696 ecs_world_t *world,
2697 const ecs_delete_empty_tables_desc_t *desc);
2698
2704FLECS_API
2706 const ecs_poly_t *poly);
2707
2713FLECS_API
2715 const ecs_poly_t *poly);
2716
2730FLECS_API
2732 const ecs_poly_t *object,
2733 int32_t type);
2734
2738#define flecs_poly_is(object, type)\
2739 flecs_poly_is_(object, type##_magic)
2740
2749FLECS_API
2751 ecs_entity_t first,
2752 ecs_entity_t second);
2753
2776FLECS_API
2778 ecs_world_t *world,
2779 const char *thread_name);
2780
2803FLECS_API
2805 ecs_world_t *world,
2806 bool lock_world);
2807
2834FLECS_API
2836 ecs_world_t *world);
2837
2855FLECS_API
2857 ecs_world_t *world);
2858
2867FLECS_API
2869 ecs_world_t *world,
2870 ecs_id_t component);
2871
2879FLECS_API
2881 ecs_world_t *world,
2882 ecs_table_t *table);
2883
2902FLECS_API
2904 ecs_world_t *world,
2905 const ecs_entity_desc_t *desc);
2906
2933FLECS_API
2935 ecs_world_t *world,
2936 const ecs_bulk_desc_t *desc);
2937
2947FLECS_API
2949 ecs_world_t *world,
2950 ecs_id_t component,
2951 int32_t count);
2952
2968FLECS_API
2970 ecs_world_t *world,
2971 ecs_entity_t dst,
2972 ecs_entity_t src,
2973 bool copy_value);
2974
2983FLECS_API
2985 ecs_world_t *world,
2986 ecs_entity_t entity);
2987
2995FLECS_API
2997 ecs_world_t *world,
2998 ecs_id_t component);
2999
3017FLECS_API
3019 ecs_world_t *world,
3020 ecs_entity_t parent,
3021 const ecs_entity_t *children,
3022 int32_t child_count);
3023
3033FLECS_API
3035 const ecs_world_t *world,
3036 ecs_entity_t parent);
3037
3055FLECS_API
3057 ecs_world_t *world,
3058 ecs_entity_t entity,
3059 ecs_id_t component);
3060
3069FLECS_API
3071 ecs_world_t *world,
3072 ecs_entity_t entity,
3073 ecs_id_t component);
3074
3126FLECS_API
3128 ecs_world_t *world,
3129 ecs_entity_t entity,
3130 ecs_id_t component);
3131
3138FLECS_API
3140 ecs_world_t *world,
3141 ecs_entity_t entity);
3142
3150FLECS_API
3152 ecs_world_t *world,
3153 ecs_id_t component);
3154
3169FLECS_API
3171 ecs_world_t *world,
3172 ecs_id_t component);
3173
3181FLECS_API
3183 const ecs_world_t *world);
3184
3203FLECS_API
3205 ecs_world_t *world,
3206 ecs_entity_t entity,
3207 bool enabled);
3208
3222FLECS_API
3224 ecs_world_t *world,
3225 ecs_entity_t entity,
3226 ecs_id_t component,
3227 bool enable);
3228
3239FLECS_API
3241 const ecs_world_t *world,
3242 ecs_entity_t entity,
3243 ecs_id_t component);
3244
3268FLECS_API
3269FLECS_ALWAYS_INLINE const void* ecs_get_id(
3270 const ecs_world_t *world,
3271 ecs_entity_t entity,
3272 ecs_id_t component);
3273
3288FLECS_API
3289FLECS_ALWAYS_INLINE void* ecs_get_mut_id(
3290 const ecs_world_t *world,
3291 ecs_entity_t entity,
3292 ecs_id_t component);
3293
3310FLECS_API
3312 ecs_world_t *world,
3313 ecs_entity_t entity,
3314 ecs_id_t component,
3315 size_t size);
3316
3327FLECS_ALWAYS_INLINE FLECS_API
3329 const ecs_world_t *world,
3330 ecs_entity_t entity,
3331 ecs_id_t component);
3332
3343FLECS_ALWAYS_INLINE FLECS_API
3345 const ecs_world_t *world,
3346 ecs_ref_t *ref,
3347 ecs_id_t component);
3348
3356FLECS_ALWAYS_INLINE FLECS_API
3358 const ecs_world_t *world,
3359 ecs_ref_t *ref);
3360
3381FLECS_API
3383 ecs_world_t *world,
3384 ecs_entity_t entity,
3385 ecs_id_t component,
3386 size_t size,
3387 bool *is_new);
3388
3398FLECS_API
3400 ecs_world_t *world,
3401 ecs_entity_t entity,
3402 ecs_id_t component);
3403
3419FLECS_API
3421 ecs_world_t *world,
3422 ecs_entity_t entity,
3423 ecs_id_t component,
3424 size_t size,
3425 const void *ptr);
3426
3455FLECS_API
3457 const ecs_world_t *world,
3458 ecs_entity_t e);
3459
3489FLECS_API
3491 const ecs_world_t *world,
3492 ecs_entity_t e);
3493
3499FLECS_API
3501 ecs_entity_t e);
3502
3519FLECS_API
3521 const ecs_world_t *world,
3522 ecs_entity_t e);
3523
3546FLECS_API
3548 ecs_world_t *world,
3549 ecs_entity_t entity);
3550
3569FLECS_API
3571 ecs_world_t *world,
3572 ecs_id_t component);
3573
3581FLECS_API
3583 const ecs_world_t *world,
3584 ecs_entity_t entity);
3585
3600FLECS_API
3602 ecs_world_t *world,
3603 ecs_entity_t entity);
3604
3620FLECS_API
3622 const ecs_world_t *world,
3623 ecs_entity_t entity);
3624
3631FLECS_API
3633 const ecs_world_t *world,
3634 ecs_entity_t entity);
3635
3643FLECS_API
3645 const ecs_world_t *world,
3646 const ecs_type_t* type);
3647
3659FLECS_API
3661 const ecs_world_t *world,
3662 const ecs_table_t *table);
3663
3678FLECS_API
3680 const ecs_world_t *world,
3681 ecs_entity_t entity);
3682
3693FLECS_API
3694FLECS_ALWAYS_INLINE bool ecs_has_id(
3695 const ecs_world_t *world,
3696 ecs_entity_t entity,
3697 ecs_id_t component);
3698
3709FLECS_API
3710FLECS_ALWAYS_INLINE bool ecs_owns_id(
3711 const ecs_world_t *world,
3712 ecs_entity_t entity,
3713 ecs_id_t component);
3714
3729FLECS_API
3731 const ecs_world_t *world,
3732 ecs_entity_t entity,
3733 ecs_entity_t rel,
3734 int32_t index);
3735
3749FLECS_API
3751 const ecs_world_t *world,
3752 ecs_entity_t entity);
3753
3774FLECS_API
3776 const ecs_world_t *world,
3777 ecs_entity_t entity,
3778 ecs_entity_t rel,
3779 ecs_id_t component);
3780
3791FLECS_API
3793 const ecs_world_t *world,
3794 ecs_entity_t entity,
3795 ecs_entity_t rel);
3796
3804FLECS_API
3806 const ecs_world_t *world,
3807 ecs_id_t entity);
3808
3828FLECS_API
3829const char* ecs_get_name(
3830 const ecs_world_t *world,
3831 ecs_entity_t entity);
3832
3842FLECS_API
3843const char* ecs_get_symbol(
3844 const ecs_world_t *world,
3845 ecs_entity_t entity);
3846
3860FLECS_API
3862 ecs_world_t *world,
3863 ecs_entity_t entity,
3864 const char *name);
3865
3879FLECS_API
3881 ecs_world_t *world,
3882 ecs_entity_t entity,
3883 const char *symbol);
3884
3896FLECS_API
3898 ecs_world_t *world,
3899 ecs_entity_t entity,
3900 const char *alias);
3901
3917FLECS_API
3919 const ecs_world_t *world,
3920 const char *path);
3921
3936FLECS_API
3938 const ecs_world_t *world,
3939 ecs_entity_t parent,
3940 const char *name);
3941
3964FLECS_API
3966 const ecs_world_t *world,
3967 ecs_entity_t parent,
3968 const char *path,
3969 const char *sep,
3970 const char *prefix,
3971 bool recursive);
3972
3990FLECS_API
3992 const ecs_world_t *world,
3993 const char *symbol,
3994 bool lookup_as_path,
3995 bool recursive);
3996
4018FLECS_API
4020 const ecs_world_t *world,
4021 ecs_entity_t parent,
4022 ecs_entity_t child,
4023 const char *sep,
4024 const char *prefix);
4025
4038FLECS_API
4040 const ecs_world_t *world,
4041 ecs_entity_t parent,
4042 ecs_entity_t child,
4043 const char *sep,
4044 const char *prefix,
4045 ecs_strbuf_t *buf,
4046 bool escape);
4047
4063FLECS_API
4065 ecs_world_t *world,
4066 ecs_entity_t parent,
4067 const char *path,
4068 const char *sep,
4069 const char *prefix);
4070
4085FLECS_API
4087 ecs_world_t *world,
4088 ecs_entity_t entity,
4089 ecs_entity_t parent,
4090 const char *path,
4091 const char *sep,
4092 const char *prefix);
4093
4107FLECS_API
4109 ecs_world_t *world,
4110 ecs_entity_t scope);
4111
4119FLECS_API
4121 const ecs_world_t *world);
4122
4132FLECS_API
4134 ecs_world_t *world,
4135 const char *prefix);
4136
4163FLECS_API
4165 ecs_world_t *world,
4166 const ecs_entity_t *lookup_path);
4167
4174FLECS_API
4176 const ecs_world_t *world);
4177
4202FLECS_API
4204 ecs_world_t *world,
4205 const ecs_component_desc_t *desc);
4206
4216FLECS_API
4218 const ecs_world_t *world,
4219 ecs_id_t component);
4220
4232FLECS_API
4234 ecs_world_t *world,
4235 ecs_entity_t component,
4236 const ecs_type_hooks_t *hooks);
4237
4244FLECS_API
4246 const ecs_world_t *world,
4247 ecs_entity_t component);
4248
4272FLECS_API
4274 const ecs_world_t *world,
4275 ecs_id_t component);
4276
4285FLECS_API
4287 const ecs_world_t *world,
4288 ecs_id_t component);
4289
4309FLECS_API
4311 const ecs_world_t *world,
4312 ecs_id_t component);
4313
4322FLECS_API
4324 ecs_id_t component,
4325 ecs_id_t pattern);
4326
4332FLECS_API
4334 ecs_id_t component);
4335
4341FLECS_API
4343 ecs_id_t component);
4344
4351 ecs_id_t component);
4352
4366FLECS_API
4368 const ecs_world_t *world,
4369 ecs_id_t component);
4370
4379FLECS_API
4380ecs_flags32_t ecs_id_get_flags(
4381 const ecs_world_t *world,
4382 ecs_id_t component);
4383
4394FLECS_API
4396 ecs_id_t component_flags);
4397
4413FLECS_API
4415 const ecs_world_t *world,
4416 ecs_id_t component);
4417
4425FLECS_API
4427 const ecs_world_t *world,
4428 ecs_id_t component,
4429 ecs_strbuf_t *buf);
4430
4438FLECS_API
4440 const ecs_world_t *world,
4441 const char *expr);
4442
4458FLECS_API
4460 const ecs_term_ref_t *ref);
4461
4473FLECS_API
4475 const ecs_term_t *term);
4476
4491FLECS_API
4493 const ecs_term_t *term);
4494
4507FLECS_API
4509 const ecs_term_t *term);
4510
4519FLECS_API
4521 const ecs_world_t *world,
4522 const ecs_term_t *term);
4523
4531FLECS_API
4533 const ecs_query_t *query);
4534
4575FLECS_API
4577 const ecs_world_t *world,
4578 ecs_id_t component);
4579
4585FLECS_API
4587 ecs_iter_t *it);
4588
4605FLECS_API
4607 const ecs_world_t *world,
4608 ecs_entity_t parent);
4609
4615FLECS_API
4617 ecs_iter_t *it);
4618
4634FLECS_API
4636 ecs_world_t *world,
4637 const ecs_query_desc_t *desc);
4638
4643FLECS_API
4645 ecs_query_t *query);
4646
4655FLECS_API
4657 const ecs_query_t *query,
4658 const char *name);
4659
4667FLECS_API
4669 const ecs_query_t *query,
4670 int32_t var_id);
4671
4682FLECS_API
4684 const ecs_query_t *query,
4685 int32_t var_id);
4686
4755FLECS_API
4757 const ecs_world_t *world,
4758 const ecs_query_t *query);
4759
4767FLECS_API
4769 ecs_iter_t *it);
4770
4789FLECS_API
4791 ecs_query_t *query,
4792 ecs_entity_t entity,
4793 ecs_iter_t *it);
4794
4813FLECS_API
4815 ecs_query_t *query,
4816 ecs_table_t *table,
4817 ecs_iter_t *it);
4818
4845FLECS_API
4847 ecs_query_t *query,
4848 ecs_table_range_t *range,
4849 ecs_iter_t *it);
4850
4858FLECS_API
4860 const ecs_query_t *query);
4861
4871FLECS_API
4873 const ecs_query_t *query);
4874
4889FLECS_API
4891 const ecs_query_t *query,
4892 const ecs_iter_t *it);
4893
4911FLECS_API
4913 ecs_query_t *query,
4914 ecs_iter_t *it,
4915 const char *expr);
4916
4944FLECS_API
4946 ecs_query_t *query);
4947
4956FLECS_API
4958 const ecs_world_t *world,
4959 ecs_entity_t query);
4960
4971FLECS_API
4973 ecs_iter_t *it);
4974
4997FLECS_API
4999 ecs_iter_t *it,
5000 uint64_t group_id);
5001
5010FLECS_API
5012 const ecs_query_t *query,
5013 uint64_t group_id);
5014
5023FLECS_API
5025 const ecs_query_t *query,
5026 uint64_t group_id);
5027
5036
5043FLECS_API
5045 const ecs_query_t *query);
5046
5052FLECS_API
5054 const ecs_query_t *query);
5055
5064FLECS_API
5066 const ecs_query_t *query);
5067
5096FLECS_API
5098 ecs_world_t *world,
5099 ecs_event_desc_t *desc);
5100
5111FLECS_API
5113 ecs_world_t *world,
5114 ecs_event_desc_t *desc);
5115
5126FLECS_API
5128 ecs_world_t *world,
5129 const ecs_observer_desc_t *desc);
5130
5139FLECS_API
5141 const ecs_world_t *world,
5142 ecs_entity_t observer);
5143
5166FLECS_API
5168 ecs_iter_t *it);
5169
5179FLECS_API
5181 ecs_iter_t *it);
5182
5194FLECS_API
5196 ecs_iter_t *it);
5197
5210FLECS_API
5212 ecs_iter_t *it);
5213
5221FLECS_API
5223 ecs_iter_t *it);
5224
5263FLECS_API
5265 ecs_iter_t *it,
5266 int32_t var_id,
5267 ecs_entity_t entity);
5268
5279FLECS_API
5281 ecs_iter_t *it,
5282 int32_t var_id,
5283 const ecs_table_t *table);
5284
5295FLECS_API
5297 ecs_iter_t *it,
5298 int32_t var_id,
5299 const ecs_table_range_t *range);
5300
5313FLECS_API
5315 ecs_iter_t *it,
5316 int32_t var_id);
5317
5324FLECS_API
5326 const ecs_iter_t *it,
5327 int32_t var_id);
5328
5334FLECS_API
5336 const ecs_iter_t *it);
5337
5343FLECS_API
5345 const ecs_iter_t *it);
5346
5360FLECS_API
5362 ecs_iter_t *it,
5363 int32_t var_id);
5364
5378FLECS_API
5380 ecs_iter_t *it,
5381 int32_t var_id);
5382
5394FLECS_API
5396 ecs_iter_t *it,
5397 int32_t var_id);
5398
5410FLECS_API
5412 const ecs_iter_t *it);
5413
5425FLECS_API
5427 ecs_iter_t *it);
5428
5440FLECS_API
5442 const ecs_iter_t *it);
5443
5459FLECS_API
5461 const ecs_iter_t *it,
5462 int32_t offset,
5463 int32_t limit);
5464
5471FLECS_API
5473 ecs_iter_t *it);
5474
5495FLECS_API
5497 const ecs_iter_t *it,
5498 int32_t index,
5499 int32_t count);
5500
5507FLECS_API
5509 ecs_iter_t *it);
5510
5552FLECS_API
5554 const ecs_iter_t *it,
5555 size_t size,
5556 int8_t index);
5557
5579FLECS_API
5581 const ecs_iter_t *it,
5582 size_t size,
5583 int8_t index,
5584 int32_t row);
5585
5594FLECS_API
5596 const ecs_iter_t *it,
5597 int8_t index);
5598
5609FLECS_API
5611 const ecs_iter_t *it,
5612 int8_t index);
5613
5620FLECS_API
5622 const ecs_iter_t *it,
5623 int8_t index);
5624
5631FLECS_API
5633 const ecs_iter_t *it,
5634 int8_t index);
5635
5644FLECS_API
5646 const ecs_iter_t *it,
5647 int8_t index);
5648
5656FLECS_API
5658 const ecs_iter_t *it,
5659 int8_t index);
5660
5668FLECS_API
5670 const ecs_iter_t *it,
5671 int8_t index);
5672
5686FLECS_API
5688 const ecs_iter_t *it,
5689 int8_t index);
5690
5706FLECS_API
5708 const ecs_table_t *table);
5709
5720FLECS_API
5722 const ecs_world_t *world,
5723 const ecs_table_t *table,
5724 ecs_id_t component);
5725
5735FLECS_API
5737 const ecs_world_t *world,
5738 const ecs_table_t *table,
5739 ecs_id_t component);
5740
5748FLECS_API
5750 const ecs_table_t *table);
5751
5765FLECS_API
5767 const ecs_table_t *table,
5768 int32_t index);
5769
5778FLECS_API
5780 const ecs_table_t *table,
5781 int32_t index);
5782
5791FLECS_API
5793 const ecs_table_t *table,
5794 int32_t index,
5795 int32_t offset);
5796
5806FLECS_API
5808 const ecs_world_t *world,
5809 const ecs_table_t *table,
5810 ecs_id_t component,
5811 int32_t offset);
5812
5820FLECS_API
5822 const ecs_table_t *table,
5823 int32_t index);
5824
5831FLECS_API
5833 const ecs_table_t *table);
5834
5842FLECS_API
5844 const ecs_table_t *table);
5845
5852FLECS_API
5854 const ecs_table_t *table);
5855
5866FLECS_API
5868 const ecs_world_t *world,
5869 const ecs_table_t *table,
5870 ecs_id_t component);
5871
5882FLECS_API
5884 const ecs_world_t *world,
5885 const ecs_table_t *table,
5886 ecs_entity_t rel);
5887
5897FLECS_API
5899 ecs_world_t *world,
5900 ecs_table_t *table,
5901 ecs_id_t component);
5902
5913FLECS_API
5915 ecs_world_t *world,
5916 const ecs_id_t *ids,
5917 int32_t id_count);
5918
5928FLECS_API
5930 ecs_world_t *world,
5931 ecs_table_t *table,
5932 ecs_id_t component);
5933
5949FLECS_API
5951 ecs_world_t *world,
5952 ecs_table_t *table);
5953
5960FLECS_API
5962 ecs_world_t *world,
5963 ecs_table_t *table);
5964
5974FLECS_API
5976 ecs_table_t *table,
5977 ecs_flags32_t flags);
5978
5986FLECS_API
5988 const ecs_table_t *table);
5989
5997FLECS_API
5999 ecs_world_t* world,
6000 ecs_table_t* table,
6001 int32_t row_1,
6002 int32_t row_2);
6003
6026FLECS_API
6028 ecs_world_t *world,
6029 ecs_entity_t entity,
6030 ecs_record_t *record,
6031 ecs_table_t *table,
6032 const ecs_type_t *added,
6033 const ecs_type_t *removed);
6034
6035
6055FLECS_API
6057 const ecs_world_t *world,
6058 const ecs_table_t *table,
6059 ecs_id_t component,
6060 ecs_id_t *component_out);
6061
6097FLECS_API
6099 const ecs_world_t *world,
6100 const ecs_table_t *table,
6101 int32_t offset,
6102 ecs_id_t component,
6103 ecs_id_t *component_out);
6104
6146FLECS_API
6148 const ecs_world_t *world,
6149 const ecs_table_t *table,
6150 int32_t offset,
6151 ecs_id_t component,
6152 ecs_entity_t rel,
6153 ecs_flags64_t flags, /* EcsSelf and/or EcsUp */
6154 ecs_entity_t *subject_out,
6155 ecs_id_t *component_out,
6156 struct ecs_table_record_t **tr_out);
6157
6165FLECS_API
6167 ecs_world_t* world,
6168 ecs_table_t* table);
6169
6186FLECS_API
6188 const ecs_world_t *world,
6189 ecs_entity_t type,
6190 void *ptr);
6191
6199FLECS_API
6201 const ecs_world_t *world,
6202 const ecs_type_info_t *ti,
6203 void *ptr);
6204
6211FLECS_API
6213 ecs_world_t *world,
6214 ecs_entity_t type);
6215
6223 ecs_world_t *world,
6224 const ecs_type_info_t *ti);
6225
6234 const ecs_world_t *world,
6235 const ecs_type_info_t *ti,
6236 void *ptr);
6237
6245FLECS_API
6247 const ecs_world_t *world,
6248 ecs_entity_t type,
6249 void* ptr);
6250
6258FLECS_API
6260 ecs_world_t *world,
6261 ecs_entity_t type,
6262 void* ptr);
6263
6272FLECS_API
6274 const ecs_world_t *world,
6275 const ecs_type_info_t *ti,
6276 void* dst,
6277 const void *src);
6278
6287FLECS_API
6289 const ecs_world_t *world,
6290 ecs_entity_t type,
6291 void* dst,
6292 const void *src);
6293
6303 const ecs_world_t *world,
6304 const ecs_type_info_t *ti,
6305 void* dst,
6306 void *src);
6307
6317 const ecs_world_t *world,
6318 ecs_entity_t type,
6319 void* dst,
6320 void *src);
6321
6331 const ecs_world_t *world,
6332 const ecs_type_info_t *ti,
6333 void* dst,
6334 void *src);
6335
6345 const ecs_world_t *world,
6346 ecs_entity_t type,
6347 void* dst,
6348 void *src);
6349
6363#include "flecs/addons/flecs_c.h"
6364
6365#ifdef __cplusplus
6366}
6367#endif
6368
6369#include "flecs/private/addons.h"
6370
6371#endif
The deprecated addon contains deprecated operations.
Extends the core API with convenience macros for C applications.
void ecs_remove_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Remove a component from an entity.
void ecs_auto_override_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Add auto override for component.
void ecs_remove_all(ecs_world_t *world, ecs_id_t component)
Remove all instances of the specified component.
void ecs_clear(ecs_world_t *world, ecs_entity_t entity)
Clear all components.
ecs_id_t ecs_get_with(const ecs_world_t *world)
Get component set with ecs_set_with().
void ecs_add_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Add a (component) id to an entity.
ecs_entity_t ecs_set_with(ecs_world_t *world, ecs_id_t component)
Create new entities with specified component.
struct ecs_value_t ecs_value_t
Utility to hold a value of a dynamic type.
struct EcsIdentifier EcsIdentifier
A (string) identifier.
struct EcsPoly EcsPoly
Component for storing a poly object.
struct EcsDefaultChildComponent EcsDefaultChildComponent
When added to an entity this informs serialization formats which component to use when a value is ass...
struct EcsComponent EcsComponent
Component information.
const ecs_entity_t EcsScopeClose
Marker used to indicate the end of a scope (}) in queries.
const ecs_entity_t EcsOnRemove
Event that triggers when an id is removed from an entity.
const ecs_entity_t EcsThis
This entity.
const ecs_entity_t EcsWildcard
Wildcard entity ("*").
const ecs_entity_t EcsName
Tag to indicate name identifier.
const ecs_entity_t EcsAcyclic
Marks a relationship as acyclic.
const ecs_entity_t EcsSymmetric
Marks relationship as commutative.
const ecs_entity_t EcsAlias
Tag to indicate alias identifier.
const ecs_entity_t EcsOnSet
Event that triggers when a component is set for an entity.
const ecs_entity_t EcsReflexive
Marks a relationship as reflexive.
const ecs_entity_t EcsTrait
Can be added to components to indicate it is a trait.
const ecs_entity_t EcsEmpty
Tag used to indicate query is empty.
const ecs_entity_t EcsOneOf
Ensure that relationship target is child of specified entity.
const ecs_entity_t EcsOnTableDelete
Event that triggers when a table is deleted.
const ecs_entity_t EcsOnTableCreate
Event that triggers when a table is created.
const ecs_entity_t EcsObserver
Tag added to observers.
const ecs_entity_t EcsQuery
Tag added to queries.
const ecs_entity_t EcsRelationship
Ensure that an entity is always used in pair as relationship.
const ecs_entity_t EcsSingleton
Mark component as singleton.
const ecs_entity_t EcsOnStart
OnStart pipeline phase.
const ecs_entity_t EcsNotQueryable
Trait added to entities that should never be returned by queries.
const ecs_entity_t EcsOnStore
OnStore pipeline phase.
const ecs_entity_t EcsOrderedChildren
Tag that when added to a parent ensures stable order of ecs_children result.
const ecs_entity_t EcsDontFragment
Mark component as non-fragmenting.
const ecs_entity_t EcsTraversable
Marks a relationship as traversable.
const ecs_entity_t EcsPredLookup
Marker used to indicate $var ~= "pattern" matching in queries.
const ecs_entity_t EcsPreStore
PreStore pipeline phase.
const ecs_entity_t EcsOnLoad
OnLoad pipeline phase.
const ecs_entity_t EcsIsA
Used to express inheritance relationships.
const ecs_entity_t EcsExclusive
Can be added to relationship to indicate that the relationship can only occur once on an entity.
const ecs_entity_t EcsSymbol
Tag to indicate symbol identifier.
const ecs_entity_t EcsDependsOn
Used to express dependency relationships.
const ecs_entity_t EcsTransitive
Marks a relationship as transitive.
const ecs_entity_t EcsDelete
Delete cleanup policy.
const ecs_entity_t EcsChildOf
Used to express parent-child relationships.
const ecs_entity_t EcsFlecsCore
Core module scope.
const ecs_entity_t EcsMonitor
Event that triggers observer when an entity starts/stops matching a query.
const ecs_entity_t EcsCanToggle
Mark a component as toggleable with ecs_enable_id().
const ecs_entity_t EcsPredEq
Marker used to indicate $var == ... matching in queries.
const ecs_entity_t EcsPhase
Phase pipeline phase.
const ecs_entity_t EcsWorld
Entity associated with world (used for "attaching" components to world)
const ecs_entity_t EcsPrivate
Tag to indicate an entity/component/system is private to a module.
const ecs_entity_t EcsScopeOpen
Marker used to indicate the start of a scope ({) in queries.
const ecs_entity_t EcsPostUpdate
PostUpdate pipeline phase.
const ecs_entity_t EcsOnValidate
OnValidate pipeline phase.
const ecs_entity_t EcsRemove
Remove cleanup policy.
const ecs_entity_t EcsOverride
Override component on instantiate.
const ecs_entity_t EcsPredMatch
Marker used to indicate $var == "name" matching in queries.
const ecs_entity_t EcsInherit
Inherit component on instantiate.
const ecs_entity_t EcsSlotOf
Used to express a slot (used with prefab inheritance)
const ecs_entity_t EcsModule
Tag added to module entities.
const ecs_entity_t EcsSparse
Mark component as sparse.
const ecs_entity_t EcsPreUpdate
PreUpdate pipeline phase.
const ecs_entity_t EcsOnAdd
Event that triggers when an id is added to an entity.
const ecs_entity_t EcsPrefab
Tag added to prefab entities.
const ecs_entity_t EcsOnInstantiate
Relationship that specifies component inheritance behavior.
const ecs_entity_t EcsPostFrame
PostFrame pipeline phase.
const ecs_entity_t EcsInheritable
Mark component as inheritable.
const ecs_entity_t EcsAny
Any entity ("_").
const ecs_entity_t EcsTarget
Ensure that an entity is always used in pair as target.
const ecs_entity_t EcsWith
Ensure that a component always is added together with another component.
const ecs_entity_t EcsPostLoad
PostLoad pipeline phase.
const ecs_entity_t EcsOnDelete
Relationship used for specifying cleanup behavior.
const ecs_entity_t EcsOnDeleteTarget
Relationship used to define what should happen when a target entity (second element of a pair) is del...
const ecs_entity_t EcsPreFrame
PreFrame pipeline phase.
const ecs_entity_t EcsFlecs
Root scope for builtin flecs entities.
const ecs_entity_t EcsSystem
Tag added to systems.
const ecs_entity_t EcsOnUpdate
OnUpdate pipeline phase.
const ecs_entity_t EcsDisabled
When this tag is added to an entity it is skipped by queries, unless EcsDisabled is explicitly querie...
const ecs_entity_t EcsDontInherit
Never inherit component on instantiate.
const ecs_entity_t EcsPairIsTag
Can be added to relationship to indicate that it should never hold data, even when it or the relation...
const ecs_entity_t EcsPanic
Panic cleanup policy.
const ecs_entity_t EcsFinal
Ensures that entity/component cannot be used as target in IsA relationship.
const ecs_entity_t EcsVariable
Variable entity ("$").
const ecs_entity_t EcsConstant
Tag added to enum/bitmask constants.
FLECS_API const ecs_entity_t ecs_id(EcsDocDescription)
Component id for EcsDocDescription.
ecs_world_t * ecs_stage_new(ecs_world_t *world)
Create unmanaged stage.
bool ecs_defer_end(ecs_world_t *world)
End block of operations to defer.
bool ecs_readonly_begin(ecs_world_t *world, bool multi_threaded)
Begin readonly mode.
void ecs_defer_resume(ecs_world_t *world)
Resume deferring.
bool ecs_defer_begin(ecs_world_t *world)
Defer operations until end of frame.
void ecs_defer_suspend(ecs_world_t *world)
Suspend deferring but do not flush queue.
bool ecs_is_deferred(const ecs_world_t *world)
Test if deferring is enabled for current stage.
void ecs_stage_free(ecs_world_t *stage)
Free unmanaged stage.
void ecs_merge(ecs_world_t *world)
Merge world or stage.
int32_t ecs_stage_get_id(const ecs_world_t *world)
Get stage id.
bool ecs_stage_is_readonly(const ecs_world_t *world)
Test whether the current world is readonly.
int32_t ecs_get_stage_count(const ecs_world_t *world)
Get number of configured stages.
ecs_world_t * ecs_get_stage(const ecs_world_t *world, int32_t stage_id)
Get stage-specific world pointer.
void ecs_set_stage_count(ecs_world_t *world, int32_t stages)
Configure world to have N stages.
void ecs_readonly_end(ecs_world_t *world)
End readonly mode.
const ecs_type_hooks_t * ecs_get_hooks_id(const ecs_world_t *world, ecs_entity_t component)
Get hooks for component.
ecs_entity_t ecs_component_init(ecs_world_t *world, const ecs_component_desc_t *desc)
Find or create a component.
const ecs_type_info_t * ecs_get_type_info(const ecs_world_t *world, ecs_id_t component)
Get the type info for an component.
struct ecs_component_desc_t ecs_component_desc_t
Used with ecs_component_init().
void ecs_set_hooks_id(ecs_world_t *world, ecs_entity_t component, const ecs_type_hooks_t *hooks)
Register hooks for component.
struct ecs_component_record_t ecs_component_record_t
Information about a (component) id, such as type info and tables with the id.
Definition flecs.h:477
struct ecs_header_t ecs_header_t
Header for ecs_poly_t objects.
struct ecs_stage_t ecs_stage_t
A stage enables modification while iterating and from multiple threads.
Definition flecs.h:412
struct ecs_ref_t ecs_ref_t
A ref is a fast way to fetch a component for a specific entity.
Definition flecs.h:461
ecs_id_t ecs_entity_t
An entity identifier.
Definition flecs.h:365
struct ecs_world_t ecs_world_t
A world is the container for all ECS data and supporting features.
Definition flecs.h:409
struct ecs_mixins_t ecs_mixins_t
Type that stores poly mixins.
Definition flecs.h:501
uint64_t ecs_id_t
Ids are the things that can be added to an entity.
Definition flecs.h:358
struct ecs_observable_t ecs_observable_t
An observable produces events that can be listened for by an observer.
Definition flecs.h:445
struct ecs_record_t ecs_record_t
Information about an entity, like its table and row.
Definition flecs.h:474
struct ecs_table_t ecs_table_t
A table stores entities and components for a specific type.
Definition flecs.h:415
void ecs_poly_t
A poly object.
Definition flecs.h:498
ecs_entity_t ecs_new_low_id(ecs_world_t *world)
Create new low id.
void ecs_set_child_order(ecs_world_t *world, ecs_entity_t parent, const ecs_entity_t *children, int32_t child_count)
Set child order for parent with OrderedChildren.
const ecs_entity_t * ecs_bulk_init(ecs_world_t *world, const ecs_bulk_desc_t *desc)
Bulk create/populate new entities.
ecs_entity_t ecs_clone(ecs_world_t *world, ecs_entity_t dst, ecs_entity_t src, bool copy_value)
Clone an entity This operation clones the components of one entity into another entity.
ecs_entity_t ecs_new(ecs_world_t *world)
Create new entity id.
ecs_entity_t ecs_entity_init(ecs_world_t *world, const ecs_entity_desc_t *desc)
Find or create an entity.
void ecs_delete(ecs_world_t *world, ecs_entity_t entity)
Delete an entity.
void ecs_delete_with(ecs_world_t *world, ecs_id_t component)
Delete all entities with the specified component.
ecs_entity_t ecs_new_w_id(ecs_world_t *world, ecs_id_t component)
Create new entity with (component) id.
ecs_entity_t ecs_new_w_table(ecs_world_t *world, ecs_table_t *table)
Create new entity in table.
const ecs_entity_t * ecs_bulk_new_w_id(ecs_world_t *world, ecs_id_t component, int32_t count)
Create N new entities.
ecs_entities_t ecs_get_ordered_children(const ecs_world_t *world, ecs_entity_t parent)
Get ordered children.
bool ecs_children_next(ecs_iter_t *it)
Progress an iterator created with ecs_children().
ecs_iter_t ecs_each_id(const ecs_world_t *world, ecs_id_t component)
Iterate all entities with specified (component id).
bool ecs_each_next(ecs_iter_t *it)
Progress an iterator created with ecs_each_id().
ecs_iter_t ecs_children(const ecs_world_t *world, ecs_entity_t parent)
Iterate children of parent.
void ecs_enable_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component, bool enable)
Enable or disable component.
bool ecs_is_enabled_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Test if component is enabled.
void ecs_enable(ecs_world_t *world, ecs_entity_t entity, bool enabled)
Enable or disable entity.
struct ecs_bulk_desc_t ecs_bulk_desc_t
Used with ecs_bulk_init().
struct ecs_entity_desc_t ecs_entity_desc_t
Used with ecs_entity_init().
char * ecs_entity_str(const ecs_world_t *world, ecs_entity_t entity)
Convert entity to string.
ecs_entity_t ecs_get_target(const ecs_world_t *world, ecs_entity_t entity, ecs_entity_t rel, int32_t index)
Get the target of a relationship.
ecs_entity_t ecs_get_parent(const ecs_world_t *world, ecs_entity_t entity)
Get parent (target of ChildOf relationship) for entity.
ecs_entity_t ecs_get_target_for_id(const ecs_world_t *world, ecs_entity_t entity, ecs_entity_t rel, ecs_id_t component)
Get the target of a relationship for a given component.
const ecs_type_t * ecs_get_type(const ecs_world_t *world, ecs_entity_t entity)
Get the type of an entity.
bool ecs_owns_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Test if an entity owns a component.
char * ecs_type_str(const ecs_world_t *world, const ecs_type_t *type)
Convert type to string.
char * ecs_table_str(const ecs_world_t *world, const ecs_table_t *table)
Convert table to string.
int32_t ecs_count_id(const ecs_world_t *world, ecs_id_t entity)
Count entities that have the specified id.
int32_t ecs_get_depth(const ecs_world_t *world, ecs_entity_t entity, ecs_entity_t rel)
Return depth for entity in tree for the specified relationship.
ecs_table_t * ecs_get_table(const ecs_world_t *world, ecs_entity_t entity)
Get the table of an entity.
bool ecs_has_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Test if an entity has a component.
void(* ecs_module_action_t)(ecs_world_t *world)
Initialization action for modules.
Definition flecs.h:620
uint64_t(* ecs_group_by_action_t)(ecs_world_t *world, ecs_table_t *table, ecs_id_t group_id, void *ctx)
Callback used for grouping tables in a query.
Definition flecs.h:600
int(* ecs_cmp_t)(const void *a_ptr, const void *b_ptr, const ecs_type_info_t *type_info)
Compare hook to compare component instances.
Definition flecs.h:662
uint64_t(* ecs_hash_value_action_t)(const void *ptr)
Callback used for hashing values.
Definition flecs.h:638
void(* ecs_group_delete_action_t)(ecs_world_t *world, uint64_t group_id, void *group_ctx, void *group_by_ctx)
Callback invoked when a query deletes an existing group.
Definition flecs.h:613
void(* ecs_iter_fini_action_t)(ecs_iter_t *it)
Function prototype for freeing an iterator.
Definition flecs.h:578
void *(* ecs_group_create_action_t)(ecs_world_t *world, uint64_t group_id, void *group_by_ctx)
Callback invoked when a query creates a new group.
Definition flecs.h:607
void(* ecs_sort_table_action_t)(ecs_world_t *world, ecs_table_t *table, ecs_entity_t *entities, void *ptr, int32_t size, int32_t lo, int32_t hi, ecs_order_by_action_t order_by)
Callback used for sorting the entire table of components.
Definition flecs.h:589
bool(* ecs_iter_next_action_t)(ecs_iter_t *it)
Function prototype for iterating an iterator.
Definition flecs.h:570
void(* ecs_iter_action_t)(ecs_iter_t *it)
Function prototype for iterables.
Definition flecs.h:560
void(* ecs_copy_t)(void *dst_ptr, const void *src_ptr, int32_t count, const ecs_type_info_t *type_info)
Copy is invoked when a component is copied into another component.
Definition flecs.h:648
bool(* ecs_equals_t)(const void *a_ptr, const void *b_ptr, const ecs_type_info_t *type_info)
Equals operator hook.
Definition flecs.h:668
int(* ecs_compare_action_t)(const void *ptr1, const void *ptr2)
Callback used for sorting values.
Definition flecs.h:633
void(* ecs_fini_action_t)(ecs_world_t *world, void *ctx)
Action callback on world exit.
Definition flecs.h:624
void(* ecs_move_t)(void *dst_ptr, void *src_ptr, int32_t count, const ecs_type_info_t *type_info)
Move is invoked when a component is moved to another component.
Definition flecs.h:655
void(* flecs_poly_dtor_t)(ecs_poly_t *poly)
Destructor function for poly objects.
Definition flecs.h:674
void(* ecs_run_action_t)(ecs_iter_t *it)
Function prototype for runnables (systems, observers).
Definition flecs.h:551
void(* ecs_ctx_free_t)(void *ctx)
Function to cleanup context data.
Definition flecs.h:629
int(* ecs_order_by_action_t)(ecs_entity_t e1, const void *ptr1, ecs_entity_t e2, const void *ptr2)
Callback used for comparing components.
Definition flecs.h:582
void(* ecs_xtor_t)(void *ptr, int32_t count, const ecs_type_info_t *type_info)
Constructor/destructor callback.
Definition flecs.h:642
void * ecs_ref_get_id(const ecs_world_t *world, ecs_ref_t *ref, ecs_id_t component)
Get component from ref.
void * ecs_emplace_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component, size_t size, bool *is_new)
Emplace a component.
void ecs_ref_update(const ecs_world_t *world, ecs_ref_t *ref)
Update ref.
const void * ecs_get_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Get an immutable pointer to a component.
void ecs_modified_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Signal that a component has been modified.
ecs_ref_t ecs_ref_init_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Create a component ref.
void * ecs_get_mut_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Get a mutable pointer to a component.
void * ecs_ensure_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component, size_t size)
Ensure entity has component, return pointer.
void ecs_set_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component, size_t size, const void *ptr)
Set the value of a component.
const ecs_id_t ECS_PAIR
Indicates that the id is a pair.
const ecs_id_t ECS_AUTO_OVERRIDE
Automatically override component when it is inherited.
const ecs_id_t ECS_TOGGLE
Adds bitset to storage which allows component to be enabled/disabled.
char * ecs_id_str(const ecs_world_t *world, ecs_id_t component)
Convert component id to string.
bool ecs_id_is_tag(const ecs_world_t *world, ecs_id_t component)
Returns whether specified component is a tag.
ecs_flags32_t ecs_id_get_flags(const ecs_world_t *world, ecs_id_t component)
Get flags associated with id.
bool ecs_id_is_valid(const ecs_world_t *world, ecs_id_t component)
Utility to check if id is valid.
const char * ecs_id_flag_str(ecs_id_t component_flags)
Convert component flag to string.
bool ecs_id_in_use(const ecs_world_t *world, ecs_id_t component)
Returns whether specified component is in use.
bool ecs_id_match(ecs_id_t component, ecs_id_t pattern)
Utility to match a component with a pattern.
void ecs_id_str_buf(const ecs_world_t *world, ecs_id_t component, ecs_strbuf_t *buf)
Write component string to buffer.
bool ecs_id_is_pair(ecs_id_t component)
Utility to check if component is a pair.
ecs_entity_t ecs_get_typeid(const ecs_world_t *world, ecs_id_t component)
Get the type for a component.
ecs_id_t ecs_id_from_str(const ecs_world_t *world, const char *expr)
Convert string to a component.
bool ecs_id_is_wildcard(ecs_id_t component)
Utility to check if component is a wildcard.
bool ecs_id_is_any(ecs_id_t component)
Utility to check if component is an any wildcard.
ecs_entity_t ecs_field_src(const ecs_iter_t *it, int8_t index)
Return field source.
bool ecs_iter_changed(ecs_iter_t *it)
Returns whether current iterator result has changed.
bool ecs_field_is_writeonly(const ecs_iter_t *it, int8_t index)
Test whether the field is writeonly.
ecs_var_t * ecs_iter_get_vars(const ecs_iter_t *it)
Get variable array.
bool ecs_field_is_readonly(const ecs_iter_t *it, int8_t index)
Test whether the field is readonly.
const char * ecs_iter_get_var_name(const ecs_iter_t *it, int32_t var_id)
Get variable name.
ecs_iter_t ecs_worker_iter(const ecs_iter_t *it, int32_t index, int32_t count)
Create a worker iterator.
bool ecs_iter_is_true(ecs_iter_t *it)
Test if iterator is true.
void ecs_iter_fini(ecs_iter_t *it)
Cleanup iterator resources.
char * ecs_iter_str(const ecs_iter_t *it)
Convert iterator to string.
bool ecs_iter_var_is_constrained(ecs_iter_t *it, int32_t var_id)
Returns whether variable is constrained.
ecs_iter_t ecs_page_iter(const ecs_iter_t *it, int32_t offset, int32_t limit)
Create a paged iterator.
int32_t ecs_iter_get_var_count(const ecs_iter_t *it)
Get number of variables.
void * ecs_field_at_w_size(const ecs_iter_t *it, size_t size, int8_t index, int32_t row)
Get data for field at specified row.
ecs_id_t ecs_field_id(const ecs_iter_t *it, int8_t index)
Return id matched for field.
bool ecs_field_is_set(const ecs_iter_t *it, int8_t index)
Test whether field is set.
void ecs_iter_set_var(ecs_iter_t *it, int32_t var_id, ecs_entity_t entity)
Set value for iterator variable.
bool ecs_field_is_self(const ecs_iter_t *it, int8_t index)
Test whether the field is matched on self.
bool ecs_iter_next(ecs_iter_t *it)
Progress any iterator.
ecs_entity_t ecs_iter_get_var(ecs_iter_t *it, int32_t var_id)
Get value of iterator variable as entity.
bool ecs_worker_next(ecs_iter_t *it)
Progress a worker iterator.
ecs_entity_t ecs_iter_first(ecs_iter_t *it)
Get first matching entity from iterator.
int32_t ecs_field_column(const ecs_iter_t *it, int8_t index)
Return index of matched table column.
uint64_t ecs_iter_get_group(const ecs_iter_t *it)
Return the group id for the currently iterated result.
void ecs_iter_set_var_as_table(ecs_iter_t *it, int32_t var_id, const ecs_table_t *table)
Same as ecs_iter_set_var(), but for a table.
ecs_table_t * ecs_iter_get_var_as_table(ecs_iter_t *it, int32_t var_id)
Get value of iterator variable as table.
void * ecs_field_w_size(const ecs_iter_t *it, size_t size, int8_t index)
Get data for field.
int32_t ecs_iter_count(ecs_iter_t *it)
Count number of matched entities in query.
bool ecs_page_next(ecs_iter_t *it)
Progress a paged iterator.
void ecs_iter_set_var_as_range(ecs_iter_t *it, int32_t var_id, const ecs_table_range_t *range)
Same as ecs_iter_set_var(), but for a range of entities This constrains the variable to a range of en...
size_t ecs_field_size(const ecs_iter_t *it, int8_t index)
Return field type size.
ecs_table_range_t ecs_iter_get_var_as_range(ecs_iter_t *it, int32_t var_id)
Get value of iterator variable as table range.
ecs_id_t ecs_strip_generation(ecs_entity_t e)
Remove generation from entity id.
void ecs_make_alive_id(ecs_world_t *world, ecs_id_t component)
Same as ecs_make_alive(), but for components.
bool ecs_is_valid(const ecs_world_t *world, ecs_entity_t e)
Test whether an entity is valid.
void ecs_make_alive(ecs_world_t *world, ecs_entity_t entity)
Ensure id is alive.
ecs_entity_t ecs_get_alive(const ecs_world_t *world, ecs_entity_t e)
Get alive identifier.
bool ecs_exists(const ecs_world_t *world, ecs_entity_t entity)
Test whether an entity exists.
bool ecs_is_alive(const ecs_world_t *world, ecs_entity_t e)
Test whether an entity is alive.
void ecs_set_version(ecs_world_t *world, ecs_entity_t entity)
Override the generation of an entity.
struct ecs_world_info_t ecs_world_info_t
Type that contains information about the world.
struct ecs_query_group_info_t ecs_query_group_info_t
Type that contains information about a query group.
struct ecs_build_info_t ecs_build_info_t
Type with information about the current Flecs build.
void ecs_emit(ecs_world_t *world, ecs_event_desc_t *desc)
Send event.
void ecs_enqueue(ecs_world_t *world, ecs_event_desc_t *desc)
Enqueue event.
ecs_entity_t ecs_observer_init(ecs_world_t *world, const ecs_observer_desc_t *desc)
Create observer.
const ecs_observer_t * ecs_observer_get(const ecs_world_t *world, ecs_entity_t observer)
Get observer object.
struct ecs_event_desc_t ecs_event_desc_t
Used with ecs_emit().
struct ecs_observer_desc_t ecs_observer_desc_t
Used with ecs_observer_init().
#define FLECS_EVENT_DESC_MAX
Maximum number of events in ecs_observer_desc_t.
Definition flecs.h:306
#define ecs_ftime_t
Customizable precision for scalar time values.
Definition flecs.h:59
#define FLECS_ID_DESC_MAX
Maximum number of ids to add ecs_entity_desc_t / ecs_bulk_desc_t.
Definition flecs.h:300
#define FLECS_TERM_COUNT_MAX
Maximum number of terms in queries.
Definition flecs.h:316
char * ecs_get_path_w_sep(const ecs_world_t *world, ecs_entity_t parent, ecs_entity_t child, const char *sep, const char *prefix)
Get a path identifier for an entity.
ecs_entity_t ecs_new_from_path_w_sep(ecs_world_t *world, ecs_entity_t parent, const char *path, const char *sep, const char *prefix)
Find or create entity from path.
ecs_entity_t ecs_lookup_symbol(const ecs_world_t *world, const char *symbol, bool lookup_as_path, bool recursive)
Lookup an entity by its symbol name.
void ecs_set_alias(ecs_world_t *world, ecs_entity_t entity, const char *alias)
Set alias for entity.
ecs_entity_t ecs_lookup(const ecs_world_t *world, const char *path)
Lookup an entity by it's path.
ecs_entity_t ecs_get_scope(const ecs_world_t *world)
Get the current scope.
void ecs_get_path_w_sep_buf(const ecs_world_t *world, ecs_entity_t parent, ecs_entity_t child, const char *sep, const char *prefix, ecs_strbuf_t *buf, bool escape)
Write path identifier to buffer.
ecs_entity_t * ecs_set_lookup_path(ecs_world_t *world, const ecs_entity_t *lookup_path)
Set search path for lookup operations.
ecs_entity_t ecs_set_name(ecs_world_t *world, ecs_entity_t entity, const char *name)
Set the name of an entity.
const char * ecs_get_symbol(const ecs_world_t *world, ecs_entity_t entity)
Get the symbol of an entity.
ecs_entity_t ecs_lookup_path_w_sep(const ecs_world_t *world, ecs_entity_t parent, const char *path, const char *sep, const char *prefix, bool recursive)
Lookup an entity from a path.
ecs_entity_t ecs_set_symbol(ecs_world_t *world, ecs_entity_t entity, const char *symbol)
Set the symbol of an entity.
ecs_entity_t ecs_lookup_child(const ecs_world_t *world, ecs_entity_t parent, const char *name)
Lookup a child entity by name.
const char * ecs_get_name(const ecs_world_t *world, ecs_entity_t entity)
Get the name of an entity.
ecs_entity_t ecs_add_path_w_sep(ecs_world_t *world, ecs_entity_t entity, ecs_entity_t parent, const char *path, const char *sep, const char *prefix)
Add specified path to entity.
ecs_entity_t * ecs_get_lookup_path(const ecs_world_t *world)
Get current lookup path.
ecs_entity_t ecs_set_scope(ecs_world_t *world, ecs_entity_t scope)
Set the current scope.
const char * ecs_set_name_prefix(ecs_world_t *world, const char *prefix)
Set a name prefix for newly created entities.
void ecs_iter_skip(ecs_iter_t *it)
Skip a table while iterating.
void ecs_iter_set_group(ecs_iter_t *it, uint64_t group_id)
Set group to iterate for query iterator.
const ecs_query_t * ecs_query_get(const ecs_world_t *world, ecs_entity_t query)
Get query object.
bool ecs_query_next(ecs_iter_t *it)
Progress query iterator.
const ecs_query_group_info_t * ecs_query_get_group_info(const ecs_query_t *query, uint64_t group_id)
Get information about query group.
bool ecs_query_has(ecs_query_t *query, ecs_entity_t entity, ecs_iter_t *it)
Match entity with query.
bool ecs_query_is_true(const ecs_query_t *query)
Does query return one or more results.
char * ecs_term_str(const ecs_world_t *world, const ecs_term_t *term)
Convert term to string expression.
int32_t ecs_query_find_var(const ecs_query_t *query, const char *name)
Find variable index.
void ecs_query_fini(ecs_query_t *query)
Delete a query.
char * ecs_query_plan_w_profile(const ecs_query_t *query, const ecs_iter_t *it)
Convert query to string with profile.
struct ecs_query_desc_t ecs_query_desc_t
Used with ecs_query_init().
const char * ecs_query_args_parse(ecs_query_t *query, ecs_iter_t *it, const char *expr)
Populate variables from key-value string.
int32_t ecs_query_match_count(const ecs_query_t *query)
Returns how often a match event happened for a cached query.
char * ecs_query_plan(const ecs_query_t *query)
Convert query to a string.
ecs_iter_t ecs_query_iter(const ecs_world_t *world, const ecs_query_t *query)
Create a query iterator.
char * ecs_query_str(const ecs_query_t *query)
Convert query to string expression.
bool ecs_query_var_is_entity(const ecs_query_t *query, int32_t var_id)
Test if variable is an entity.
ecs_query_t * ecs_query_init(ecs_world_t *world, const ecs_query_desc_t *desc)
Create a query.
bool ecs_query_changed(ecs_query_t *query)
Returns whether the query data changed since the last iteration.
bool ecs_query_has_range(ecs_query_t *query, ecs_table_range_t *range, ecs_iter_t *it)
Match range with query.
const char * ecs_query_var_name(const ecs_query_t *query, int32_t var_id)
Get variable name.
bool ecs_term_match_this(const ecs_term_t *term)
Is term matched on $this variable.
bool ecs_query_has_table(ecs_query_t *query, ecs_table_t *table, ecs_iter_t *it)
Match table with query.
void * ecs_query_get_group_ctx(const ecs_query_t *query, uint64_t group_id)
Get context of query group.
ecs_query_count_t ecs_query_count(const ecs_query_t *query)
Returns number of entities and results the query matches with.
bool ecs_term_is_initialized(const ecs_term_t *term)
Test whether a term is set.
bool ecs_term_ref_is_set(const ecs_term_ref_t *ref)
Test whether term ref is set.
struct ecs_query_count_t ecs_query_count_t
Struct returned by ecs_query_count().
bool ecs_term_match_0(const ecs_term_t *term)
Is term matched on 0 source.
const ecs_query_t * ecs_query_get_cache_query(const ecs_query_t *query)
Get query used to populate cache.
struct ecs_term_ref_t ecs_term_ref_t
Type that describes a reference to an entity or variable in a term.
ecs_query_cache_kind_t
Specify cache policy for query.
Definition flecs.h:708
ecs_inout_kind_t
Specify read/write access for term.
Definition flecs.h:687
ecs_oper_kind_t
Specify operator for term.
Definition flecs.h:697
@ EcsQueryCacheAll
Require that all query terms can be cached.
Definition flecs.h:711
@ EcsQueryCacheDefault
Behavior determined by query creation context.
Definition flecs.h:709
@ EcsQueryCacheNone
No caching.
Definition flecs.h:712
@ EcsQueryCacheAuto
Cache query terms that are cacheable.
Definition flecs.h:710
@ EcsOut
Term is only written.
Definition flecs.h:693
@ EcsInOut
Term is both read and written.
Definition flecs.h:691
@ EcsInOutFilter
Same as InOutNone + prevents term from triggering observers.
Definition flecs.h:690
@ EcsInOutDefault
InOut for regular terms, In for shared terms.
Definition flecs.h:688
@ EcsInOutNone
Term is neither read nor written.
Definition flecs.h:689
@ EcsIn
Term is only read.
Definition flecs.h:692
@ EcsNot
The term must not match.
Definition flecs.h:700
@ EcsOptional
The term may match.
Definition flecs.h:701
@ EcsOr
One of the terms in an or chain must match.
Definition flecs.h:699
@ EcsOrFrom
Term must match at least one component from term id.
Definition flecs.h:703
@ EcsAnd
The term must match.
Definition flecs.h:698
@ EcsNotFrom
Term must match none of the components from term id.
Definition flecs.h:704
@ EcsAndFrom
Term must match all components from term id.
Definition flecs.h:702
ecs_table_t * ecs_table_add_id(ecs_world_t *world, ecs_table_t *table, ecs_id_t component)
Get table that has all components of current table plus the specified id.
int32_t ecs_search_offset(const ecs_world_t *world, const ecs_table_t *table, int32_t offset, ecs_id_t component, ecs_id_t *component_out)
Search for component in table type starting from an offset.
ecs_table_t * ecs_table_remove_id(ecs_world_t *world, ecs_table_t *table, ecs_id_t component)
Get table that has all components of current table minus the specified component.
const ecs_type_t * ecs_table_get_type(const ecs_table_t *table)
Get type for table.
int32_t ecs_table_get_column_index(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Get column index for component.
void * ecs_table_get_id(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component, int32_t offset)
Get column from table by component.
int32_t ecs_table_size(const ecs_table_t *table)
Returns allocated size of table.
bool ecs_table_has_flags(ecs_table_t *table, ecs_flags32_t flags)
Test table for flags.
int32_t ecs_table_column_to_type_index(const ecs_table_t *table, int32_t index)
Convert column index to type index.
int32_t ecs_table_column_count(const ecs_table_t *table)
Return number of columns in table.
bool ecs_commit(ecs_world_t *world, ecs_entity_t entity, ecs_record_t *record, ecs_table_t *table, const ecs_type_t *added, const ecs_type_t *removed)
Commit (move) entity to a table.
void * ecs_table_get_column(const ecs_table_t *table, int32_t index, int32_t offset)
Get column from table by column index.
int32_t ecs_search(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component, ecs_id_t *component_out)
Search for component in table type.
int32_t ecs_table_count(const ecs_table_t *table)
Returns the number of entities in the table.
const ecs_entity_t * ecs_table_entities(const ecs_table_t *table)
Returns array with entity ids for table.
void ecs_table_unlock(ecs_world_t *world, ecs_table_t *table)
Unlock a table.
bool ecs_table_has_traversable(const ecs_table_t *table)
Check if table has traversable entities.
int32_t ecs_table_get_depth(const ecs_world_t *world, const ecs_table_t *table, ecs_entity_t rel)
Return depth for table in tree for relationship rel.
int32_t ecs_search_relation(const ecs_world_t *world, const ecs_table_t *table, int32_t offset, ecs_id_t component, ecs_entity_t rel, ecs_flags64_t flags, ecs_entity_t *subject_out, ecs_id_t *component_out, struct ecs_table_record_t **tr_out)
Search for component/relationship id in table type starting from an offset.
bool ecs_table_has_id(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Test if table has component.
void ecs_table_swap_rows(ecs_world_t *world, ecs_table_t *table, int32_t row_1, int32_t row_2)
Swaps two elements inside the table.
void ecs_table_lock(ecs_world_t *world, ecs_table_t *table)
Lock a table.
ecs_table_t * ecs_table_find(ecs_world_t *world, const ecs_id_t *ids, int32_t id_count)
Find table from id array.
size_t ecs_table_get_column_size(const ecs_table_t *table, int32_t index)
Get column size from table.
int32_t ecs_table_get_type_index(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Get type index for component.
void ecs_table_clear_entities(ecs_world_t *world, ecs_table_t *table)
Remove all entities in a table.
int32_t ecs_table_type_to_column_index(const ecs_table_t *table, int32_t index)
Convert type index to column index.
int ecs_value_fini_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *ptr)
Destruct a value.
int ecs_value_fini(const ecs_world_t *world, ecs_entity_t type, void *ptr)
Destruct a value.
int ecs_value_copy(const ecs_world_t *world, ecs_entity_t type, void *dst, const void *src)
Copy value.
int ecs_value_move(const ecs_world_t *world, ecs_entity_t type, void *dst, void *src)
Move value.
int ecs_value_move_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *dst, void *src)
Move value.
void * ecs_value_new_w_type_info(ecs_world_t *world, const ecs_type_info_t *ti)
Construct a value in new storage.
int ecs_value_move_ctor_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *dst, void *src)
Move construct value.
int ecs_value_copy_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *dst, const void *src)
Copy value.
int ecs_value_init_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *ptr)
Construct a value in existing storage.
void * ecs_value_new(ecs_world_t *world, ecs_entity_t type)
Construct a value in new storage.
int ecs_value_free(ecs_world_t *world, ecs_entity_t type, void *ptr)
Destruct a value, free storage.
int ecs_value_move_ctor(const ecs_world_t *world, ecs_entity_t type, void *dst, void *src)
Move construct value.
int ecs_value_init(const ecs_world_t *world, ecs_entity_t type, void *ptr)
Construct a value in existing storage.
struct ecs_entities_t ecs_entities_t
Type returned by ecs_get_entities().
void ecs_atfini(ecs_world_t *world, ecs_fini_action_t action, void *ctx)
Register action to be executed when world is destroyed.
bool ecs_is_fini(const ecs_world_t *world)
Returns whether the world is being deleted.
int ecs_fini(ecs_world_t *world)
Delete a world.
ecs_flags32_t ecs_world_get_flags(const ecs_world_t *world)
Get flags set on the world.
ecs_world_t * ecs_mini(void)
Create a new world with just the core module.
ecs_world_t * ecs_init(void)
Create a new world.
ecs_world_t * ecs_init_w_args(int argc, char *argv[])
Create a new world with arguments.
ecs_entities_t ecs_get_entities(const ecs_world_t *world)
Return entity identifiers in world.
void ecs_set_target_fps(ecs_world_t *world, float fps)
Set target frames per second (FPS) for application.
void ecs_measure_system_time(ecs_world_t *world, bool enable)
Measure system time.
float ecs_frame_begin(ecs_world_t *world, float delta_time)
Begin frame.
void ecs_run_post_frame(ecs_world_t *world, ecs_fini_action_t action, void *ctx)
Register action to be executed once after frame.
bool ecs_should_quit(const ecs_world_t *world)
Return whether a quit has been requested.
void ecs_set_default_query_flags(ecs_world_t *world, ecs_flags32_t flags)
Set default query flags.
void ecs_quit(ecs_world_t *world)
Signal exit This operation signals that the application should quit.
void ecs_measure_frame_time(ecs_world_t *world, bool enable)
Measure frame time.
void ecs_frame_end(ecs_world_t *world)
End frame.
ecs_entity_t ecs_get_entity(const ecs_poly_t *poly)
Get entity from poly.
ecs_id_t ecs_make_pair(ecs_entity_t first, ecs_entity_t second)
Make a pair id.
const ecs_build_info_t * ecs_get_build_info(void)
Get build info.
bool flecs_poly_is_(const ecs_poly_t *object, int32_t type)
Test if pointer is of specified type.
ecs_entity_t ecs_get_max_id(const ecs_world_t *world)
Get the largest issued entity id (not counting generation).
void ecs_run_aperiodic(ecs_world_t *world, ecs_flags32_t flags)
Force aperiodic actions.
void * ecs_get_binding_ctx(const ecs_world_t *world)
Get the world binding context.
void ecs_shrink(ecs_world_t *world)
Free unused memory.
void ecs_dim(ecs_world_t *world, int32_t entity_count)
Dimension the world for a specified number of entities.
void ecs_set_entity_range(ecs_world_t *world, ecs_entity_t id_start, ecs_entity_t id_end)
Set a range for issuing new entity ids.
const ecs_world_info_t * ecs_get_world_info(const ecs_world_t *world)
Get world info.
const ecs_world_t * ecs_get_world(const ecs_poly_t *poly)
Get world from poly.
void ecs_set_ctx(ecs_world_t *world, void *ctx, ecs_ctx_free_t ctx_free)
Set a world context.
void ecs_exclusive_access_begin(ecs_world_t *world, const char *thread_name)
Begin exclusive thread access.
int32_t ecs_delete_empty_tables(ecs_world_t *world, const ecs_delete_empty_tables_desc_t *desc)
Cleanup empty tables.
void ecs_set_binding_ctx(ecs_world_t *world, void *ctx, ecs_ctx_free_t ctx_free)
Set a world binding context.
struct ecs_delete_empty_tables_desc_t ecs_delete_empty_tables_desc_t
Used with ecs_delete_empty_tables().
bool ecs_enable_range_check(ecs_world_t *world, bool enable)
Enable/disable range limits.
void ecs_exclusive_access_end(ecs_world_t *world, bool lock_world)
End exclusive thread access.
void * ecs_get_ctx(const ecs_world_t *world)
Get the world context.
Operating system abstraction API.
Component information.
Definition flecs.h:1544
ecs_size_t size
Component size.
Definition flecs.h:1545
ecs_size_t alignment
Component alignment.
Definition flecs.h:1546
When added to an entity this informs serialization formats which component to use when a value is ass...
Definition flecs.h:1559
ecs_id_t component
Default component id.
Definition flecs.h:1560
A (string) identifier.
Definition flecs.h:1535
ecs_size_t length
Length of identifier.
Definition flecs.h:1537
char * value
Identifier string.
Definition flecs.h:1536
ecs_hashmap_t * index
Current index.
Definition flecs.h:1540
uint64_t hash
Hash of current value.
Definition flecs.h:1538
uint64_t index_hash
Hash of existing record in current index.
Definition flecs.h:1539
Component for storing a poly object.
Definition flecs.h:1550
ecs_poly_t * poly
Pointer to poly object.
Definition flecs.h:1551
Apply a rate filter to a tick source.
Definition timer.h:45
Component used to provide a tick source to systems.
Definition system.h:32
Component used for one shot/interval timer functionality.
Definition timer.h:35
Type with information about the current Flecs build.
Definition flecs.h:1446
int16_t version_major
Major flecs version.
Definition flecs.h:1450
const char ** addons
Addons included in build.
Definition flecs.h:1448
const char * version
Stringified version.
Definition flecs.h:1449
const char * compiler
Compiler used to compile flecs.
Definition flecs.h:1447
bool sanitize
Is this a sanitize build.
Definition flecs.h:1454
bool perf_trace
Is this a perf tracing build.
Definition flecs.h:1455
int16_t version_minor
Minor flecs version.
Definition flecs.h:1451
bool debug
Is this a debug build.
Definition flecs.h:1453
int16_t version_patch
Patch flecs version.
Definition flecs.h:1452
Used with ecs_bulk_init().
Definition flecs.h:1069
void ** data
Array with component data to insert.
Definition flecs.h:1081
ecs_id_t ids[(32)]
Ids to create the entities with.
Definition flecs.h:1079
int32_t count
Number of entities to create/populate.
Definition flecs.h:1077
int32_t _canary
Used for validity testing.
Definition flecs.h:1070
ecs_entity_t * entities
Entities to bulk insert.
Definition flecs.h:1072
ecs_table_t * table
Table to insert the entities into.
Definition flecs.h:1088
Used with ecs_component_init().
Definition flecs.h:1099
int32_t _canary
Used for validity testing.
Definition flecs.h:1100
ecs_type_info_t type
Parameters for type (size, hooks, ...)
Definition flecs.h:1106
ecs_entity_t entity
Existing entity to associate with observer (optional)
Definition flecs.h:1103
Used with ecs_delete_empty_tables().
Definition flecs.h:2654
uint16_t delete_generation
Delete table when generation > delete_generation.
Definition flecs.h:2659
double time_budget_seconds
Amount of time operation is allowed to spend.
Definition flecs.h:2662
uint16_t clear_generation
Free table data when generation > clear_generation.
Definition flecs.h:2656
Type returned by ecs_get_entities().
Definition flecs.h:2021
int32_t alive_count
Number of alive entity ids.
Definition flecs.h:2024
int32_t count
Total number of entity ids.
Definition flecs.h:2023
const ecs_entity_t * ids
Array with all entity ids in the world.
Definition flecs.h:2022
Used with ecs_entity_init().
Definition flecs.h:1023
const char * sep
Optional custom separator for hierarchical names.
Definition flecs.h:1035
const char * root_sep
Optional, used for identifiers relative to root.
Definition flecs.h:1039
const char * name
Name of the entity.
Definition flecs.h:1030
bool use_low_id
When set to true, a low id (typically reserved for components) will be used to create the entity,...
Definition flecs.h:1051
const char * symbol
Optional entity symbol.
Definition flecs.h:1041
int32_t _canary
Used for validity testing.
Definition flecs.h:1024
const ecs_id_t * add
0-terminated array of ids to add to the entity.
Definition flecs.h:1056
const char * add_expr
String expression with components to add.
Definition flecs.h:1062
const ecs_value_t * set
0-terminated array of values to set on the entity.
Definition flecs.h:1059
ecs_entity_t id
Set to modify existing entity (optional)
Definition flecs.h:1026
ecs_entity_t parent
Parent entity.
Definition flecs.h:1028
Used with ecs_emit().
Definition flecs.h:1392
ecs_entity_t entity
Single-entity alternative to setting table / offset / count.
Definition flecs.h:1417
const void * const_param
Same as param, but with the guarantee that the value won't be modified.
Definition flecs.h:1428
ecs_table_t * table
The table for which to notify.
Definition flecs.h:1402
int32_t count
Limit number of notified entities to count.
Definition flecs.h:1414
ecs_table_t * other_table
Optional 2nd table to notify.
Definition flecs.h:1406
int32_t offset
Limit notified entities to ones starting from offset (row) in table.
Definition flecs.h:1409
const ecs_type_t * ids
Component ids.
Definition flecs.h:1399
ecs_poly_t * observable
Observable (usually the world)
Definition flecs.h:1431
ecs_entity_t event
The event id.
Definition flecs.h:1394
ecs_flags32_t flags
Event flags.
Definition flecs.h:1434
void * param
Optional context.
Definition flecs.h:1423
Header for ecs_poly_t objects.
Definition flecs.h:504
int32_t type
Magic number indicating which type of flecs object.
Definition flecs.h:505
int32_t refcount
Refcount, to enable RAII handles.
Definition flecs.h:506
ecs_mixins_t * mixins
Table with offsets to (optional) mixins.
Definition flecs.h:507
Iterator.
Definition flecs.h:1147
ecs_world_t * real_world
Actual world.
Definition flecs.h:1150
void * param
Param passed to ecs_run.
Definition flecs.h:1183
ecs_entity_t event
The event (if applicable)
Definition flecs.h:1171
int32_t frame_offset
Offset relative to start of iteration.
Definition flecs.h:1194
ecs_flags32_t ref_fields
Bitset with fields that aren't component arrays.
Definition flecs.h:1165
ecs_entity_t interrupted_by
When set, system execution is interrupted.
Definition flecs.h:1198
ecs_flags32_t flags
Iterator flags.
Definition flecs.h:1197
ecs_iter_t * chain_it
Optional, allows for creating iterator chains.
Definition flecs.h:1205
void * ctx
System context.
Definition flecs.h:1184
void * run_ctx
Run language binding context.
Definition flecs.h:1187
ecs_table_t * table
Current table.
Definition flecs.h:1159
int32_t offset
Offset relative to current table.
Definition flecs.h:1153
ecs_id_t event_id
The (component) id for the event.
Definition flecs.h:1172
ecs_iter_fini_action_t fini
Function to cleanup iterator resources.
Definition flecs.h:1204
ecs_iter_private_t priv_
Private data.
Definition flecs.h:1199
ecs_world_t * world
The world.
Definition flecs.h:1149
void * callback_ctx
Callback language binding context.
Definition flecs.h:1186
ecs_entity_t * sources
Entity on which the id was matched (0 if same as entities)
Definition flecs.h:1162
void * binding_ctx
System binding context.
Definition flecs.h:1185
ecs_flags32_t row_fields
Fields that must be obtained with field_at.
Definition flecs.h:1166
float delta_system_time
Time elapsed since last system invocation.
Definition flecs.h:1191
const ecs_query_t * query
Query being evaluated.
Definition flecs.h:1180
int8_t term_index
Index of term that emitted an event.
Definition flecs.h:1177
ecs_entity_t system
The system (if applicable)
Definition flecs.h:1170
ecs_flags32_t set_fields
Fields that are set.
Definition flecs.h:1164
const ecs_size_t * sizes
Component sizes.
Definition flecs.h:1158
float delta_time
Time elapsed since last frame.
Definition flecs.h:1190
ecs_flags32_t up_fields
Bitset with fields matched through up traversal.
Definition flecs.h:1167
ecs_iter_action_t callback
Callback of system or observer.
Definition flecs.h:1203
int8_t field_count
Number of fields in iterator.
Definition flecs.h:1176
ecs_table_t * other_table
Prev or next table when adding/removing.
Definition flecs.h:1160
int32_t event_cur
Unique event id.
Definition flecs.h:1173
const ecs_table_record_t ** trs
Info on where to find field in table.
Definition flecs.h:1157
int32_t count
Number of entities to iterate.
Definition flecs.h:1154
void ** ptrs
Component pointers.
Definition flecs.h:1156
ecs_iter_next_action_t next
Function to progress iterator.
Definition flecs.h:1202
const ecs_entity_t * entities
Entity identifiers.
Definition flecs.h:1155
ecs_id_t * ids
(Component) ids
Definition flecs.h:1161
ecs_flags64_t constrained_vars
Bitset that marks constrained variables.
Definition flecs.h:1163
Used with ecs_observer_init().
Definition flecs.h:1330
ecs_ctx_free_t run_ctx_free
Callback to free run ctx.
Definition flecs.h:1374
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:1362
void * run_ctx
Context associated with run (for language bindings).
Definition flecs.h:1371
ecs_entity_t entity
Existing entity to associate with observer (optional)
Definition flecs.h:1335
ecs_entity_t events[(8)]
Events to observe (OnAdd, OnRemove, OnSet)
Definition flecs.h:1341
int32_t * last_event_id
Optional shared last event id for multiple observers.
Definition flecs.h:1381
void * callback_ctx
Context associated with callback (for language bindings).
Definition flecs.h:1365
void * ctx
User context to pass to callback.
Definition flecs.h:1359
ecs_query_desc_t query
Query for observer.
Definition flecs.h:1338
ecs_poly_t * observable
Observable with which to register the observer.
Definition flecs.h:1377
ecs_ctx_free_t callback_ctx_free
Callback to free callback ctx.
Definition flecs.h:1368
int8_t term_index_
Used for internal purposes.
Definition flecs.h:1384
ecs_iter_action_t callback
Callback to invoke on an event, invoked when the observer matches.
Definition flecs.h:1348
bool yield_existing
When observer is created, generate events from existing data.
Definition flecs.h:1345
ecs_run_action_t run
Callback invoked on an event.
Definition flecs.h:1356
int32_t _canary
Used for validity testing.
Definition flecs.h:1332
An observer reacts to events matching a query.
Definition flecs.h:858
int32_t event_count
Number of events.
Definition flecs.h:865
ecs_iter_action_t callback
See ecs_observer_desc_t::callback.
Definition flecs.h:867
ecs_entity_t entity
Entity associated with observer.
Definition flecs.h:881
ecs_observable_t * observable
Observable for observer.
Definition flecs.h:878
ecs_run_action_t run
See ecs_observer_desc_t::run.
Definition flecs.h:868
ecs_header_t hdr
Object header.
Definition flecs.h:859
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:874
void * run_ctx
Run language binding context.
Definition flecs.h:872
ecs_world_t * world
The world.
Definition flecs.h:880
ecs_ctx_free_t run_ctx_free
Callback to free run_ctx.
Definition flecs.h:876
void * callback_ctx
Callback language binding context.
Definition flecs.h:871
void * ctx
Observer context.
Definition flecs.h:870
ecs_entity_t events[(8)]
Observer events.
Definition flecs.h:864
ecs_ctx_free_t callback_ctx_free
Callback to free callback_ctx.
Definition flecs.h:875
ecs_query_t * query
Observer query.
Definition flecs.h:861
Struct returned by ecs_query_count().
Definition flecs.h:5029
int32_t entities
Number of entities returned by query.
Definition flecs.h:5031
int32_t results
Number of results returned by query.
Definition flecs.h:5030
int32_t tables
Number of tables returned by query.
Definition flecs.h:5032
Used with ecs_query_init().
Definition flecs.h:1256
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:1317
ecs_id_t group_by
Component id to be used for grouping.
Definition flecs.h:1287
ecs_term_t terms[32]
Query terms.
Definition flecs.h:1261
int32_t _canary
Used for validity testing.
Definition flecs.h:1258
void * ctx
User context to pass to callback.
Definition flecs.h:1311
ecs_ctx_free_t group_by_ctx_free
Function to free group_by_ctx.
Definition flecs.h:1308
void * group_by_ctx
Context to pass to group_by.
Definition flecs.h:1305
void * binding_ctx
Context to be used for language bindings.
Definition flecs.h:1314
ecs_entity_t order_by
Component to sort on, used together with order_by_callback or order_by_table_callback.
Definition flecs.h:1283
ecs_order_by_action_t order_by_callback
Callback used for ordering query results.
Definition flecs.h:1275
ecs_group_create_action_t on_group_create
Callback that is invoked when a new group is created.
Definition flecs.h:1298
ecs_entity_t entity
Entity associated with query (optional)
Definition flecs.h:1323
ecs_ctx_free_t binding_ctx_free
Callback to free binding_ctx.
Definition flecs.h:1320
ecs_group_by_action_t group_by_callback
Callback used for grouping results.
Definition flecs.h:1294
ecs_group_delete_action_t on_group_delete
Callback that is invoked when an existing group is deleted.
Definition flecs.h:1302
ecs_sort_table_action_t order_by_table_callback
Callback used for ordering query results.
Definition flecs.h:1279
ecs_flags32_t flags
Flags for enabling query features.
Definition flecs.h:1270
ecs_query_cache_kind_t cache_kind
Caching policy of query.
Definition flecs.h:1267
const char * expr
Query DSL expression (optional)
Definition flecs.h:1264
Type that contains information about a query group.
Definition flecs.h:1518
int32_t table_count
Number of tables in group.
Definition flecs.h:1521
void * ctx
Group context, returned by on_group_create.
Definition flecs.h:1522
int32_t match_count
How often tables have been matched/unmatched.
Definition flecs.h:1520
Queries are lists of constraints (terms) that match entities.
Definition flecs.h:817
ecs_flags32_t row_fields
Fields that must be acquired with field_at.
Definition flecs.h:837
ecs_flags32_t data_fields
Fields that have data.
Definition flecs.h:834
ecs_flags32_t read_fields
Fields that read data.
Definition flecs.h:836
ecs_header_t hdr
Object header.
Definition flecs.h:818
int8_t var_count
Number of query variables.
Definition flecs.h:826
ecs_flags32_t fixed_fields
Fields with a fixed source.
Definition flecs.h:831
ecs_flags32_t var_fields
Fields with non-$this variable source.
Definition flecs.h:832
ecs_flags32_t write_fields
Fields that write data.
Definition flecs.h:835
int32_t eval_count
Number of times query is evaluated.
Definition flecs.h:852
ecs_world_t * world
World or stage query was created with.
Definition flecs.h:850
ecs_flags32_t static_id_fields
Fields with a static (component) id.
Definition flecs.h:833
uint64_t bloom_filter
Bitmask used to quickly discard tables.
Definition flecs.h:824
ecs_world_t * real_world
Actual world.
Definition flecs.h:849
ecs_flags32_t set_fields
Fields that will be set.
Definition flecs.h:839
ecs_entity_t entity
Entity associated with query (optional)
Definition flecs.h:848
void * ctx
User context to pass to callback.
Definition flecs.h:845
int32_t * sizes
Component sizes.
Definition flecs.h:821
ecs_id_t * ids
Component ids.
Definition flecs.h:822
ecs_flags32_t shared_readonly_fields
Fields that don't write shared data.
Definition flecs.h:838
ecs_term_t * terms
Query terms.
Definition flecs.h:820
ecs_query_cache_kind_t cache_kind
Caching policy of query.
Definition flecs.h:841
int8_t term_count
Number of query terms.
Definition flecs.h:827
char ** vars
Array with variable names for iterator.
Definition flecs.h:843
int8_t field_count
Number of fields returned by query.
Definition flecs.h:828
ecs_flags32_t flags
Query flags.
Definition flecs.h:825
void * binding_ctx
Context to be used for language bindings.
Definition flecs.h:846
Type that describes a reference to an entity or variable in a term.
Definition flecs.h:778
const char * name
Name.
Definition flecs.h:785
ecs_entity_t id
Entity id.
Definition flecs.h:779
Type that describes a term (single element in a query).
Definition flecs.h:793
ecs_term_ref_t src
Source of term.
Definition flecs.h:799
int8_t field_index
Index of field for term in iterator.
Definition flecs.h:810
ecs_id_t id
Component id to be matched by term.
Definition flecs.h:794
int16_t oper
Operator of term.
Definition flecs.h:808
ecs_term_ref_t second
Second element of pair.
Definition flecs.h:801
ecs_flags16_t flags_
Flags that help eval, set by ecs_query_init()
Definition flecs.h:811
ecs_entity_t trav
Relationship to traverse when looking for the component.
Definition flecs.h:803
int16_t inout
Access to contents matched by term.
Definition flecs.h:807
ecs_term_ref_t first
Component or first element of pair.
Definition flecs.h:800
ecs_copy_t copy_ctor
Ctor + copy.
Definition flecs.h:937
void * lifecycle_ctx
Component lifecycle context (see meta add-on)
Definition flecs.h:989
void * ctx
User defined context.
Definition flecs.h:987
ecs_iter_action_t on_remove
Callback that is invoked when an instance of the component is removed.
Definition flecs.h:979
void * binding_ctx
Language binding context.
Definition flecs.h:988
ecs_move_t move_dtor
Move + dtor.
Definition flecs.h:952
ecs_flags32_t flags
Hook flags.
Definition flecs.h:964
ecs_cmp_t cmp
Compare hook.
Definition flecs.h:955
ecs_copy_t copy
copy assignment
Definition flecs.h:933
ecs_ctx_free_t lifecycle_ctx_free
Callback to free lifecycle_ctx.
Definition flecs.h:993
ecs_iter_action_t on_set
Callback that is invoked when an instance of the component is set.
Definition flecs.h:974
ecs_move_t move
move assignment
Definition flecs.h:934
ecs_xtor_t ctor
ctor
Definition flecs.h:931
ecs_iter_action_t on_replace
Callback that is invoked with the existing and new value before the value is assigned.
Definition flecs.h:985
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:991
ecs_iter_action_t on_add
Callback that is invoked when an instance of a component is added.
Definition flecs.h:969
ecs_ctx_free_t binding_ctx_free
Callback to free binding_ctx.
Definition flecs.h:992
ecs_move_t move_ctor
Ctor + move.
Definition flecs.h:940
ecs_equals_t equals
Equals hook.
Definition flecs.h:958
ecs_move_t ctor_move_dtor
Ctor + move + dtor (or move_ctor + dtor).
Definition flecs.h:946
ecs_xtor_t dtor
dtor
Definition flecs.h:932
Type that contains component information (passed to ctors/dtors/...)
Definition flecs.h:1000
ecs_size_t alignment
Alignment of type.
Definition flecs.h:1002
ecs_size_t size
Size of type.
Definition flecs.h:1001
const char * name
Type name.
Definition flecs.h:1005
ecs_entity_t component
Handle to component (do not set)
Definition flecs.h:1004
ecs_type_hooks_t hooks
Type hooks.
Definition flecs.h:1003
A type is a list of (component) ids.
Definition flecs.h:382
ecs_id_t * array
Array with ids.
Definition flecs.h:383
int32_t count
Number of elements in array.
Definition flecs.h:384
Utility to hold a value of a dynamic type.
Definition flecs.h:1014
void * ptr
Pointer to value.
Definition flecs.h:1016
ecs_entity_t type
Type of value.
Definition flecs.h:1015
Type that contains information about the world.
Definition flecs.h:1459
float delta_time
Time passed to or computed by ecs_progress()
Definition flecs.h:1465
ecs_entity_t min_id
First allowed entity id.
Definition flecs.h:1461
int64_t set_count
Set commands processed.
Definition flecs.h:1501
double world_time_total
Time elapsed in simulation.
Definition flecs.h:1473
int32_t tag_id_count
Number of tag (no data) ids in the world.
Definition flecs.h:1489
int32_t component_id_count
Number of component (data) ids in the world.
Definition flecs.h:1490
int64_t pipeline_build_count_total
Total number of pipeline builds.
Definition flecs.h:1485
int64_t eval_comp_monitors_total
Total number of monitor evaluations.
Definition flecs.h:1478
int32_t table_count
Number of tables.
Definition flecs.h:1493
float delta_time_raw
Raw delta time (no time scaling)
Definition flecs.h:1464
float frame_time_total
Total time spent processing a frame.
Definition flecs.h:1468
int64_t table_create_total
Total number of times a table was created.
Definition flecs.h:1483
int64_t observers_ran_frame
Total number of times observer was invoked.
Definition flecs.h:1487
float system_time_total
Total time spent in systems.
Definition flecs.h:1469
int64_t id_delete_total
Total number of times an id was deleted.
Definition flecs.h:1482
int64_t systems_ran_frame
Total number of systems ran in last frame.
Definition flecs.h:1486
float merge_time_total
Total time spent in merges.
Definition flecs.h:1471
struct ecs_world_info_t::@0 cmd
Command statistics.
int64_t discard_count
Commands discarded, happens when entity is no longer alive when running the command.
Definition flecs.h:1504
int64_t clear_count
Clear commands processed.
Definition flecs.h:1500
ecs_entity_t last_component_id
Last issued component entity id.
Definition flecs.h:1460
int64_t frame_count_total
Total number of frames.
Definition flecs.h:1476
ecs_entity_t max_id
Last allowed entity id.
Definition flecs.h:1462
int64_t merge_count_total
Total number of merges.
Definition flecs.h:1477
int64_t other_count
Other commands processed.
Definition flecs.h:1506
int64_t batched_command_count
Commands batched.
Definition flecs.h:1508
int64_t table_delete_total
Total number of times a table was deleted.
Definition flecs.h:1484
int64_t delete_count
Selete commands processed.
Definition flecs.h:1499
int64_t rematch_count_total
Total number of rematches.
Definition flecs.h:1479
int64_t id_create_total
Total number of times a new id was created.
Definition flecs.h:1481
int64_t batched_entity_count
Entities for which commands were batched.
Definition flecs.h:1507
float time_scale
Time scale applied to delta_time.
Definition flecs.h:1466
int32_t pair_id_count
Number of pair ids in the world.
Definition flecs.h:1491
float rematch_time_total
Time spent on query rematching.
Definition flecs.h:1472
int64_t ensure_count
Ensure/emplace commands processed.
Definition flecs.h:1502
float target_fps
Target fps.
Definition flecs.h:1467
double world_time_total_raw
Time elapsed in simulation (no scaling)
Definition flecs.h:1474
float emit_time_total
Total time spent notifying observers.
Definition flecs.h:1470
int64_t modified_count
Modified commands processed.
Definition flecs.h:1503
const char * name_prefix
Value set by ecs_set_name_prefix().
Definition flecs.h:1511
int64_t event_count
Enqueued custom events.
Definition flecs.h:1505
int64_t add_count
Add commands processed.
Definition flecs.h:1497
int64_t remove_count
Remove commands processed.
Definition flecs.h:1498