Flecs v4.1
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 5
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
62
68// #define FLECS_ACCURATE_COUNTERS
69
75// #define FLECS_DISABLE_COUNTERS
76
77/* Make sure provided configuration is valid */
78#if defined(FLECS_DEBUG) && defined(FLECS_NDEBUG)
79#warning "invalid configuration: cannot both define FLECS_DEBUG and FLECS_NDEBUG"
80#endif
81#if defined(FLECS_DEBUG) && defined(NDEBUG)
82#warning "invalid configuration: cannot both define FLECS_DEBUG and NDEBUG"
83#endif
84
89#if !defined(FLECS_DEBUG) && !defined(FLECS_NDEBUG)
90#if defined(NDEBUG)
91#define FLECS_NDEBUG
92#else
93#define FLECS_DEBUG
94#endif
95#endif
96
101#ifdef FLECS_SANITIZE
102#ifndef FLECS_DEBUG
103#define FLECS_DEBUG /* If sanitized mode is enabled, so is debug mode */
104#endif
105#endif
106
111#ifdef FLECS_DEBUG
112#ifndef FLECS_DEBUG_INFO
113#define FLECS_DEBUG_INFO
114#endif
115#ifndef FLECS_EXCLUSIVE_ACCESS
116#define FLECS_EXCLUSIVE_ACCESS /* Enable exclusive access checks in debug mode */
117#endif
118#endif
119
120/* Tip: if you see weird behavior that you think might be a bug, make sure to
121 * test with the FLECS_DEBUG or FLECS_SANITIZE flags enabled. There's a good
122 * chance that this gives you more information about the issue! */
123
137// #define FLECS_SOFT_ASSERT
138
144// #define FLECS_KEEP_ASSERT
145
152// #define FLECS_DEFAULT_TO_UNCACHED_QUERIES
153
166// #define FLECS_CREATE_MEMBER_ENTITIES
167
176// #define FLECS_CPP_NO_AUTO_REGISTRATION
177
185// #define FLECS_CPP_NO_ENUM_REFLECTION
186
191// #define FLECS_NO_ALWAYS_INLINE
192
220// #define FLECS_CUSTOM_BUILD
221
222#ifndef FLECS_CUSTOM_BUILD
223#define FLECS_ALERTS
224#define FLECS_APP
225// #define FLECS_C /**< C API convenience macros, always enabled. */
226#define FLECS_CPP
227#define FLECS_DOC
228// #define FLECS_EXCLUSIVE_ACCESS /**< Enable exclusive world access checks. */
229// #define FLECS_JOURNAL /**< Journaling addon. */
230#define FLECS_JSON
231#define FLECS_HTTP
232#define FLECS_LOG
233#define FLECS_META
234#define FLECS_METRICS
235#define FLECS_MODULE
236#define FLECS_OS_API_IMPL
237// #define FLECS_PERF_TRACE /**< Enable performance tracing. */
238#define FLECS_PIPELINE
239#define FLECS_REST
240#define FLECS_PARSER
241#define FLECS_QUERY_DSL
242#define FLECS_SCRIPT
243// #define FLECS_SCRIPT_MATH /**< Math functions for Flecs script (may require linking with libm). */
244#define FLECS_SYSTEM
245#define FLECS_STATS
246#define FLECS_TIMER
247#define FLECS_UNITS
248#endif // ifndef FLECS_CUSTOM_BUILD
249
253// #define FLECS_LOW_FOOTPRINT
254#ifdef FLECS_LOW_FOOTPRINT
255#define FLECS_HI_COMPONENT_ID 16
256#define FLECS_HI_ID_RECORD_ID 16
257#define FLECS_ENTITY_PAGE_BITS 6
258#define FLECS_USE_OS_ALLOC
259#define FLECS_DEFAULT_TO_UNCACHED_QUERIES
260#endif
261
276#ifndef FLECS_HI_COMPONENT_ID
277#define FLECS_HI_COMPONENT_ID 256
278#endif
279
286#ifndef FLECS_HI_ID_RECORD_ID
287#define FLECS_HI_ID_RECORD_ID 1024
288#endif
289
295#ifndef FLECS_SPARSE_PAGE_BITS
296#define FLECS_SPARSE_PAGE_BITS 6
297#endif
298
301#ifndef FLECS_ENTITY_PAGE_BITS
302#define FLECS_ENTITY_PAGE_BITS 10
303#endif
304
309// #define FLECS_USE_OS_ALLOC
310
313#ifndef FLECS_ID_DESC_MAX
314#define FLECS_ID_DESC_MAX 32
315#endif
316
319#ifndef FLECS_EVENT_DESC_MAX
320#define FLECS_EVENT_DESC_MAX 8
321#endif
322
325#define FLECS_VARIABLE_COUNT_MAX 64
326
329#ifndef FLECS_TERM_COUNT_MAX
330#define FLECS_TERM_COUNT_MAX 32
331#endif
332
335#ifndef FLECS_TERM_ARG_COUNT_MAX
336#define FLECS_TERM_ARG_COUNT_MAX 16
337#endif
338
341#ifndef FLECS_QUERY_VARIABLE_COUNT_MAX
342#define FLECS_QUERY_VARIABLE_COUNT_MAX 64
343#endif
344
347#ifndef FLECS_QUERY_SCOPE_NESTING_MAX
348#define FLECS_QUERY_SCOPE_NESTING_MAX 8
349#endif
350
355#ifndef FLECS_DAG_DEPTH_MAX
356#define FLECS_DAG_DEPTH_MAX 128
357#endif
358
363#define FLECS_TREE_SPAWNER_DEPTH_CACHE_SIZE (6)
364
367#include "flecs/private/api_defines.h"
368
378typedef uint64_t ecs_id_t;
379
386
402typedef struct {
404 int32_t count;
405} ecs_type_t;
406
430
433
436
438typedef struct ecs_term_t ecs_term_t;
439
442
461
466
471typedef struct ecs_iter_t ecs_iter_t;
472
481typedef struct ecs_ref_t ecs_ref_t;
482
487
492
495
498
518typedef void ecs_poly_t;
519
522
529
532
535#include "flecs/datastructures/vec.h" /* Vector datatype */
536#include "flecs/datastructures/sparse.h" /* Sparse set */
537#include "flecs/datastructures/block_allocator.h" /* Block allocator */
538#include "flecs/datastructures/stack_allocator.h" /* Stack allocator */
539#include "flecs/datastructures/map.h" /* Map */
540#include "flecs/datastructures/allocator.h" /* Allocator */
541#include "flecs/datastructures/strbuf.h" /* String builder */
542#include "flecs/os_api.h" /* Abstraction for operating system functions */
543
544#ifdef __cplusplus
545extern "C" {
546#endif
547
572typedef void (*ecs_run_action_t)(
573 ecs_iter_t *it);
574
581typedef void (*ecs_iter_action_t)(
582 ecs_iter_t *it);
583
592 ecs_iter_t *it);
593
600 ecs_iter_t *it);
601
604 ecs_entity_t e1,
605 const void *ptr1,
606 ecs_entity_t e2,
607 const void *ptr2);
608
611 ecs_world_t* world,
612 ecs_table_t* table,
613 ecs_entity_t* entities,
614 void* ptr,
615 int32_t size,
616 int32_t lo,
617 int32_t hi,
618 ecs_order_by_action_t order_by);
619
621typedef uint64_t (*ecs_group_by_action_t)(
622 ecs_world_t *world,
623 ecs_table_t *table,
624 ecs_id_t group_id,
625 void *ctx);
626
628typedef void* (*ecs_group_create_action_t)(
629 ecs_world_t *world,
630 uint64_t group_id,
631 void *group_by_ctx); /* from ecs_query_desc_t */
632
635 ecs_world_t *world,
636 uint64_t group_id,
637 void *group_ctx, /* return value from ecs_group_create_action_t */
638 void *group_by_ctx); /* from ecs_query_desc_t */
639
641typedef void (*ecs_module_action_t)(
642 ecs_world_t *world);
643
645typedef void (*ecs_fini_action_t)(
646 ecs_world_t *world,
647 void *ctx);
648
650typedef void (*ecs_ctx_free_t)(
651 void *ctx);
652
654typedef int (*ecs_compare_action_t)(
655 const void *ptr1,
656 const void *ptr2);
657
659typedef uint64_t (*ecs_hash_value_action_t)(
660 const void *ptr);
661
663typedef void (*ecs_xtor_t)(
664 void *ptr,
665 int32_t count,
666 const ecs_type_info_t *type_info);
667
669typedef void (*ecs_copy_t)(
670 void *dst_ptr,
671 const void *src_ptr,
672 int32_t count,
673 const ecs_type_info_t *type_info);
674
676typedef void (*ecs_move_t)(
677 void *dst_ptr,
678 void *src_ptr,
679 int32_t count,
680 const ecs_type_info_t *type_info);
681
683typedef int (*ecs_cmp_t)(
684 const void *a_ptr,
685 const void *b_ptr,
686 const ecs_type_info_t *type_info);
687
689typedef bool (*ecs_equals_t)(
690 const void *a_ptr,
691 const void *b_ptr,
692 const ecs_type_info_t *type_info);
693
695typedef void (*flecs_poly_dtor_t)(
696 ecs_poly_t *poly);
697
716
727
735
742#define EcsSelf (1llu << 63)
743
748#define EcsUp (1llu << 62)
749
754#define EcsTrav (1llu << 61)
755
760#define EcsCascade (1llu << 60)
761
766#define EcsDesc (1llu << 59)
767
772#define EcsIsVariable (1llu << 58)
773
778#define EcsIsEntity (1llu << 57)
779
784#define EcsIsName (1llu << 56)
785
790#define EcsTraverseFlags (EcsSelf|EcsUp|EcsTrav|EcsCascade|EcsDesc)
791
796#define EcsTermRefFlags (EcsTraverseFlags|EcsIsVariable|EcsIsEntity|EcsIsName)
797
812
834
875
904
912/* Flags that can be used to check which hooks a type has set */
913#define ECS_TYPE_HOOK_CTOR ECS_CAST(ecs_flags32_t, 1 << 0)
914#define ECS_TYPE_HOOK_DTOR ECS_CAST(ecs_flags32_t, 1 << 1)
915#define ECS_TYPE_HOOK_COPY ECS_CAST(ecs_flags32_t, 1 << 2)
916#define ECS_TYPE_HOOK_MOVE ECS_CAST(ecs_flags32_t, 1 << 3)
917#define ECS_TYPE_HOOK_COPY_CTOR ECS_CAST(ecs_flags32_t, 1 << 4)
918#define ECS_TYPE_HOOK_MOVE_CTOR ECS_CAST(ecs_flags32_t, 1 << 5)
919#define ECS_TYPE_HOOK_CTOR_MOVE_DTOR ECS_CAST(ecs_flags32_t, 1 << 6)
920#define ECS_TYPE_HOOK_MOVE_DTOR ECS_CAST(ecs_flags32_t, 1 << 7)
921#define ECS_TYPE_HOOK_CMP ECS_CAST(ecs_flags32_t, 1 << 8)
922#define ECS_TYPE_HOOK_EQUALS ECS_CAST(ecs_flags32_t, 1 << 9)
923
924
925/* Flags that can be used to set/check which hooks of a type are invalid */
926#define ECS_TYPE_HOOK_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 10)
927#define ECS_TYPE_HOOK_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 12)
928#define ECS_TYPE_HOOK_COPY_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 13)
929#define ECS_TYPE_HOOK_MOVE_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 14)
930#define ECS_TYPE_HOOK_COPY_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 15)
931#define ECS_TYPE_HOOK_MOVE_CTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 16)
932#define ECS_TYPE_HOOK_CTOR_MOVE_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 17)
933#define ECS_TYPE_HOOK_MOVE_DTOR_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 18)
934#define ECS_TYPE_HOOK_CMP_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 19)
935#define ECS_TYPE_HOOK_EQUALS_ILLEGAL ECS_CAST(ecs_flags32_t, 1 << 20)
936
937/* Internal debug flag that indicates type hooks have been invoked */
938#define ECS_TYPE_HOOK_IN_USE ECS_CAST(ecs_flags32_t, 1 << 21)
939
940
941/* All valid hook flags */
942#define ECS_TYPE_HOOKS (ECS_TYPE_HOOK_CTOR|ECS_TYPE_HOOK_DTOR|\
943 ECS_TYPE_HOOK_COPY|ECS_TYPE_HOOK_MOVE|ECS_TYPE_HOOK_COPY_CTOR|\
944 ECS_TYPE_HOOK_MOVE_CTOR|ECS_TYPE_HOOK_CTOR_MOVE_DTOR|\
945 ECS_TYPE_HOOK_MOVE_DTOR|ECS_TYPE_HOOK_CMP|ECS_TYPE_HOOK_EQUALS)
946
947/* All invalid hook flags */
948#define ECS_TYPE_HOOKS_ILLEGAL (ECS_TYPE_HOOK_CTOR_ILLEGAL|\
949 ECS_TYPE_HOOK_DTOR_ILLEGAL|ECS_TYPE_HOOK_COPY_ILLEGAL|\
950 ECS_TYPE_HOOK_MOVE_ILLEGAL|ECS_TYPE_HOOK_COPY_CTOR_ILLEGAL|\
951 ECS_TYPE_HOOK_MOVE_CTOR_ILLEGAL|ECS_TYPE_HOOK_CTOR_MOVE_DTOR_ILLEGAL|\
952 ECS_TYPE_HOOK_MOVE_DTOR_ILLEGAL|ECS_TYPE_HOOK_CMP_ILLEGAL|\
953 ECS_TYPE_HOOK_EQUALS_ILLEGAL)
1018
1030
1031#include "flecs/private/api_types.h" /* Supporting API types */
1032#include "flecs/private/api_support.h" /* Supporting API functions */
1033#include "flecs/datastructures/hashmap.h" /* Hashmap */
1034#include "flecs/private/api_internals.h" /* Supporting API functions */
1035
1041
1046typedef struct ecs_entity_desc_t {
1047 int32_t _canary;
1053 const char *name;
1058 const char *sep;
1062 const char *root_sep;
1064 const char *symbol;
1080
1083
1085 const char *add_expr;
1087
1117
1131
1171 /* World */
1175 /* Matched data */
1176 int32_t offset;
1177 int32_t count;
1179 void **ptrs;
1181 const int16_t *columns;
1182 const ecs_size_t *sizes;
1187 ecs_flags64_t constrained_vars;
1188 ecs_termset_t set_fields;
1189 ecs_termset_t ref_fields;
1190 ecs_termset_t row_fields;
1191 ecs_termset_t up_fields;
1193 /* Input information */
1197 int32_t event_cur;
1199 /* Query information */
1201 int8_t term_index;
1206 /* Context */
1207 void *param;
1208 void *ctx;
1211 void *run_ctx;
1213 /* Time */
1217 /* Iterator counters */
1220 /* Misc */
1221 ecs_flags32_t flags;
1223 ecs_iter_private_t priv_;
1225 /* Chained iterators */
1230};
1231
1232
1237#define EcsQueryMatchPrefab (1u << 1u)
1238
1243#define EcsQueryMatchDisabled (1u << 2u)
1244
1249#define EcsQueryMatchEmptyTables (1u << 3u)
1250
1255#define EcsQueryAllowUnresolvedByName (1u << 6u)
1256
1261#define EcsQueryTableOnly (1u << 7u)
1262
1273#define EcsQueryDetectChanges (1u << 8u)
1274
1283#define EcsQueryGroupByOrdered (1u << 9u)
1284
1294#define EcsQueryGroupByDesc (1u << 10u)
1295
1296
1370
1431
1436typedef struct ecs_event_desc_t {
1439
1444
1447
1451
1453 int32_t offset;
1454
1458 int32_t count;
1459
1462
1467 void *param;
1468
1472 const void *const_param;
1473
1476
1478 ecs_flags32_t flags;
1480
1481
1490typedef struct ecs_build_info_t {
1491 const char *compiler;
1492 const char **addons;
1493 const char **flags;
1494 const char *version;
1498 bool debug;
1502
1562
1570
1574typedef struct ecs_entity_range_t {
1575 uint32_t min;
1576 uint32_t max;
1577 uint32_t cur;
1578 ecs_vec_t recycled;
1580
1591typedef struct EcsIdentifier {
1592 char *value;
1593 ecs_size_t length;
1594 uint64_t hash;
1595 uint64_t index_hash;
1596 ecs_hashmap_t *index;
1598
1600typedef struct EcsComponent {
1601 ecs_size_t size;
1602 ecs_size_t alignment;
1604
1609
1618
1623
1625typedef struct {
1626 const char *child_name;
1628 uint32_t child;
1631
1633typedef struct {
1634 ecs_vec_t children;
1636
1647
1651/* Only include deprecated definitions if deprecated addon is required */
1652#ifdef FLECS_DEPRECATED
1654#endif
1655
1671FLECS_API extern const ecs_id_t ECS_PAIR;
1672
1674FLECS_API extern const ecs_id_t ECS_AUTO_OVERRIDE;
1675
1677FLECS_API extern const ecs_id_t ECS_TOGGLE;
1678
1680FLECS_API extern const ecs_id_t ECS_VALUE_PAIR;
1681
1689/* Built-in component IDs */
1690
1692FLECS_API extern const ecs_entity_t ecs_id(EcsComponent);
1693
1695FLECS_API extern const ecs_entity_t ecs_id(EcsIdentifier);
1696
1698FLECS_API extern const ecs_entity_t ecs_id(EcsPoly);
1699
1701FLECS_API extern const ecs_entity_t ecs_id(EcsParent);
1702
1704FLECS_API extern const ecs_entity_t ecs_id(EcsTreeSpawner);
1705
1707FLECS_API extern const ecs_entity_t ecs_id(EcsDefaultChildComponent);
1708
1710FLECS_API extern const ecs_entity_t EcsParentDepth;
1711
1713FLECS_API extern const ecs_entity_t EcsQuery;
1714
1716FLECS_API extern const ecs_entity_t EcsObserver;
1717
1719FLECS_API extern const ecs_entity_t EcsSystem;
1720
1722FLECS_API extern const ecs_entity_t ecs_id(EcsTickSource);
1723
1725FLECS_API extern const ecs_entity_t ecs_id(EcsPipelineQuery);
1726
1728FLECS_API extern const ecs_entity_t ecs_id(EcsTimer);
1729
1731FLECS_API extern const ecs_entity_t ecs_id(EcsRateFilter);
1732
1734FLECS_API extern const ecs_entity_t EcsFlecs;
1735
1737FLECS_API extern const ecs_entity_t EcsFlecsCore;
1738
1740FLECS_API extern const ecs_entity_t EcsWorld;
1741
1743FLECS_API extern const ecs_entity_t EcsWildcard;
1744
1746FLECS_API extern const ecs_entity_t EcsAny;
1747
1749FLECS_API extern const ecs_entity_t EcsThis;
1750
1752FLECS_API extern const ecs_entity_t EcsVariable;
1753
1761FLECS_API extern const ecs_entity_t EcsTransitive;
1762
1770FLECS_API extern const ecs_entity_t EcsReflexive;
1771
1782FLECS_API extern const ecs_entity_t EcsFinal;
1783
1789FLECS_API extern const ecs_entity_t EcsInheritable;
1790
1792FLECS_API extern const ecs_entity_t EcsOnInstantiate;
1793
1797FLECS_API extern const ecs_entity_t EcsOverride;
1798
1802FLECS_API extern const ecs_entity_t EcsInherit;
1803
1808FLECS_API extern const ecs_entity_t EcsDontInherit;
1809
1817FLECS_API extern const ecs_entity_t EcsSymmetric;
1818
1828FLECS_API extern const ecs_entity_t EcsExclusive;
1829
1831FLECS_API extern const ecs_entity_t EcsAcyclic;
1832
1835FLECS_API extern const ecs_entity_t EcsTraversable;
1836
1846FLECS_API extern const ecs_entity_t EcsWith;
1847
1857FLECS_API extern const ecs_entity_t EcsOneOf;
1858
1860FLECS_API extern const ecs_entity_t EcsCanToggle;
1861
1865FLECS_API extern const ecs_entity_t EcsTrait;
1866
1876FLECS_API extern const ecs_entity_t EcsRelationship;
1877
1887FLECS_API extern const ecs_entity_t EcsTarget;
1888
1891FLECS_API extern const ecs_entity_t EcsPairIsTag;
1892
1894FLECS_API extern const ecs_entity_t EcsName;
1895
1897FLECS_API extern const ecs_entity_t EcsSymbol;
1898
1900FLECS_API extern const ecs_entity_t EcsAlias;
1901
1903FLECS_API extern const ecs_entity_t EcsChildOf;
1904
1906FLECS_API extern const ecs_entity_t EcsIsA;
1907
1909FLECS_API extern const ecs_entity_t EcsDependsOn;
1910
1912FLECS_API extern const ecs_entity_t EcsSlotOf;
1913
1915FLECS_API extern const ecs_entity_t EcsOrderedChildren;
1916
1918FLECS_API extern const ecs_entity_t EcsModule;
1919
1922FLECS_API extern const ecs_entity_t EcsPrefab;
1923
1926FLECS_API extern const ecs_entity_t EcsDisabled;
1927
1931FLECS_API extern const ecs_entity_t EcsNotQueryable;
1932
1934FLECS_API extern const ecs_entity_t EcsOnAdd;
1935
1937FLECS_API extern const ecs_entity_t EcsOnRemove;
1938
1940FLECS_API extern const ecs_entity_t EcsOnSet;
1941
1943FLECS_API extern const ecs_entity_t EcsMonitor;
1944
1946FLECS_API extern const ecs_entity_t EcsOnTableCreate;
1947
1949FLECS_API extern const ecs_entity_t EcsOnTableDelete;
1950
1952FLECS_API extern const ecs_entity_t EcsOnDelete;
1953
1956FLECS_API extern const ecs_entity_t EcsOnDeleteTarget;
1957
1960FLECS_API extern const ecs_entity_t EcsRemove;
1961
1964FLECS_API extern const ecs_entity_t EcsDelete;
1965
1968FLECS_API extern const ecs_entity_t EcsPanic;
1969
1972FLECS_API extern const ecs_entity_t EcsSingleton;
1973
1975FLECS_API extern const ecs_entity_t EcsSparse;
1976
1978FLECS_API extern const ecs_entity_t EcsDontFragment;
1979
1981FLECS_API extern const ecs_entity_t EcsPredEq;
1982
1984FLECS_API extern const ecs_entity_t EcsPredMatch;
1985
1987FLECS_API extern const ecs_entity_t EcsPredLookup;
1988
1990FLECS_API extern const ecs_entity_t EcsScopeOpen;
1991
1993FLECS_API extern const ecs_entity_t EcsScopeClose;
1994
1999FLECS_API extern const ecs_entity_t EcsEmpty;
2000
2001FLECS_API extern const ecs_entity_t ecs_id(EcsPipeline);
2002FLECS_API extern const ecs_entity_t EcsOnStart;
2003FLECS_API extern const ecs_entity_t EcsPreFrame;
2004FLECS_API extern const ecs_entity_t EcsOnLoad;
2005FLECS_API extern const ecs_entity_t EcsPostLoad;
2006FLECS_API extern const ecs_entity_t EcsPreUpdate;
2007FLECS_API extern const ecs_entity_t EcsOnUpdate;
2008FLECS_API extern const ecs_entity_t EcsOnValidate;
2009FLECS_API extern const ecs_entity_t EcsPostUpdate;
2010FLECS_API extern const ecs_entity_t EcsPreStore;
2011FLECS_API extern const ecs_entity_t EcsOnStore;
2012FLECS_API extern const ecs_entity_t EcsPostFrame;
2013FLECS_API extern const ecs_entity_t EcsPhase;
2015FLECS_API extern const ecs_entity_t EcsConstant;
2019#define EcsLastInternalComponentId (ecs_id(EcsTreeSpawner))
2020
2023#define EcsFirstUserComponentId (8)
2024
2027#define EcsFirstUserEntityId (FLECS_HI_COMPONENT_ID + 128)
2028
2029/* When visualized, the reserved ID ranges look like this:
2030 * - [1..8]: Built-in components
2031 * - [9..FLECS_HI_COMPONENT_ID]: Low IDs reserved for application components
2032 * - [FLECS_HI_COMPONENT_ID + 1..EcsFirstUserEntityId]: Built-in entities
2033 */
2034
2056FLECS_API
2058
2065FLECS_API
2067
2077FLECS_API
2079 int argc,
2080 char *argv[]);
2081
2088FLECS_API
2090 ecs_world_t *world);
2091
2099FLECS_API
2101 const ecs_world_t *world);
2102
2111FLECS_API
2113 ecs_world_t *world,
2114 ecs_fini_action_t action,
2115 void *ctx);
2116
2123
2150FLECS_API
2152 const ecs_world_t *world);
2153
2161FLECS_API
2163 const ecs_world_t *world);
2164
2190FLECS_API
2192 ecs_world_t *world,
2193 ecs_ftime_t delta_time);
2194
2201FLECS_API
2203 ecs_world_t *world);
2204
2213FLECS_API
2215 ecs_world_t *world,
2216 ecs_fini_action_t action,
2217 void *ctx);
2218
2225FLECS_API
2227 ecs_world_t *world);
2228
2235FLECS_API
2237 const ecs_world_t *world);
2238
2251 ecs_world_t *world,
2252 bool enable);
2253
2265 ecs_world_t *world,
2266 bool enable);
2267
2283FLECS_API
2285 ecs_world_t *world,
2286 ecs_ftime_t fps);
2287
2301FLECS_API
2303 ecs_world_t *world,
2304 ecs_flags32_t flags);
2305
2382FLECS_API
2384 ecs_world_t *world,
2385 bool multi_threaded);
2386
2394FLECS_API
2396 ecs_world_t *world);
2397
2403FLECS_API
2405 ecs_world_t *stage);
2406
2423FLECS_API
2425 ecs_world_t *world);
2426
2440FLECS_API
2442 ecs_world_t *world);
2443
2458FLECS_API
2460 ecs_world_t *world);
2461
2472FLECS_API
2474 ecs_world_t *world);
2475
2487FLECS_API
2489 const ecs_world_t *world);
2490
2502FLECS_API
2504 const ecs_world_t *world);
2505
2519FLECS_API
2521 ecs_world_t *world,
2522 int32_t stages);
2523
2530FLECS_API
2532 const ecs_world_t *world);
2533
2549FLECS_API
2551 const ecs_world_t *world,
2552 int32_t stage_id);
2553
2561FLECS_API
2563 const ecs_world_t *world);
2564
2572FLECS_API
2574 ecs_world_t *world);
2575
2580FLECS_API
2582 ecs_world_t *stage);
2583
2591FLECS_API
2593 const ecs_world_t *world);
2594
2610FLECS_API
2612 ecs_world_t *world,
2613 void *ctx,
2614 ecs_ctx_free_t ctx_free);
2615
2624FLECS_API
2626 ecs_world_t *world,
2627 void *ctx,
2628 ecs_ctx_free_t ctx_free);
2629
2637FLECS_API
2639 const ecs_world_t *world);
2640
2648FLECS_API
2650 const ecs_world_t *world);
2651
2657FLECS_API
2659
2665FLECS_API
2667 const ecs_world_t *world);
2668
2677FLECS_API
2679 ecs_world_t *world,
2680 int32_t entity_count);
2681
2696FLECS_API
2698 ecs_world_t *world);
2699
2714FLECS_API
2716 ecs_world_t *world,
2717 uint32_t min,
2718 uint32_t max);
2719
2734FLECS_API
2736 ecs_world_t *world,
2737 const ecs_entity_range_t *range);
2738
2746FLECS_API
2748 const ecs_world_t *world);
2749
2755FLECS_API
2757 const ecs_world_t *world);
2758
2772FLECS_API
2774 ecs_world_t *world,
2775 ecs_flags32_t flags);
2776
2792
2828FLECS_API
2830 ecs_world_t *world,
2831 const ecs_delete_empty_tables_desc_t *desc);
2832
2838FLECS_API
2840 const ecs_poly_t *poly);
2841
2847FLECS_API
2849 const ecs_poly_t *poly);
2850
2864FLECS_API
2866 const ecs_poly_t *object,
2867 int32_t type);
2868
2872#define flecs_poly_is(object, type)\
2873 flecs_poly_is_(object, type##_magic)
2874
2883FLECS_API
2885 ecs_entity_t first,
2886 ecs_entity_t second);
2887
2910FLECS_API
2912 ecs_world_t *world,
2913 const char *thread_name);
2914
2937FLECS_API
2939 ecs_world_t *world,
2940 bool lock_world);
2941
2968FLECS_API
2970 ecs_world_t *world);
2971
2989FLECS_API
2991 ecs_world_t *world);
2992
3001FLECS_API
3003 ecs_world_t *world,
3004 ecs_id_t component);
3005
3013FLECS_API
3015 ecs_world_t *world,
3016 ecs_table_t *table);
3017
3036FLECS_API
3038 ecs_world_t *world,
3039 const ecs_entity_desc_t *desc);
3040
3067FLECS_API
3069 ecs_world_t *world,
3070 const ecs_bulk_desc_t *desc);
3071
3081FLECS_API
3083 ecs_world_t *world,
3084 ecs_id_t component,
3085 int32_t count);
3086
3102FLECS_API
3104 ecs_world_t *world,
3105 ecs_entity_t dst,
3106 ecs_entity_t src,
3107 bool copy_value);
3108
3117FLECS_API
3119 ecs_world_t *world,
3120 ecs_entity_t entity);
3121
3129FLECS_API
3131 ecs_world_t *world,
3132 ecs_id_t component);
3133
3151FLECS_API
3153 ecs_world_t *world,
3154 ecs_entity_t parent,
3155 const ecs_entity_t *children,
3156 int32_t child_count);
3157
3167FLECS_API
3169 const ecs_world_t *world,
3170 ecs_entity_t parent);
3171
3189FLECS_API
3191 ecs_world_t *world,
3192 ecs_entity_t entity,
3193 ecs_id_t component);
3194
3203FLECS_API
3205 ecs_world_t *world,
3206 ecs_entity_t entity,
3207 ecs_id_t component);
3208
3260FLECS_API
3262 ecs_world_t *world,
3263 ecs_entity_t entity,
3264 ecs_id_t component);
3265
3272FLECS_API
3274 ecs_world_t *world,
3275 ecs_entity_t entity);
3276
3284FLECS_API
3286 ecs_world_t *world,
3287 ecs_id_t component);
3288
3304FLECS_API
3306 ecs_world_t *world,
3307 ecs_id_t component);
3308
3317FLECS_API
3319 const ecs_world_t *world);
3320
3339FLECS_API
3341 ecs_world_t *world,
3342 ecs_entity_t entity,
3343 bool enabled);
3344
3358FLECS_API
3360 ecs_world_t *world,
3361 ecs_entity_t entity,
3362 ecs_id_t component,
3363 bool enable);
3364
3375FLECS_API
3377 const ecs_world_t *world,
3378 ecs_entity_t entity,
3379 ecs_id_t component);
3380
3404FLECS_API
3405FLECS_ALWAYS_INLINE const void* ecs_get_id(
3406 const ecs_world_t *world,
3407 ecs_entity_t entity,
3408 ecs_id_t component);
3409
3424FLECS_API
3425FLECS_ALWAYS_INLINE void* ecs_get_mut_id(
3426 const ecs_world_t *world,
3427 ecs_entity_t entity,
3428 ecs_id_t component);
3429
3447FLECS_API
3449 ecs_world_t *world,
3450 ecs_entity_t entity,
3451 ecs_id_t component,
3452 size_t size);
3453
3464FLECS_ALWAYS_INLINE FLECS_API
3466 const ecs_world_t *world,
3467 ecs_entity_t entity,
3468 ecs_id_t component);
3469
3480FLECS_ALWAYS_INLINE FLECS_API
3482 const ecs_world_t *world,
3483 ecs_ref_t *ref,
3484 ecs_id_t component);
3485
3494FLECS_ALWAYS_INLINE FLECS_API
3496 const ecs_world_t *world,
3497 ecs_ref_t *ref,
3498 ecs_id_t component);
3499
3520FLECS_API
3522 ecs_world_t *world,
3523 ecs_entity_t entity,
3524 ecs_id_t component,
3525 size_t size,
3526 bool *is_new);
3527
3537FLECS_API
3539 ecs_world_t *world,
3540 ecs_entity_t entity,
3541 ecs_id_t component);
3542
3558FLECS_API
3560 ecs_world_t *world,
3561 ecs_entity_t entity,
3562 ecs_id_t component,
3563 size_t size,
3564 const void *ptr);
3565
3594FLECS_API
3596 const ecs_world_t *world,
3597 ecs_entity_t e);
3598
3628FLECS_API
3630 const ecs_world_t *world,
3631 ecs_entity_t e);
3632
3638FLECS_API
3640 ecs_entity_t e);
3641
3658FLECS_API
3660 const ecs_world_t *world,
3661 ecs_entity_t e);
3662
3685FLECS_API
3687 ecs_world_t *world,
3688 ecs_entity_t entity);
3689
3708FLECS_API
3710 ecs_world_t *world,
3711 ecs_id_t component);
3712
3720FLECS_API
3722 const ecs_world_t *world,
3723 ecs_entity_t entity);
3724
3739FLECS_API
3741 ecs_world_t *world,
3742 ecs_entity_t entity);
3743
3749FLECS_API
3751 ecs_entity_t entity);
3752
3768FLECS_API
3770 const ecs_world_t *world,
3771 ecs_entity_t entity);
3772
3779FLECS_API
3781 const ecs_world_t *world,
3782 ecs_entity_t entity);
3783
3791FLECS_API
3793 const ecs_world_t *world,
3794 const ecs_type_t* type);
3795
3807FLECS_API
3809 const ecs_world_t *world,
3810 const ecs_table_t *table);
3811
3826FLECS_API
3828 const ecs_world_t *world,
3829 ecs_entity_t entity);
3830
3841FLECS_API
3842FLECS_ALWAYS_INLINE bool ecs_has_id(
3843 const ecs_world_t *world,
3844 ecs_entity_t entity,
3845 ecs_id_t component);
3846
3857FLECS_API
3858FLECS_ALWAYS_INLINE bool ecs_owns_id(
3859 const ecs_world_t *world,
3860 ecs_entity_t entity,
3861 ecs_id_t component);
3862
3877FLECS_API
3879 const ecs_world_t *world,
3880 ecs_entity_t entity,
3881 ecs_entity_t rel,
3882 int32_t index);
3883
3897FLECS_API
3899 const ecs_world_t *world,
3900 ecs_entity_t entity);
3901
3915FLECS_API
3917 ecs_world_t *world,
3918 ecs_entity_t parent,
3919 const char *name);
3920
3941FLECS_API
3943 const ecs_world_t *world,
3944 ecs_entity_t entity,
3945 ecs_entity_t rel,
3946 ecs_id_t component);
3947
3958FLECS_API
3960 const ecs_world_t *world,
3961 ecs_entity_t entity,
3962 ecs_entity_t rel);
3963
3971FLECS_API
3973 const ecs_world_t *world,
3974 ecs_id_t entity);
3975
3995FLECS_API
3996const char* ecs_get_name(
3997 const ecs_world_t *world,
3998 ecs_entity_t entity);
3999
4009FLECS_API
4010const char* ecs_get_symbol(
4011 const ecs_world_t *world,
4012 ecs_entity_t entity);
4013
4027FLECS_API
4029 ecs_world_t *world,
4030 ecs_entity_t entity,
4031 const char *name);
4032
4046FLECS_API
4048 ecs_world_t *world,
4049 ecs_entity_t entity,
4050 const char *symbol);
4051
4063FLECS_API
4065 ecs_world_t *world,
4066 ecs_entity_t entity,
4067 const char *alias);
4068
4084FLECS_API
4086 const ecs_world_t *world,
4087 const char *path);
4088
4103FLECS_API
4105 const ecs_world_t *world,
4106 ecs_entity_t parent,
4107 const char *name);
4108
4131FLECS_API
4133 const ecs_world_t *world,
4134 ecs_entity_t parent,
4135 const char *path,
4136 const char *sep,
4137 const char *prefix,
4138 bool recursive);
4139
4157FLECS_API
4159 const ecs_world_t *world,
4160 const char *symbol,
4161 bool lookup_as_path,
4162 bool recursive);
4163
4185FLECS_API
4187 const ecs_world_t *world,
4188 ecs_entity_t parent,
4189 ecs_entity_t child,
4190 const char *sep,
4191 const char *prefix);
4192
4206FLECS_API
4208 const ecs_world_t *world,
4209 ecs_entity_t parent,
4210 ecs_entity_t child,
4211 const char *sep,
4212 const char *prefix,
4213 ecs_strbuf_t *buf,
4214 bool escape);
4215
4231FLECS_API
4233 ecs_world_t *world,
4234 ecs_entity_t parent,
4235 const char *path,
4236 const char *sep,
4237 const char *prefix);
4238
4253FLECS_API
4255 ecs_world_t *world,
4256 ecs_entity_t entity,
4257 ecs_entity_t parent,
4258 const char *path,
4259 const char *sep,
4260 const char *prefix);
4261
4275FLECS_API
4277 ecs_world_t *world,
4278 ecs_entity_t scope);
4279
4287FLECS_API
4289 const ecs_world_t *world);
4290
4300FLECS_API
4302 ecs_world_t *world,
4303 const char *prefix);
4304
4331FLECS_API
4333 ecs_world_t *world,
4334 const ecs_entity_t *lookup_path);
4335
4342FLECS_API
4344 const ecs_world_t *world);
4345
4370FLECS_API
4372 ecs_world_t *world,
4373 const ecs_component_desc_t *desc);
4374
4384FLECS_API
4386 const ecs_world_t *world,
4387 ecs_id_t component);
4388
4400FLECS_API
4402 ecs_world_t *world,
4403 ecs_entity_t component,
4404 const ecs_type_hooks_t *hooks);
4405
4412FLECS_API
4414 const ecs_world_t *world,
4415 ecs_entity_t component);
4416
4440FLECS_API
4442 const ecs_world_t *world,
4443 ecs_id_t component);
4444
4453FLECS_API
4455 const ecs_world_t *world,
4456 ecs_id_t component);
4457
4477FLECS_API
4479 const ecs_world_t *world,
4480 ecs_id_t component);
4481
4490FLECS_API
4492 ecs_id_t component,
4493 ecs_id_t pattern);
4494
4500FLECS_API
4502 ecs_id_t component);
4503
4509FLECS_API
4511 ecs_id_t component);
4512
4519 ecs_id_t component);
4520
4534FLECS_API
4536 const ecs_world_t *world,
4537 ecs_id_t component);
4538
4547FLECS_API
4548ecs_flags32_t ecs_id_get_flags(
4549 const ecs_world_t *world,
4550 ecs_id_t component);
4551
4562FLECS_API
4564 uint64_t component_flags);
4565
4581FLECS_API
4583 const ecs_world_t *world,
4584 ecs_id_t component);
4585
4593FLECS_API
4595 const ecs_world_t *world,
4596 ecs_id_t component,
4597 ecs_strbuf_t *buf);
4598
4607FLECS_API
4609 const ecs_world_t *world,
4610 const char *expr);
4611
4627FLECS_API
4629 const ecs_term_ref_t *ref);
4630
4642FLECS_API
4644 const ecs_term_t *term);
4645
4660FLECS_API
4662 const ecs_term_t *term);
4663
4676FLECS_API
4678 const ecs_term_t *term);
4679
4688FLECS_API
4690 const ecs_world_t *world,
4691 const ecs_term_t *term);
4692
4700FLECS_API
4702 const ecs_query_t *query);
4703
4744FLECS_API
4746 const ecs_world_t *world,
4747 ecs_id_t component);
4748
4754FLECS_API
4756 ecs_iter_t *it);
4757
4780FLECS_API
4781FLECS_ALWAYS_INLINE ecs_iter_t ecs_children(
4782 const ecs_world_t *world,
4783 ecs_entity_t parent);
4784
4792FLECS_API
4793FLECS_ALWAYS_INLINE ecs_iter_t ecs_children_w_rel(
4794 const ecs_world_t *world,
4795 ecs_entity_t relationship,
4796 ecs_entity_t parent);
4797
4803FLECS_API
4805 ecs_iter_t *it);
4806
4825FLECS_API
4827 ecs_world_t *world,
4828 const ecs_query_desc_t *desc);
4829
4840FLECS_API
4842 ecs_world_t *world,
4843 ecs_entity_t entity,
4844 const ecs_query_desc_t *desc);
4845
4850FLECS_API
4852 ecs_query_t *query);
4853
4862FLECS_API
4864 const ecs_query_t *query,
4865 const char *name);
4866
4874FLECS_API
4876 const ecs_query_t *query,
4877 int32_t var_id);
4878
4889FLECS_API
4891 const ecs_query_t *query,
4892 int32_t var_id);
4893
4962FLECS_API
4964 const ecs_world_t *world,
4965 const ecs_query_t *query);
4966
4974FLECS_API
4976 ecs_iter_t *it);
4977
4996FLECS_API
4998 const ecs_query_t *query,
4999 ecs_entity_t entity,
5000 ecs_iter_t *it);
5001
5020FLECS_API
5022 const ecs_query_t *query,
5023 ecs_table_t *table,
5024 ecs_iter_t *it);
5025
5052FLECS_API
5054 const ecs_query_t *query,
5055 ecs_table_range_t *range,
5056 ecs_iter_t *it);
5057
5065FLECS_API
5067 const ecs_query_t *query);
5068
5078FLECS_API
5080 const ecs_query_t *query);
5081
5096FLECS_API
5098 const ecs_query_t *query,
5099 const ecs_iter_t *it);
5100
5106FLECS_API
5108 const ecs_query_t *query);
5109
5127FLECS_API
5129 ecs_query_t *query,
5130 ecs_iter_t *it,
5131 const char *expr);
5132
5155FLECS_API
5157 ecs_query_t *query);
5158
5167FLECS_API
5169 const ecs_world_t *world,
5170 ecs_entity_t query);
5171
5182FLECS_API
5184 ecs_iter_t *it);
5185
5208FLECS_API
5210 ecs_iter_t *it,
5211 uint64_t group_id);
5212
5238FLECS_API
5239const ecs_map_t* ecs_query_get_groups(
5240 const ecs_query_t *query);
5241
5250FLECS_API
5252 const ecs_query_t *query,
5253 uint64_t group_id);
5254
5263FLECS_API
5265 const ecs_query_t *query,
5266 uint64_t group_id);
5267
5276
5283FLECS_API
5285 const ecs_query_t *query);
5286
5292FLECS_API
5294 const ecs_query_t *query);
5295
5304FLECS_API
5306 const ecs_query_t *query);
5307
5336FLECS_API
5338 ecs_world_t *world,
5339 ecs_event_desc_t *desc);
5340
5351FLECS_API
5353 ecs_world_t *world,
5354 ecs_event_desc_t *desc);
5355
5370FLECS_API
5372 ecs_world_t *world,
5373 const ecs_observer_desc_t *desc);
5374
5390FLECS_API
5392 ecs_world_t *world,
5393 ecs_entity_t observer,
5394 const ecs_observer_desc_t *desc);
5395
5404FLECS_API
5406 const ecs_world_t *world,
5407 ecs_entity_t observer);
5408
5431FLECS_API
5433 ecs_iter_t *it);
5434
5444FLECS_API
5446 ecs_iter_t *it);
5447
5459FLECS_API
5461 ecs_iter_t *it);
5462
5475FLECS_API
5477 ecs_iter_t *it);
5478
5486FLECS_API
5488 ecs_iter_t *it);
5489
5528FLECS_API
5530 ecs_iter_t *it,
5531 int32_t var_id,
5532 ecs_entity_t entity);
5533
5544FLECS_API
5546 ecs_iter_t *it,
5547 int32_t var_id,
5548 const ecs_table_t *table);
5549
5560FLECS_API
5562 ecs_iter_t *it,
5563 int32_t var_id,
5564 const ecs_table_range_t *range);
5565
5578FLECS_API
5580 ecs_iter_t *it,
5581 int32_t var_id);
5582
5589FLECS_API
5591 const ecs_iter_t *it,
5592 int32_t var_id);
5593
5599FLECS_API
5601 const ecs_iter_t *it);
5602
5608FLECS_API
5610 const ecs_iter_t *it);
5611
5625FLECS_API
5627 ecs_iter_t *it,
5628 int32_t var_id);
5629
5643FLECS_API
5645 ecs_iter_t *it,
5646 int32_t var_id);
5647
5659FLECS_API
5661 ecs_iter_t *it,
5662 int32_t var_id);
5663
5675FLECS_API
5677 const ecs_iter_t *it);
5678
5690FLECS_API
5692 ecs_iter_t *it);
5693
5705FLECS_API
5707 const ecs_iter_t *it);
5708
5724FLECS_API
5726 const ecs_iter_t *it,
5727 int32_t offset,
5728 int32_t limit);
5729
5736FLECS_API
5738 ecs_iter_t *it);
5739
5760FLECS_API
5762 const ecs_iter_t *it,
5763 int32_t index,
5764 int32_t count);
5765
5772FLECS_API
5774 ecs_iter_t *it);
5775
5817FLECS_API
5819 const ecs_iter_t *it,
5820 size_t size,
5821 int8_t index);
5822
5845FLECS_API
5847 const ecs_iter_t *it,
5848 size_t size,
5849 int8_t index,
5850 int32_t row);
5851
5860FLECS_API
5862 const ecs_iter_t *it,
5863 int8_t index);
5864
5875FLECS_API
5877 const ecs_iter_t *it,
5878 int8_t index);
5879
5886FLECS_API
5888 const ecs_iter_t *it,
5889 int8_t index);
5890
5897FLECS_API
5899 const ecs_iter_t *it,
5900 int8_t index);
5901
5910FLECS_API
5912 const ecs_iter_t *it,
5913 int8_t index);
5914
5922FLECS_API
5924 const ecs_iter_t *it,
5925 int8_t index);
5926
5934FLECS_API
5936 const ecs_iter_t *it,
5937 int8_t index);
5938
5952FLECS_API
5954 const ecs_iter_t *it,
5955 int8_t index);
5956
5972FLECS_API
5974 const ecs_table_t *table);
5975
5986FLECS_API
5988 const ecs_world_t *world,
5989 const ecs_table_t *table,
5990 ecs_id_t component);
5991
6001FLECS_API
6003 const ecs_world_t *world,
6004 const ecs_table_t *table,
6005 ecs_id_t component);
6006
6014FLECS_API
6016 const ecs_table_t *table);
6017
6031FLECS_API
6033 const ecs_table_t *table,
6034 int32_t index);
6035
6044FLECS_API
6046 const ecs_table_t *table,
6047 int32_t index);
6048
6057FLECS_API
6059 const ecs_table_t *table,
6060 int32_t index,
6061 int32_t offset);
6062
6072FLECS_API
6074 const ecs_world_t *world,
6075 const ecs_table_t *table,
6076 ecs_id_t component,
6077 int32_t offset);
6078
6086FLECS_API
6088 const ecs_table_t *table,
6089 int32_t index);
6090
6097FLECS_API
6099 const ecs_table_t *table);
6100
6108FLECS_API
6110 const ecs_table_t *table);
6111
6118FLECS_API
6120 const ecs_table_t *table);
6121
6132FLECS_API
6134 const ecs_world_t *world,
6135 const ecs_table_t *table,
6136 ecs_id_t component);
6137
6148FLECS_API
6150 const ecs_world_t *world,
6151 const ecs_table_t *table,
6152 ecs_entity_t relationship,
6153 int32_t index);
6154
6165FLECS_API
6167 const ecs_world_t *world,
6168 const ecs_table_t *table,
6169 ecs_entity_t rel);
6170
6180FLECS_API
6182 ecs_world_t *world,
6183 ecs_table_t *table,
6184 ecs_id_t component);
6185
6196FLECS_API
6198 ecs_world_t *world,
6199 const ecs_id_t *ids,
6200 int32_t id_count);
6201
6211FLECS_API
6213 ecs_world_t *world,
6214 ecs_table_t *table,
6215 ecs_id_t component);
6216
6232FLECS_API
6234 ecs_world_t *world,
6235 ecs_table_t *table);
6236
6243FLECS_API
6245 ecs_world_t *world,
6246 ecs_table_t *table);
6247
6257FLECS_API
6259 ecs_table_t *table,
6260 ecs_flags32_t flags);
6261
6269FLECS_API
6271 const ecs_table_t *table);
6272
6282FLECS_API
6284 ecs_world_t* world,
6285 ecs_table_t* table,
6286 int32_t row_1,
6287 int32_t row_2);
6288
6313FLECS_API
6315 ecs_world_t *world,
6316 ecs_entity_t entity,
6317 ecs_record_t *record,
6318 ecs_table_t *table,
6319 const ecs_type_t *added,
6320 const ecs_type_t *removed);
6321
6322
6342FLECS_API
6344 const ecs_world_t *world,
6345 const ecs_table_t *table,
6346 ecs_id_t component,
6347 ecs_id_t *component_out);
6348
6384FLECS_API
6386 const ecs_world_t *world,
6387 const ecs_table_t *table,
6388 int32_t offset,
6389 ecs_id_t component,
6390 ecs_id_t *component_out);
6391
6432FLECS_API
6434 const ecs_world_t *world,
6435 const ecs_table_t *table,
6436 int32_t offset,
6437 ecs_id_t component,
6438 ecs_entity_t rel,
6439 ecs_flags64_t flags, /* EcsSelf and/or EcsUp */
6440 ecs_entity_t *tgt_out,
6441 ecs_id_t *component_out,
6442 struct ecs_table_record_t **tr_out);
6443
6459FLECS_API
6461 const ecs_world_t *world,
6462 ecs_entity_t entity,
6463 ecs_id_t id,
6464 ecs_entity_t rel,
6465 bool self,
6467 ecs_entity_t *tgt_out,
6468 ecs_id_t *id_out,
6469 struct ecs_table_record_t **tr_out);
6470
6478FLECS_API
6480 ecs_world_t* world,
6481 ecs_table_t* table);
6482
6499FLECS_API
6501 const ecs_world_t *world,
6502 ecs_entity_t type,
6503 void *ptr);
6504
6512FLECS_API
6514 const ecs_world_t *world,
6515 const ecs_type_info_t *ti,
6516 void *ptr);
6517
6524FLECS_API
6526 ecs_world_t *world,
6527 ecs_entity_t type);
6528
6536 ecs_world_t *world,
6537 const ecs_type_info_t *ti);
6538
6547 const ecs_world_t *world,
6548 const ecs_type_info_t *ti,
6549 void *ptr);
6550
6558FLECS_API
6560 const ecs_world_t *world,
6561 ecs_entity_t type,
6562 void* ptr);
6563
6571FLECS_API
6573 ecs_world_t *world,
6574 ecs_entity_t type,
6575 void* ptr);
6576
6585FLECS_API
6587 const ecs_world_t *world,
6588 const ecs_type_info_t *ti,
6589 void* dst,
6590 const void *src);
6591
6600FLECS_API
6602 const ecs_world_t *world,
6603 ecs_entity_t type,
6604 void* dst,
6605 const void *src);
6606
6616 const ecs_world_t *world,
6617 const ecs_type_info_t *ti,
6618 void* dst,
6619 void *src);
6620
6630 const ecs_world_t *world,
6631 ecs_entity_t type,
6632 void* dst,
6633 void *src);
6634
6644 const ecs_world_t *world,
6645 const ecs_type_info_t *ti,
6646 void* dst,
6647 void *src);
6648
6658 const ecs_world_t *world,
6659 ecs_entity_t type,
6660 void* dst,
6661 void *src);
6662
6676#include "flecs/addons/flecs_c.h"
6677
6678#ifdef __cplusplus
6679}
6680#endif
6681
6682#include "flecs/private/addons.h"
6683
6684#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 an auto override for a 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 the 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 a 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 EcsTreeSpawner EcsTreeSpawner
Tree instantiation cache component.
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 as...
struct EcsParent EcsParent
Non-fragmenting ChildOf relationship.
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
Mark a relationship as acyclic.
const ecs_entity_t EcsSymmetric
Mark 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
Mark 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 a query is empty.
const ecs_entity_t EcsOneOf
Ensure that a relationship target is a child of the 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 a pair as a 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() results.
const ecs_entity_t EcsDontFragment
Mark component as non-fragmenting.
const ecs_entity_t EcsTraversable
Mark 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 a 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
Mark 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 an observer when an entity starts or 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 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 a pair as a target.
const ecs_entity_t EcsParentDepth
Relationship storing the entity's depth in a non-fragmenting hierarchy.
const ecs_entity_t EcsWith
Ensure that a component is always 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 built-in 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 queri...
const ecs_entity_t EcsDontInherit
Never inherit component on instantiate.
const ecs_entity_t EcsPairIsTag
Can be added to a relationship to indicate that it should never hold data, even when it or the relati...
const ecs_entity_t EcsPanic
Panic cleanup policy.
const ecs_entity_t EcsFinal
Ensure that an entity or component cannot be used as a target in an IsA relationship.
const ecs_entity_t EcsVariable
Variable entity ("$").
const ecs_entity_t EcsConstant
Tag added to enum or 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 an unmanaged stage.
bool ecs_defer_end(ecs_world_t *world)
End a 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 the end of the 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 the current stage.
void ecs_stage_free(ecs_world_t *stage)
Free an unmanaged stage.
void ecs_merge(ecs_world_t *stage)
Merge a stage.
int32_t ecs_stage_get_id(const ecs_world_t *world)
Get the 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 the 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 the world to have N stages.
void ecs_readonly_end(ecs_world_t *world)
End readonly mode.
bool ecs_is_defer_suspended(const ecs_world_t *world)
Test if deferring is suspended for the current stage.
const ecs_type_hooks_t * ecs_get_hooks_id(const ecs_world_t *world, ecs_entity_t component)
Get hooks for a 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 a 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 a 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:497
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:432
struct ecs_ref_t ecs_ref_t
A ref is a fast way to fetch a component for a specific entity.
Definition flecs.h:481
ecs_id_t ecs_entity_t
An entity identifier.
Definition flecs.h:385
struct ecs_table_record_t ecs_table_record_t
Opaque type for table record.
Definition flecs.h:531
struct ecs_world_t ecs_world_t
A world is the container for all ECS data and supporting features.
Definition flecs.h:429
struct ecs_mixins_t ecs_mixins_t
Type that stores poly mixins.
Definition flecs.h:521
uint64_t ecs_id_t
IDs are the things that can be added to an entity.
Definition flecs.h:378
struct ecs_observable_t ecs_observable_t
An observable produces events that can be listened for by an observer.
Definition flecs.h:465
struct ecs_record_t ecs_record_t
Information about an entity, like its table and row.
Definition flecs.h:494
struct ecs_table_t ecs_table_t
A table stores entities and components for a specific type.
Definition flecs.h:435
void ecs_poly_t
A poly object.
Definition flecs.h:518
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 or 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.
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 a 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 a parent.
ecs_iter_t ecs_children_w_rel(const ecs_world_t *world, ecs_entity_t relationship, ecs_entity_t parent)
Same as ecs_children(), but with a custom relationship argument.
void ecs_enable_id(ecs_world_t *world, ecs_entity_t entity, ecs_id_t component, bool enable)
Enable or disable a component.
bool ecs_is_enabled_id(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t component)
Test if a component is enabled.
void ecs_enable(ecs_world_t *world, ecs_entity_t entity, bool enabled)
Enable or disable an 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 an entity to a 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 the parent (target of the ChildOf relationship) for an 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 a type to a string.
char * ecs_table_str(const ecs_world_t *world, const ecs_table_t *table)
Convert a table to a 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 the depth for an entity in the 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.
ecs_entity_t ecs_new_w_parent(ecs_world_t *world, ecs_entity_t parent, const char *name)
Create child with Parent component.
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:641
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:621
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:683
uint64_t(* ecs_hash_value_action_t)(const void *ptr)
Callback used for hashing values.
Definition flecs.h:659
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:634
void(* ecs_iter_fini_action_t)(ecs_iter_t *it)
Function prototype for freeing an iterator.
Definition flecs.h:599
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:628
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:610
bool(* ecs_iter_next_action_t)(ecs_iter_t *it)
Function prototype for iterating an iterator.
Definition flecs.h:591
void(* ecs_iter_action_t)(ecs_iter_t *it)
Function prototype for iterables.
Definition flecs.h:581
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:669
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:689
int(* ecs_compare_action_t)(const void *ptr1, const void *ptr2)
Callback used for sorting values.
Definition flecs.h:654
void(* ecs_fini_action_t)(ecs_world_t *world, void *ctx)
Action callback on world exit.
Definition flecs.h:645
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:676
void(* flecs_poly_dtor_t)(ecs_poly_t *poly)
Destructor function for poly objects.
Definition flecs.h:695
void(* ecs_run_action_t)(ecs_iter_t *it)
Function prototype for runnables (systems, observers).
Definition flecs.h:572
void(* ecs_ctx_free_t)(void *ctx)
Function to clean up context data.
Definition flecs.h:650
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:603
void(* ecs_xtor_t)(void *ptr, int32_t count, const ecs_type_info_t *type_info)
Constructor/destructor callback.
Definition flecs.h:663
void * ecs_ref_get_id(const ecs_world_t *world, ecs_ref_t *ref, ecs_id_t component)
Get a component from a 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, ecs_id_t component)
Update a 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 an entity has a component and return a 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
Indicate 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
Add a bitset to storage, which allows a component to be enabled or disabled.
const ecs_id_t ECS_VALUE_PAIR
Indicate that the target of a pair is an integer value.
char * ecs_id_str(const ecs_world_t *world, ecs_id_t component)
Convert a component ID to a string.
bool ecs_id_is_tag(const ecs_world_t *world, ecs_id_t component)
Return whether a 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 an ID.
bool ecs_id_is_valid(const ecs_world_t *world, ecs_id_t component)
Utility to check if an ID is valid.
const char * ecs_id_flag_str(uint64_t component_flags)
Convert a component flag to a string.
bool ecs_id_in_use(const ecs_world_t *world, ecs_id_t component)
Return whether a 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 a component string to a buffer.
bool ecs_id_is_pair(ecs_id_t component)
Utility to check if a 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 a string to a component.
bool ecs_id_is_wildcard(ecs_id_t component)
Utility to check if a component is a wildcard.
bool ecs_id_is_any(ecs_id_t component)
Utility to check if a component is an any wildcard.
ecs_entity_t ecs_field_src(const ecs_iter_t *it, int8_t index)
Return the field source.
bool ecs_iter_changed(ecs_iter_t *it)
Return whether the current iterator result has changed.
bool ecs_field_is_writeonly(const ecs_iter_t *it, int8_t index)
Test whether the field is write-only.
ecs_var_t * ecs_iter_get_vars(const ecs_iter_t *it)
Get the variable array.
bool ecs_field_is_readonly(const ecs_iter_t *it, int8_t index)
Test whether the field is read-only.
const char * ecs_iter_get_var_name(const ecs_iter_t *it, int32_t var_id)
Get the 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 an iterator is true.
void ecs_iter_fini(ecs_iter_t *it)
Clean up iterator resources.
char * ecs_iter_str(const ecs_iter_t *it)
Convert an iterator to a string.
bool ecs_iter_var_is_constrained(ecs_iter_t *it, int32_t var_id)
Return whether a 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 the 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 a field at a specified row.
ecs_id_t ecs_field_id(const ecs_iter_t *it, int8_t index)
Return the ID matched for a field.
bool ecs_field_is_set(const ecs_iter_t *it, int8_t index)
Test whether a field is set.
void ecs_iter_set_var(ecs_iter_t *it, int32_t var_id, ecs_entity_t entity)
Set the value for an 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 the value of an iterator variable as an entity.
bool ecs_worker_next(ecs_iter_t *it)
Progress a worker iterator.
ecs_entity_t ecs_iter_first(ecs_iter_t *it)
Get the first matching entity from an iterator.
int32_t ecs_field_column(const ecs_iter_t *it, int8_t index)
Return the index of a 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 the value of an iterator variable as a table.
void * ecs_field_w_size(const ecs_iter_t *it, size_t size, int8_t index)
Get data for a field.
int32_t ecs_iter_count(ecs_iter_t *it)
Count the number of matched entities in a 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.
size_t ecs_field_size(const ecs_iter_t *it, int8_t index)
Return the field type size.
ecs_table_range_t ecs_iter_get_var_as_range(ecs_iter_t *it, int32_t var_id)
Get the value of an iterator variable as a table range.
ecs_id_t ecs_strip_generation(ecs_entity_t e)
Remove the generation from an 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 an ID is alive.
ecs_entity_t ecs_get_alive(const ecs_world_t *world, ecs_entity_t e)
Get an alive identifier.
uint32_t ecs_get_version(ecs_entity_t entity)
Get the generation of an entity.
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_entity_range_t ecs_entity_range_t
Type that stores an entity id range.
struct ecs_build_info_t ecs_build_info_t
Type with information about the current Flecs build.
ecs_entity_t ecs_observer_update(ecs_world_t *world, ecs_entity_t observer, const ecs_observer_desc_t *desc)
Update an existing observer.
void ecs_emit(ecs_world_t *world, ecs_event_desc_t *desc)
Send an event.
void ecs_enqueue(ecs_world_t *world, ecs_event_desc_t *desc)
Enqueue an event.
ecs_entity_t ecs_observer_init(ecs_world_t *world, const ecs_observer_desc_t *desc)
Create an observer.
const ecs_observer_t * ecs_observer_get(const ecs_world_t *world, ecs_entity_t observer)
Get the 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:320
#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 in ecs_entity_desc_t / ecs_bulk_desc_t.
Definition flecs.h:314
#define FLECS_TERM_COUNT_MAX
Maximum number of terms in queries.
Definition flecs.h:330
#define FLECS_TREE_SPAWNER_DEPTH_CACHE_SIZE
Size of the depth cache in the tree spawner component.
Definition flecs.h:363
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 an entity from a path.
ecs_entity_t ecs_lookup_symbol(const ecs_world_t *world, const char *symbol, bool lookup_as_path, bool recursive)
Look up an entity by its symbol name.
void ecs_set_alias(ecs_world_t *world, ecs_entity_t entity, const char *alias)
Set an alias for an entity.
ecs_entity_t ecs_lookup(const ecs_world_t *world, const char *path)
Look up an entity by its 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 a path identifier to a buffer.
ecs_entity_t * ecs_set_lookup_path(ecs_world_t *world, const ecs_entity_t *lookup_path)
Set the 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)
Look up 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)
Look up 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 a specified path to an entity.
ecs_entity_t * ecs_get_lookup_path(const ecs_world_t *world)
Get the 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.
bool ecs_query_has_table(const ecs_query_t *query, ecs_table_t *table, ecs_iter_t *it)
Match a table with a query.
void ecs_iter_set_group(ecs_iter_t *it, uint64_t group_id)
Set the group to iterate for a query iterator.
const ecs_query_t * ecs_query_get(const ecs_world_t *world, ecs_entity_t query)
Get the query object.
bool ecs_query_next(ecs_iter_t *it)
Progress a 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 a query group.
ecs_query_t * ecs_query_update(ecs_world_t *world, ecs_entity_t entity, const ecs_query_desc_t *desc)
Replace the query on an existing entity.
bool ecs_query_is_true(const ecs_query_t *query)
Test whether a query returns one or more results.
char * ecs_term_str(const ecs_world_t *world, const ecs_term_t *term)
Convert a term to a string expression.
bool ecs_query_has_range(const ecs_query_t *query, ecs_table_range_t *range, ecs_iter_t *it)
Match a range with a query.
int32_t ecs_query_find_var(const ecs_query_t *query, const char *name)
Find a variable index.
void ecs_query_fini(ecs_query_t *query)
Delete a query.
bool ecs_query_has(const ecs_query_t *query, ecs_entity_t entity, ecs_iter_t *it)
Match an entity with a query.
char * ecs_query_plan_w_profile(const ecs_query_t *query, const ecs_iter_t *it)
Convert a query to a string with a 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 a key-value string.
int32_t ecs_query_match_count(const ecs_query_t *query)
Return how often a match event happened for a cached query.
char * ecs_query_plan(const ecs_query_t *query)
Convert a 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 a query to a string expression.
bool ecs_query_var_is_entity(const ecs_query_t *query, int32_t var_id)
Test if a 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)
Return whether the query data changed since the last iteration.
const char * ecs_query_var_name(const ecs_query_t *query, int32_t var_id)
Get the variable name.
bool ecs_term_match_this(const ecs_term_t *term)
Is a term matched on the $this variable.
char * ecs_query_plans(const ecs_query_t *query)
Same as ecs_query_plan(), but includes the plan for populating the cache (if any).
void * ecs_query_get_group_ctx(const ecs_query_t *query, uint64_t group_id)
Get the context of a query group.
ecs_query_count_t ecs_query_count(const ecs_query_t *query)
Return the number of entities and results the query matches with.
const ecs_map_t * ecs_query_get_groups(const ecs_query_t *query)
Return the map with query groups.
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 a 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 a term matched on a 0 source.
const ecs_query_t * ecs_query_get_cache_query(const ecs_query_t *query)
Get the query used to populate the 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:729
ecs_inout_kind_t
Specify read/write access for term.
Definition flecs.h:708
ecs_oper_kind_t
Specify operator for term.
Definition flecs.h:718
@ EcsQueryCacheAll
Require that all query terms can be cached.
Definition flecs.h:732
@ EcsQueryCacheDefault
Behavior determined by query creation context.
Definition flecs.h:730
@ EcsQueryCacheNone
No caching.
Definition flecs.h:733
@ EcsQueryCacheAuto
Cache query terms that are cacheable.
Definition flecs.h:731
@ EcsOut
Term is only written.
Definition flecs.h:714
@ EcsInOut
Term is both read and written.
Definition flecs.h:712
@ EcsInOutFilter
Same as InOutNone + prevents term from triggering observers.
Definition flecs.h:711
@ EcsInOutDefault
InOut for regular terms, In for shared terms.
Definition flecs.h:709
@ EcsInOutNone
Term is neither read nor written.
Definition flecs.h:710
@ EcsIn
Term is only read.
Definition flecs.h:713
@ EcsNot
The term must not match.
Definition flecs.h:721
@ EcsOptional
The term may match.
Definition flecs.h:722
@ EcsOr
One of the terms in an or chain must match.
Definition flecs.h:720
@ EcsOrFrom
Term must match at least one component from term ID.
Definition flecs.h:724
@ EcsAnd
The term must match.
Definition flecs.h:719
@ EcsNotFrom
Term must match none of the components from term ID.
Definition flecs.h:725
@ EcsAndFrom
Term must match all components from term ID.
Definition flecs.h:723
ecs_table_t * ecs_table_add_id(ecs_world_t *world, ecs_table_t *table, ecs_id_t component)
Get the table that has all components of the 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 a component in a 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 the table that has all components of the current table minus the specified component.
const ecs_type_t * ecs_table_get_type(const ecs_table_t *table)
Get the type for a table.
int32_t ecs_table_get_column_index(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Get the column index for a component.
int32_t ecs_search_relation_for_entity(const ecs_world_t *world, ecs_entity_t entity, ecs_id_t id, ecs_entity_t rel, bool self, ecs_component_record_t *cr, ecs_entity_t *tgt_out, ecs_id_t *id_out, struct ecs_table_record_t **tr_out)
Search for a component ID by following a relationship, starting from an entity.
void * ecs_table_get_id(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component, int32_t offset)
Get a column from a table by component.
int32_t ecs_table_size(const ecs_table_t *table)
Return the allocated size of the table.
bool ecs_table_has_flags(ecs_table_t *table, ecs_flags32_t flags)
Test a table for flags.
int32_t ecs_table_column_to_type_index(const ecs_table_t *table, int32_t index)
Convert a column index to a type index.
int32_t ecs_table_column_count(const ecs_table_t *table)
Return the number of columns in a 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) an entity to a table.
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 *tgt_out, ecs_id_t *component_out, struct ecs_table_record_t **tr_out)
Search for a component or relationship ID in a table type starting from an offset.
void * ecs_table_get_column(const ecs_table_t *table, int32_t index, int32_t offset)
Get a column from a 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 a component in a table type.
ecs_entity_t ecs_table_get_target(const ecs_world_t *world, const ecs_table_t *table, ecs_entity_t relationship, int32_t index)
Get the relationship target for a table.
int32_t ecs_table_count(const ecs_table_t *table)
Return the number of entities in the table.
const ecs_entity_t * ecs_table_entities(const ecs_table_t *table)
Return the array with entity IDs for the 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 a 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 the depth for a table in the tree for the specified relationship.
bool ecs_table_has_id(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Test if a table has a component.
void ecs_table_swap_rows(ecs_world_t *world, ecs_table_t *table, int32_t row_1, int32_t row_2)
Swap 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 a table from an ID array.
size_t ecs_table_get_column_size(const ecs_table_t *table, int32_t index)
Get the column size from a table.
int32_t ecs_table_get_type_index(const ecs_world_t *world, const ecs_table_t *table, ecs_id_t component)
Get the type index for a 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 a type index to a 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 a value.
int ecs_value_move(const ecs_world_t *world, ecs_entity_t type, void *dst, void *src)
Move a value.
int ecs_value_move_w_type_info(const ecs_world_t *world, const ecs_type_info_t *ti, void *dst, void *src)
Move a 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 a 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 a 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 and free storage.
int ecs_value_move_ctor(const ecs_world_t *world, ecs_entity_t type, void *dst, void *src)
Move-construct a 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 an action to be executed when the world is destroyed.
bool ecs_is_fini(const ecs_world_t *world)
Return 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 the world.
void ecs_set_target_fps(ecs_world_t *world, float fps)
Set target frames per second (FPS) for an 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 an action to be executed once after the 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 the default query flags.
void ecs_quit(ecs_world_t *world)
Signal exit.
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 the entity from a 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 a pointer is of the specified type.
void ecs_entity_range_set(ecs_world_t *world, const ecs_entity_range_t *range)
Set the active entity range.
const ecs_entity_range_t * ecs_entity_range_new(ecs_world_t *world, uint32_t min, uint32_t max)
Create a new entity range.
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.
const ecs_world_info_t * ecs_get_world_info(const ecs_world_t *world)
Get the world info.
const ecs_world_t * ecs_get_world(const ecs_poly_t *poly)
Get the world from a 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)
Clean up empty tables.
const ecs_entity_range_t * ecs_entity_range_get(const ecs_world_t *world)
Get the currently active entity id range.
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().
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:1600
ecs_size_t size
Component size.
Definition flecs.h:1601
ecs_size_t alignment
Component alignment.
Definition flecs.h:1602
When added to an entity, this informs serialization formats which component to use when a value is as...
Definition flecs.h:1615
ecs_id_t component
Default component ID.
Definition flecs.h:1616
A (string) identifier.
Definition flecs.h:1591
ecs_size_t length
Length of identifier.
Definition flecs.h:1593
char * value
Identifier string.
Definition flecs.h:1592
ecs_hashmap_t * index
Current index.
Definition flecs.h:1596
uint64_t hash
Hash of current value.
Definition flecs.h:1594
uint64_t index_hash
Hash of existing record in current index.
Definition flecs.h:1595
Non-fragmenting ChildOf relationship.
Definition flecs.h:1620
ecs_entity_t value
Parent entity.
Definition flecs.h:1621
Component for storing a poly object.
Definition flecs.h:1606
ecs_poly_t * poly
Pointer to poly object.
Definition flecs.h:1607
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 and interval timer functionality.
Definition timer.h:35
Tree instantiation cache component.
Definition flecs.h:1644
ecs_tree_spawner_t data[(6)]
Cache data indexed by depth.
Definition flecs.h:1645
Type with information about the current Flecs build.
Definition flecs.h:1490
const char ** flags
Compile-time settings.
Definition flecs.h:1493
int16_t version_major
Major Flecs version.
Definition flecs.h:1495
const char ** addons
Addons included in the build.
Definition flecs.h:1492
const char * version
Stringified version.
Definition flecs.h:1494
const char * compiler
Compiler used to compile Flecs.
Definition flecs.h:1491
bool sanitize
Is this a sanitize build?
Definition flecs.h:1499
bool perf_trace
Is this a perf tracing build?
Definition flecs.h:1500
int16_t version_minor
Minor Flecs version.
Definition flecs.h:1496
bool debug
Is this a debug build?
Definition flecs.h:1498
int16_t version_patch
Patch Flecs version.
Definition flecs.h:1497
Used with ecs_bulk_init().
Definition flecs.h:1092
ecs_id_t ids[32]
IDs to create the entities with.
Definition flecs.h:1102
void ** data
Array with component data to insert.
Definition flecs.h:1104
int32_t count
Number of entities to create/populate.
Definition flecs.h:1100
int32_t _canary
Used for validity testing.
Definition flecs.h:1093
ecs_entity_t * entities
Entities to bulk insert.
Definition flecs.h:1095
ecs_table_t * table
Table to insert the entities into.
Definition flecs.h:1111
Used with ecs_component_init().
Definition flecs.h:1122
int32_t _canary
Used for validity testing.
Definition flecs.h:1123
ecs_type_info_t type
Parameters for type (size, hooks, ...).
Definition flecs.h:1129
ecs_entity_t entity
Existing entity to associate with a component (optional).
Definition flecs.h:1126
Used with ecs_delete_empty_tables().
Definition flecs.h:2778
uint16_t delete_generation
Delete table when generation > delete_generation.
Definition flecs.h:2783
double time_budget_seconds
Amount of time operation is allowed to spend.
Definition flecs.h:2786
uint16_t clear_generation
Free table data when generation > clear_generation.
Definition flecs.h:2780
int32_t offset
Table index to start scanning at.
Definition flecs.h:2790
Type returned by ecs_get_entities().
Definition flecs.h:2118
int32_t alive_count
Number of alive entity IDs.
Definition flecs.h:2121
int32_t count
Total number of entity IDs.
Definition flecs.h:2120
const ecs_entity_t * ids
Array with all entity IDs in the world.
Definition flecs.h:2119
Used with ecs_entity_init().
Definition flecs.h:1046
const char * sep
Optional custom separator for hierarchical names.
Definition flecs.h:1058
const char * root_sep
Optional, used for identifiers relative to the root.
Definition flecs.h:1062
const char * name
Name of the entity.
Definition flecs.h:1053
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:1074
const char * symbol
Optional entity symbol.
Definition flecs.h:1064
int32_t _canary
Used for validity testing.
Definition flecs.h:1047
const ecs_id_t * add
0-terminated array of IDs to add to the entity.
Definition flecs.h:1079
const char * add_expr
String expression with components to add.
Definition flecs.h:1085
const ecs_value_t * set
0-terminated array of values to set on the entity.
Definition flecs.h:1082
ecs_entity_t id
Set to modify existing entity (optional).
Definition flecs.h:1049
ecs_entity_t parent
Parent entity.
Definition flecs.h:1051
Type that stores an entity id range.
Definition flecs.h:1574
uint32_t max
Last id in range (inclusive, 0 = unlimited).
Definition flecs.h:1576
uint32_t cur
Last issued id in range.
Definition flecs.h:1577
ecs_vec_t recycled
Recycled entity ids (vec<entity_t>).
Definition flecs.h:1578
uint32_t min
First id in range (inclusive).
Definition flecs.h:1575
Used with ecs_emit().
Definition flecs.h:1436
ecs_entity_t entity
Single-entity alternative to setting table / offset / count.
Definition flecs.h:1461
const void * const_param
Same as param, but with the guarantee that the value won't be modified.
Definition flecs.h:1472
ecs_table_t * table
The table for which to notify.
Definition flecs.h:1446
int32_t count
Limit number of notified entities to count.
Definition flecs.h:1458
ecs_table_t * other_table
Optional second table to notify.
Definition flecs.h:1450
int32_t offset
Limit notified entities to ones starting from offset (row) in table.
Definition flecs.h:1453
const ecs_type_t * ids
Component IDs.
Definition flecs.h:1443
ecs_poly_t * observable
Observable (usually the world).
Definition flecs.h:1475
ecs_entity_t event
The event ID.
Definition flecs.h:1438
ecs_flags32_t flags
Event flags.
Definition flecs.h:1478
void * param
Optional context.
Definition flecs.h:1467
Header for ecs_poly_t objects.
Definition flecs.h:524
int32_t type
Magic number indicating which type of Flecs object.
Definition flecs.h:525
int32_t refcount
Refcount, to enable RAII handles.
Definition flecs.h:526
ecs_mixins_t * mixins
Table with offsets to (optional) mixins.
Definition flecs.h:527
Iterator.
Definition flecs.h:1170
ecs_world_t * real_world
Actual world.
Definition flecs.h:1173
void * param
Param passed to ecs_run().
Definition flecs.h:1207
ecs_entity_t event
The event (if applicable).
Definition flecs.h:1195
int32_t frame_offset
Offset relative to the start of iteration.
Definition flecs.h:1218
ecs_flags32_t ref_fields
Bitset with fields that aren't component arrays.
Definition flecs.h:1189
ecs_entity_t interrupted_by
When set, system execution is interrupted.
Definition flecs.h:1222
ecs_flags32_t flags
Iterator flags.
Definition flecs.h:1221
ecs_iter_t * chain_it
Optional, allows for creating iterator chains.
Definition flecs.h:1229
void * ctx
System context.
Definition flecs.h:1208
void * run_ctx
Run language binding context.
Definition flecs.h:1211
ecs_table_t * table
Current table.
Definition flecs.h:1183
int32_t offset
Offset relative to the current table.
Definition flecs.h:1176
ecs_id_t event_id
The (component) ID for the event.
Definition flecs.h:1196
ecs_iter_fini_action_t fini
Function to clean up iterator resources.
Definition flecs.h:1228
ecs_iter_private_t priv_
Private data.
Definition flecs.h:1223
ecs_world_t * world
The world.
Definition flecs.h:1172
void * callback_ctx
Callback language binding context.
Definition flecs.h:1210
ecs_entity_t * sources
Entity on which the ID was matched (0 if same as entities).
Definition flecs.h:1186
void * binding_ctx
System binding context.
Definition flecs.h:1209
ecs_flags32_t row_fields
Fields that must be obtained with field_at.
Definition flecs.h:1190
float delta_system_time
Time elapsed since last system invocation.
Definition flecs.h:1215
const ecs_query_t * query
Query being evaluated.
Definition flecs.h:1204
int8_t term_index
Index of the term that emitted an event.
Definition flecs.h:1201
ecs_entity_t system
The system (if applicable).
Definition flecs.h:1194
ecs_flags32_t set_fields
Fields that are set.
Definition flecs.h:1188
const ecs_size_t * sizes
Component sizes.
Definition flecs.h:1182
float delta_time
Time elapsed since last frame.
Definition flecs.h:1214
ecs_flags32_t up_fields
Bitset with fields matched through up traversal.
Definition flecs.h:1191
ecs_iter_action_t callback
Callback of system or observer.
Definition flecs.h:1227
int8_t field_count
Number of fields in the iterator.
Definition flecs.h:1200
ecs_table_t * other_table
Previous or next table when adding or removing.
Definition flecs.h:1184
int32_t event_cur
Unique event ID.
Definition flecs.h:1197
const ecs_table_record_t ** trs
Info on where to find the field in the table.
Definition flecs.h:1180
int32_t count
Number of entities to iterate.
Definition flecs.h:1177
void ** ptrs
Component pointers.
Definition flecs.h:1179
ecs_iter_next_action_t next
Function to progress iterator.
Definition flecs.h:1226
const ecs_entity_t * entities
Entity identifiers.
Definition flecs.h:1178
ecs_id_t * ids
(Component) IDs.
Definition flecs.h:1185
ecs_flags64_t constrained_vars
Bitset that marks constrained variables.
Definition flecs.h:1187
Used with ecs_observer_init().
Definition flecs.h:1375
ecs_ctx_free_t run_ctx_free
Callback to free run ctx.
Definition flecs.h:1424
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:1412
void * run_ctx
Context associated with run (for language bindings).
Definition flecs.h:1421
ecs_entity_t entity
Existing entity to associate with an observer (optional).
Definition flecs.h:1380
int32_t * last_event_id
Used for internal purposes.
Definition flecs.h:1427
void * callback_ctx
Context associated with callback (for language bindings).
Definition flecs.h:1415
void * ctx
User context to pass to callback.
Definition flecs.h:1409
ecs_query_desc_t query
Query for observer.
Definition flecs.h:1383
ecs_flags32_t flags_
Used for internal purposes.
Definition flecs.h:1429
ecs_ctx_free_t callback_ctx_free
Callback to free callback ctx.
Definition flecs.h:1418
int8_t term_index_
Used for internal purposes.
Definition flecs.h:1428
bool global_observer
Global observers are tied to the lifespan of the world.
Definition flecs.h:1395
ecs_iter_action_t callback
Callback to invoke on an event, invoked when the observer matches.
Definition flecs.h:1398
bool yield_existing
When an observer is created, generate events from existing data.
Definition flecs.h:1390
ecs_run_action_t run
Callback invoked on an event.
Definition flecs.h:1406
ecs_entity_t events[8]
Events to observe (OnAdd, OnRemove, OnSet).
Definition flecs.h:1386
int32_t _canary
Used for validity testing.
Definition flecs.h:1377
An observer reacts to events matching a query.
Definition flecs.h:879
int32_t event_count
Number of events.
Definition flecs.h:886
ecs_iter_action_t callback
See ecs_observer_desc_t::callback.
Definition flecs.h:888
ecs_entity_t entity
Entity associated with the observer.
Definition flecs.h:902
ecs_observable_t * observable
Observable for the observer.
Definition flecs.h:899
ecs_run_action_t run
See ecs_observer_desc_t::run.
Definition flecs.h:889
ecs_header_t hdr
Object header.
Definition flecs.h:880
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:895
ecs_entity_t events[8]
Observer events.
Definition flecs.h:885
void * run_ctx
Run language binding context.
Definition flecs.h:893
ecs_world_t * world
The world.
Definition flecs.h:901
ecs_ctx_free_t run_ctx_free
Callback to free run_ctx.
Definition flecs.h:897
void * callback_ctx
Callback language binding context.
Definition flecs.h:892
void * ctx
Observer context.
Definition flecs.h:891
ecs_ctx_free_t callback_ctx_free
Callback to free callback_ctx.
Definition flecs.h:896
ecs_query_t * query
Observer query.
Definition flecs.h:882
Struct returned by ecs_query_count().
Definition flecs.h:5269
int32_t entities
Number of entities returned by the query.
Definition flecs.h:5271
int32_t results
Number of results returned by the query.
Definition flecs.h:5270
int32_t tables
Number of tables returned by the query.
Definition flecs.h:5272
Used with ecs_query_init().
Definition flecs.h:1301
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:1362
ecs_id_t group_by
Component ID to be used for grouping.
Definition flecs.h:1332
ecs_term_t terms[32]
Query terms.
Definition flecs.h:1306
int32_t _canary
Used for validity testing.
Definition flecs.h:1303
void * ctx
User context to pass to callback.
Definition flecs.h:1356
ecs_ctx_free_t group_by_ctx_free
Function to free group_by_ctx.
Definition flecs.h:1353
void * group_by_ctx
Context to pass to group_by.
Definition flecs.h:1350
void * binding_ctx
Context to be used for language bindings.
Definition flecs.h:1359
ecs_entity_t order_by
Component to sort on, used together with order_by_callback or order_by_table_callback.
Definition flecs.h:1328
ecs_order_by_action_t order_by_callback
Callback used for ordering query results.
Definition flecs.h:1320
ecs_group_create_action_t on_group_create
Callback that is invoked when a new group is created.
Definition flecs.h:1343
ecs_entity_t entity
Entity associated with query (optional).
Definition flecs.h:1368
ecs_ctx_free_t binding_ctx_free
Callback to free binding_ctx.
Definition flecs.h:1365
ecs_group_by_action_t group_by_callback
Callback used for grouping results.
Definition flecs.h:1339
ecs_group_delete_action_t on_group_delete
Callback that is invoked when an existing group is deleted.
Definition flecs.h:1347
ecs_sort_table_action_t order_by_table_callback
Callback used for ordering query results.
Definition flecs.h:1324
ecs_flags32_t flags
Flags for enabling query features.
Definition flecs.h:1315
ecs_query_cache_kind_t cache_kind
Caching policy of the query.
Definition flecs.h:1312
const char * expr
Query DSL expression (optional).
Definition flecs.h:1309
Type that contains information about a query group.
Definition flecs.h:1564
int32_t table_count
Number of tables in group.
Definition flecs.h:1567
void * ctx
Group context, returned by on_group_create.
Definition flecs.h:1568
uint64_t id
Group ID.
Definition flecs.h:1565
int32_t match_count
How often tables have been matched or unmatched.
Definition flecs.h:1566
Queries are lists of constraints (terms) that match entities.
Definition flecs.h:838
ecs_flags32_t row_fields
Fields that must be acquired with field_at.
Definition flecs.h:858
ecs_flags32_t data_fields
Fields that have data.
Definition flecs.h:855
ecs_flags32_t read_fields
Fields that read data.
Definition flecs.h:857
ecs_header_t hdr
Object header.
Definition flecs.h:839
int8_t var_count
Number of query variables.
Definition flecs.h:847
ecs_flags32_t fixed_fields
Bitmasks for quick field information lookups.
Definition flecs.h:852
ecs_flags32_t var_fields
Fields with non-$this variable source.
Definition flecs.h:853
ecs_flags32_t write_fields
Fields that write data.
Definition flecs.h:856
int32_t eval_count
Number of times the query is evaluated.
Definition flecs.h:873
ecs_world_t * world
World or stage the query was created with.
Definition flecs.h:871
ecs_flags32_t static_id_fields
Fields with a static (component) id.
Definition flecs.h:854
uint64_t bloom_filter
Bitmask used to quickly discard tables.
Definition flecs.h:845
ecs_world_t * real_world
Actual world.
Definition flecs.h:870
ecs_flags32_t set_fields
Fields that will be set.
Definition flecs.h:860
ecs_entity_t entity
Entity associated with query (optional).
Definition flecs.h:869
void * ctx
User context to pass to callback.
Definition flecs.h:866
int32_t * sizes
Component sizes.
Definition flecs.h:842
ecs_id_t * ids
Component ids.
Definition flecs.h:843
ecs_flags32_t shared_readonly_fields
Fields that don't write shared data.
Definition flecs.h:859
ecs_term_t * terms
Query terms.
Definition flecs.h:841
ecs_query_cache_kind_t cache_kind
Caching policy of the query.
Definition flecs.h:862
int8_t term_count
Number of query terms.
Definition flecs.h:848
char ** vars
Array with variable names for the iterator.
Definition flecs.h:864
int8_t field_count
Number of fields returned by the query.
Definition flecs.h:849
ecs_flags32_t flags
Query flags.
Definition flecs.h:846
void * binding_ctx
Context to be used for language bindings.
Definition flecs.h:867
Type that describes a reference to an entity or variable in a term.
Definition flecs.h:799
const char * name
Name.
Definition flecs.h:806
ecs_entity_t id
Entity ID.
Definition flecs.h:800
Type that describes a term (single element in a query).
Definition flecs.h:814
ecs_term_ref_t src
Source of term.
Definition flecs.h:820
int8_t field_index
Index of the field for the term in the iterator.
Definition flecs.h:831
ecs_id_t id
Component ID to be matched by term.
Definition flecs.h:815
int16_t oper
Operator of term.
Definition flecs.h:829
ecs_term_ref_t second
Second element of pair.
Definition flecs.h:822
ecs_flags16_t flags_
Flags that help evaluation, set by ecs_query_init().
Definition flecs.h:832
ecs_entity_t trav
Relationship to traverse when looking for the component.
Definition flecs.h:824
int16_t inout
Access to contents matched by term.
Definition flecs.h:828
ecs_term_ref_t first
Component or first element of pair.
Definition flecs.h:821
Component with data to instantiate a non-fragmenting tree.
Definition flecs.h:1625
uint32_t child
Prefab child entity (without generation).
Definition flecs.h:1628
int32_t parent_index
Index into the children vector.
Definition flecs.h:1629
const char * child_name
Name of the prefab child.
Definition flecs.h:1626
ecs_table_t * table
Table in which the child will be stored.
Definition flecs.h:1627
Tree spawner data for a single hierarchy depth.
Definition flecs.h:1633
ecs_vec_t children
vector<ecs_tree_spawner_child_t>.
Definition flecs.h:1634
ecs_copy_t copy_ctor
Ctor + copy.
Definition flecs.h:961
void * lifecycle_ctx
Component lifecycle context (see meta addon).
Definition flecs.h:1012
void * ctx
User-defined context.
Definition flecs.h:1010
ecs_iter_action_t on_remove
Callback that is invoked when an instance of the component is removed.
Definition flecs.h:1002
void * binding_ctx
Language binding context.
Definition flecs.h:1011
ecs_move_t move_dtor
Move + dtor.
Definition flecs.h:976
ecs_flags32_t flags
Hook flags.
Definition flecs.h:988
ecs_cmp_t cmp
Compare hook.
Definition flecs.h:979
ecs_copy_t copy
copy assignment.
Definition flecs.h:957
ecs_ctx_free_t lifecycle_ctx_free
Callback to free lifecycle_ctx.
Definition flecs.h:1016
ecs_iter_action_t on_set
Callback that is invoked when an instance of the component is set.
Definition flecs.h:997
ecs_move_t move
move assignment.
Definition flecs.h:958
ecs_xtor_t ctor
ctor.
Definition flecs.h:955
ecs_iter_action_t on_replace
Callback that is invoked with the existing and new value before the value is assigned.
Definition flecs.h:1008
ecs_ctx_free_t ctx_free
Callback to free ctx.
Definition flecs.h:1014
ecs_iter_action_t on_add
Callback that is invoked when an instance of a component is added.
Definition flecs.h:992
ecs_ctx_free_t binding_ctx_free
Callback to free binding_ctx.
Definition flecs.h:1015
ecs_move_t move_ctor
Ctor + move.
Definition flecs.h:964
ecs_equals_t equals
Equals hook.
Definition flecs.h:982
ecs_move_t ctor_move_dtor
Ctor + move + dtor (or move_ctor + dtor).
Definition flecs.h:970
ecs_xtor_t dtor
dtor.
Definition flecs.h:956
Type that contains component information (passed to ctors/dtors/...).
Definition flecs.h:1023
ecs_size_t alignment
Alignment of the type.
Definition flecs.h:1025
ecs_size_t size
Size of the type.
Definition flecs.h:1024
const char * name
Type name.
Definition flecs.h:1028
ecs_entity_t component
Handle to component (do not set).
Definition flecs.h:1027
ecs_type_hooks_t hooks
Type hooks.
Definition flecs.h:1026
A type is a list of (component) IDs.
Definition flecs.h:402
ecs_id_t * array
Array with IDs.
Definition flecs.h:403
int32_t count
Number of elements in array.
Definition flecs.h:404
Utility to hold a value of a dynamic type.
Definition flecs.h:1037
void * ptr
Pointer to value.
Definition flecs.h:1039
ecs_entity_t type
Type of value.
Definition flecs.h:1038
Type that contains information about the world.
Definition flecs.h:1504
int64_t observers_ran_total
Total number of times an observer was invoked.
Definition flecs.h:1530
float delta_time
Time passed to or computed by ecs_progress().
Definition flecs.h:1508
int64_t systems_ran_total
Total number of systems run.
Definition flecs.h:1529
int64_t set_count
Set commands processed.
Definition flecs.h:1547
double world_time_total
Time elapsed in simulation.
Definition flecs.h:1516
int32_t tag_id_count
Number of tag (no data) IDs in the world.
Definition flecs.h:1533
int32_t component_id_count
Number of component (data) IDs in the world.
Definition flecs.h:1534
int64_t pipeline_build_count_total
Total number of pipeline builds.
Definition flecs.h:1528
int64_t eval_comp_monitors_total
Total number of monitor evaluations.
Definition flecs.h:1521
int32_t table_count
Number of tables.
Definition flecs.h:1537
float delta_time_raw
Raw delta time (no time scaling).
Definition flecs.h:1507
float frame_time_total
Total time spent processing a frame.
Definition flecs.h:1511
int64_t table_create_total
Total number of times a table was created.
Definition flecs.h:1526
float system_time_total
Total time spent in systems.
Definition flecs.h:1512
int64_t id_delete_total
Total number of times an ID was deleted.
Definition flecs.h:1525
float merge_time_total
Total time spent in merges.
Definition flecs.h:1514
struct ecs_world_info_t::@0 cmd
Command statistics.
int64_t discard_count
Commands discarded, happens when the entity is no longer alive when running the command.
Definition flecs.h:1550
int64_t clear_count
Clear commands processed.
Definition flecs.h:1546
ecs_entity_t last_component_id
Last issued component entity ID.
Definition flecs.h:1505
int64_t frame_count_total
Total number of frames.
Definition flecs.h:1519
int64_t merge_count_total
Total number of merges.
Definition flecs.h:1520
int64_t other_count
Other commands processed.
Definition flecs.h:1552
int64_t batched_command_count
Commands batched.
Definition flecs.h:1554
int64_t table_delete_total
Total number of times a table was deleted.
Definition flecs.h:1527
int64_t queries_ran_total
Total number of times a query was evaluated.
Definition flecs.h:1531
int64_t delete_count
Delete commands processed.
Definition flecs.h:1545
int64_t rematch_count_total
Total number of rematches.
Definition flecs.h:1522
int64_t id_create_total
Total number of times a new ID was created.
Definition flecs.h:1524
int64_t batched_entity_count
Entities for which commands were batched.
Definition flecs.h:1553
float time_scale
Time scale applied to delta_time.
Definition flecs.h:1509
int32_t pair_id_count
Number of pair IDs in the world.
Definition flecs.h:1535
float rematch_time_total
Time spent on query rematching.
Definition flecs.h:1515
int64_t ensure_count
Ensure or emplace commands processed.
Definition flecs.h:1548
float target_fps
Target FPS.
Definition flecs.h:1510
double world_time_total_raw
Time elapsed in simulation (no scaling).
Definition flecs.h:1517
float emit_time_total
Total time spent notifying observers.
Definition flecs.h:1513
uint32_t creation_time
Time when world was created.
Definition flecs.h:1539
int64_t modified_count
Modified commands processed.
Definition flecs.h:1549
const char * name_prefix
Value set by ecs_set_name_prefix().
Definition flecs.h:1557
int64_t event_count
Enqueued custom events.
Definition flecs.h:1551
int64_t add_count
Add commands processed.
Definition flecs.h:1543
int64_t remove_count
Remove commands processed.
Definition flecs.h:1544