Skip to content

Releases: SanderMertens/flecs

Flecs v4.0.4

08 Jan 01:33
8a1e9ab
Compare
Choose a tag to compare

Happy new year! 🥂 🎉

Highlights

  • Component ids no longer need to match between worlds, which means Flecs worlds are now truly independent!
  • Enums with custom underlying types are now properly supported by the core and meta addon
  • The script and query implementations have been fuzzed, which lead to lots of gnarly bugs being found 🐛
  • A big flecs script refactor improved performance 50x (!) over 4.0.3, and 6x over 3.2.12
  • Many, many new flecs script features which means much more complex scenes can now be built:

buildings
Procedural scene constructed from primitive shapes with flecs script

Release notes

This version includes the following bugfixes:

  • [cpp] Fix ubsan error in free_obj<T> (thanks @jspohr!)
  • [cpp] Fix issue with registering hooks after component registration (thanks @jpeletier!)
  • [cpp] Fix issue where calling set_group/set_var on const query objects was not possible
  • [cpp] Fix crash when iterating components of entity with an empty type
  • [cpp] Fix issue with nested observers and implicit namespaced component registration
  • [cpp] Fix issue with reregistering component symbol after deletion
  • [cpp] Fix issue where shared fields could not be accessed with field/field_at in each callback
  • [cpp] Fix issue with enum_data::index_by_value
  • [cpp] Fix crash in C++ addon logging
  • [cpp] Fix issue in C++ API when iterating a large number of sparse components
  • [core] Fix issue where batched commands for implicitly registered component could crash
  • [core] Fix issue with registration of traits for builtin entities
  • [core] Fix issue with using ecs_entity_desc_t::set while deferring is suspended
  • [core] Fix illegal memory access in ecs_add_path_w_sep
  • [core] Fix write to invalid memory in flecs_path_append
  • [core] Fix issue with name lookups that have multiple consecutive separator characters
  • [core] Fix issue with attempting to lookup #id's with value larger than UINT32_MAX
  • [core] Fix leaks when using FLECS_USE_OS_ALLOC
  • [core] Fix issues where code was accessing world flags on stage object
  • [core] Fix access to uninitialized ecs_cmd_t::id field
  • [core] Fix leak when deferring a batched set for a large non-trivial component
  • [core] Fix issue where second element of pair could not be a sparse component
  • [core] Fix command batching issue where component is added in two stages
  • [observers] Fix issue where observers could be triggered multiple times for the same event
  • [observers] Fix issue where event was incorrectly propagated for masked component
  • [observers] Fix issue where observer with multiple up() terms could get duplicate events
  • [observers] Fix issue where OnTableCreate observer did not trigger in deferred mode
  • [queries] Fix crash when sorted query with MatchEmptyTables only matches empty tables
  • [queries] Fix issue where up traversal with inheritance could return duplicate results
  • [queries] Fix issue where IsA was incorrectly traversed for non-inheritable components
  • [queries] Fix issue with using query.find(flecs::entity, ...) and EcsQueryMatchEmptyTables
  • [queries] Fix issue where queries would return inconsistent component id for *From operator fields
  • [queries] Fix assert that happens while reporting a query error
  • [queries] Fix assert when query has unbalanced {} scopes
  • [queries] Fix issue where query incorrectly treated this entity reference as variable
  • [queries] Fix issue with queries that have mixed cached fields and shared fields
  • [queries] Fix issue with queries created in stage, change detection and shared fields
  • [meta] Fix memory leaks in cursor string conversions
  • [json] Fix issue where override components would show up as inheritable in serialized JSON
  • [script] Fix issue where script AST would incorrectly cache ids of entities created by template
  • [script] Fix issue with parsing opaque primitive components
  • [script] Fix issue with using pair components in templates
  • [rest] Fix issue with reporting errors that contain formatting characters
  • [misc] Fix file handle leak when file fails to load (thanks @peter15914!)

This version includes the following improvements:

  • [cpp] Prevent recycled entity ids when reparenting C++ module
  • [cpp] Add to_json() method to flecs::query_base
  • [cpp] Allow for X_TO_JSON_INIT macros to be used in C++
  • [cpp] Fix warning for incorrect type in static_cast for inout & operator kinds
  • [cpp] Implement world local component ids
  • [cpp] Enums with custom underlying types are now supported
  • [core] Reduce overhead of monitors by not creating observers for optional terms
  • [core] Add assert to prevent entity ids from overflowing the 32 bit range (thanks @Ukendio!)
  • [core] Implement type info flags for detecting invalid component lifecycle (thanks @jpeletier!)
  • [core] Reduce page size of non-entity sparse sets (Reduce memory footprint)
  • [core] Use map instead of sparse set for type_info (Reduce memory footprint)
  • [core] Remove unnecessary observer sparse set (Reduce memory footprint)
  • [core] Reduce size of low id record array (reduces RAM)
  • [core] Change flecs.core.Disabled to (OnInstantiate, Override) (from Inherit)
  • [core] Allow for infinitely nested observer calls
  • [core] Add cycle detection in observer code to prevent stack overflows
  • [core] Add error message when invalid path is passed to ecs_add_path_w_sep
  • [core] Remove propagation of empty state for tables
  • [core] Change ecs_delete_empty_tables API by changing its parameters to a desc struct
  • [queries] Add ecs_query_get to get ecs_query_t* object from entity
  • [queries] Add more validator tests for !(ChildOf, _) queries
  • [systems] Add system disabling test
  • [script] Flecs script expression refactor
  • [script] Add support for function arguments to flecs script
  • [script] Add math functions to flecs script in a new FLECS_SCRIPT_MATH addon
  • [script] Add ability to specify variables when running a script
  • [script] Add support for multiple template instances per entity
  • [script] Improve detection of invalid statements in with scopes
  • [script] Add ability to define world-scoped script variables (like PI)
  • [script] Add support for string interpolation to expression parser
  • [script] Add support for entity name expressions (like"e_$i" { })
  • [script] Implement support for for var in x..y loops
  • [script] Add divide by zero checks so runtime doesn't crash but reports error
  • [script] Add more builtin script functions for doc addon and testing for components
  • [script] Implement random number generator for flecs script
  • [script] Bulk-add components in entity scope to improve script performance
  • [script] Add support for else if
  • [script] Add support for match expressions
  • [script] Add support for using add assign and multiply assign in initializers
  • [script] Empty scopes now create an anonymous entity
  • [script] Allow referring to variables without $
  • [script] Variables now need to use const x: value notation when using implicit type
  • [script] Props can now have implicit types
  • [http] Allow HTTP server to be created without threading support (thanks @basicer!)
  • [http] Allow for script code to be provided in body of /script request
  • [http] Increase size of HTTP receive buffer, throw warning if request exceeds it
  • [http] Add body parameter to ecs_http_server_request
  • [docs] Add system & query examples for each and run callback variants
  • [docs] Add example that shows how to iterate multiple queries in a system
  • [docs] Add Unreal-Flecs link to documentation page
  • [docs] Fix issue with query_to_custom_json example
  • [docs] Fix ecs/world typo in system manual (thanks @iHR4K!)
  • [docs] Add Resistance is Brutal to README
  • [docs] Improvements to migration guide (thanks @999pingGG!)
  • [docs] Add flecs tutorial links to documentation page
  • [ci] Fix warnings in tests (thanks @jpeletier!)
  • [ci] Silence clang warning about missing default case
  • [ci] Fix CI bazel job to work with new bazel version

Breaking changes

  • Flecs script API functions have been renamed: #466 (comment)
  • flecs::reset() no longer exists: #466 (comment)
  • Events for communicating empty table state no longer exist: #466 (comment)
  • The signature of ecs_http_server_request has changed: #466 (comment)
  • The const var = value script syntax has been deprecated: #466 (comment)
  • Empty script scopes now create anonymous entities: #466 (comment)
  • Not strictly a breaking change, but the order in which nested observers are evaluated has changed, which may break code that relied on observer ordering (which is undefined).

New Contributors

Read more

Flecs v4.0.3

09 Nov 19:15
b3ad03c
Compare
Choose a tag to compare

Highlights

  • None, just a lot of small improvements and bugfixes 🐛

Release notes

This version includes the following bugfixes:

  • [cpp] Fix issue with modified<R, T> where first type is a tag
  • [cpp] Fix conflicting identifier between flecs and magic_enum library
  • [cpp] Fix issue with reparenting module that is in root namespace
  • [cpp] Disable incorrect msvc warning on enum reflection code
  • [core] Remove FLECS_API in block_allocator.c which was causing linker errors (thanks @Indra-db!)
  • [core] Fix crash if component and entity w/component are deleted in same cleanup operation
  • [core] Fix linked list corruption in supporting data structure for Union relationships
  • [core] Fix issue where union relationships weren't copied from prefab to prefab instance
  • [core] Fix bug with component overriding for prefabs with union pairs
  • [core] Avoid size integer overflow of command buffer vector during world cleanup (thanks @jpeletier!)
  • [queries] Fix issue with queries that match empty tables and iterate individual entities
  • [queries] Fix issue with evaluating queries with any wildcards that match multiple tables
  • [queries] Fix issue where offset could be applied to NULL address
  • [observers] Fix issue with yield_existing observers and not terms
  • [observers] Fix issue with getting field in OnSet observer after removing override
  • [observers] Fix issue where (OnInstantiate, Override) would not trigger OnSet observers
  • [expr] Fix memory leak after failed multiline string assignment
  • [json] Fix JSON serialization for auto_override/toggle components
  • [json] Fix issue with serializing type info to JSON for sparse components
  • [log] Fix issue where ecs_log_set_level returns wrong value
  • [stats] Fix issue in flecs::stats module when global MatchEmptyTables flag is set
  • [alerts] Fix broken FLECS_NO_ALERTS macro (thanks @pfeodrippe!)

This version includes the following improvements:

  • [cpp] Implement iter::targets for easy iteration of relationship targets for a field
  • [cpp] Remove redundant call to strcpy in ecs_cpp_get_symbol_name
  • [cpp] Enforce correct type when using *_second operations in entity, entity_view and entity_builder
  • [queries] Return wildcard table records in ecs_iter_t::trs for any wildcard terms
  • [queries] Report errors for invalid usage of cascade and desc modifiers
  • [observers] Add yield_existing flags for customizing observer create/delete behavior
  • [observers] Trigger events for optional observer terms
  • [core] Add ecs_world_get_flags function
  • [core] Escape separator characters in entity name when using ecs_get_path
  • [core] Add option to escape characters for serialization in entity path
  • [core] Implement ecs_table_clear_entities (thanks @gsnook!)
  • [meta] Emit OnSet after modifying EcsEnum component (thanks @jpeletier!)
  • [json] Fix issue with serializing queries that have large numbers of fields
  • [json] Don't serialize base DontInherit components to JSON
  • [rest] Include query plan used to populate cache in REST reply
  • [http] Automatically test port range when creating HTTP server for multi-application support
  • [doc] Add UUID to doc addon
  • [docs] Add link to flecs raylib starter kit to documents
  • [docs] Add Hyperion to README
  • [docs] Add Age of Respair to README
  • [docs] Fix incomplete sentence in query manual
  • [docs] Fix find/replace errors in query manual
  • [docs] Show how to use lookup functions in hierarchy examples
  • [docs] Fix disabling typo in entity manual
  • [docs] Fix TermAt indexing in C# docs (thanks @deathbeam!)
  • [docs] Rename Routine to System in C# docs (thanks @deathbeam)
  • [docs] Fix comment typo in prefab example (thanks @Indra-db)
  • [docs] Fix broken link in relationship manual
  • [docs] Add note to prefab manual on how prefabs are only ignored for entities matched on $this
  • [docs] Add missing , in migration guide
  • [docs] Fix typo in scopes section of query manual
  • [tests] Fix duplicate test case
  • [build] Remove unnecessary version attribute from flecs bazel model definition (thanks @reutermj!)
  • [ci] macOS CI improvements (thanks @waywardmonkeys!)

Breaking changes

  • ecs_get_path_w_sep_buf now has an additional escape argument (#466 (comment))

New Contributors

Full Changelog: v4.0.2...v4.0.3

Flecs v4.0.2

24 Sep 17:59
bf9ec9f
Compare
Choose a tag to compare

Highlights

Release notes

This version includes the following bugfixes:

  • [cpp] Fix spurious entities that are created when renaming C++ module
  • [cpp] Fix issue with non-$this fields in query iteration (thanks @Gaspard--!)
  • [cpp] Fix issue with computing component name from multiple threads/worlds
  • [cpp] Fix issue where C++ world object would sometimes not get freed (thanks @jpeletier!)
  • [cpp] Fix issue with observers and up traversal
  • [cpp] Fix clang 20 compiler error in enum reflection code
  • [core] Fix issue with using sparse components and ecs_new_w_table
  • [core] Fix issue with ecs_new_w_table and overriding components
  • [core] Fix issue with creating queries inside of hooks
  • [core] Fix issue with testing tables for wildcard pair ids
  • [core] Fix potential leak in ecs_clone due to double constructor call (thanks @jpeletier!)
  • [core] Fix issues with simple observers/queries for sparse components
  • [core] Fix issues with hooks for sparse components
  • [core] Fix issue with batched OnAdd + OnRemove observers
  • [queries] Fix issue with matching IsA -> IsA -> ChildOf up traversal
  • [queries] Fix issue with matching prefab/disabled entities for queries that start with not term
  • [systems] Fix issue with setting rate filter on system without tick source
  • [systems] Fix issue with cleaning up iterator resources for systems that match nothing
  • [json] Fix crash when serializing query plan for trivial query
  • [json] Fix issue where conflicting alerts member could serialize to invalid JSON
  • [script] Fix issue where script visitor function wasn't restored after parsing template
  • [stats] Fix issue where units module was not always imported by stats (thanks @domdom!)
  • [stats] Fix crash when fetching WorldSummary by REST API before it's initialized
  • [explorer] Fix issue with entity names that have contain / characters

This version includes the following improvements:

  • [cpp] Add flecs::ref::has
  • [cpp] Add missing overload for query_builder::with(const char*, id_t)
  • [cpp] Add flecs::iter::other_table()
  • [c] Remove const from ecs_ref_get
  • [core] Implement fine-grained feature tracking for add/remove operations
  • [core] Add performance tracing hooks to OS API
  • [core] Add perf trace when sleeping due to target_fps (thanks @waywardmonkeys!)
  • [core] Add support for AUTO_OVERRIDE to prefab children
  • [core] Implement deterministic ids for prefab children
  • [core] Use __alignof__ on clang
  • [core] Allow for restoring ranges with ecs_set_entity_range
  • [core] Add compile time flag to disable statistics counters
  • [core] Fix thread sanitizer warnings
  • [core] Prevent calling ecs_run_post_frame outside of frame
  • [core] Add ecs_id_from_str
  • [core] Allow for suspending readonly mode outside of multithreaded systems
  • [queries] Remove redundant query instruction constants
  • [queries] Allow (IsA, tgt|self) queries to be cached
  • [queries] Don't automatically cache queries with only not/optional terms
  • [observers] Add yield_existing support to OnRemove observers
  • [meta] Support calling ecs_meta_get_string on opaque string types
  • [meta] Make flaky alert tests not flaky (thanks @jpeletier!)
  • [meta] Add a const_string opaque type (thanks @jpeletier!)
  • [meta] Auto-generate lifecycle hooks for reflection-only types
  • [stats] Add counter for tracking component monitor evaluations
  • [units] Remove unused symbols from units addons
  • [docs] Fix typos in documentation on how to run tests (thanks @jpeletier!)
  • [docs] Add Meta copyright notice to LICENSE (has no impact on license which is still MIT!)
  • [docs] Fix typos (thanks @waywardmonkeys!)
  • [docs] Fix emit/event typo in observer manual (thanks @awest03!)
  • [docs] Add missing access modifier section to query language manual
  • [docs] Add link to storage in pictures to docs
  • [docs] Fix broken links in design guide
  • [build] Move flecs.c and flecs.h files to distr folder
  • [build] Migrate bazel build to bzlmod (thanks @reutermj!)
  • [build] Add bazel build definitions for examples and add bazel build/test to CI
  • [ci] Add spell check to CI (thanks @Georgiy-Tugai!)

Breaking changes

  • The flecs.c and flecs.h have moved to distr (#466)

New Contributors

Full Changelog: v4.0.1...v4.0.2

Flecs v4.0.1

16 Aug 02:44
02c8c26
Compare
Choose a tag to compare

Highlights

Lots of performance improvements! 🚀

  • Queries for sparse components are up to 20x faster
  • get, get_mut, has and owns are 1.5-3x faster
  • Cached queries are 5x faster to create, and match 1.5x faster with new tables
  • Simple uncached queries are up to 2x faster than v4.0.0 (5x faster than v3.2.12)

Release notes

This version includes the following bugfixes:

  • [cpp] Fix crash when copying world object during shutdown (thanks @jpeletier!)
  • [cpp] Call populate_self recursively for simple query results (thanks @Indra-db!)
  • [core] Fix assert when toggling component from stage
  • [core] Fix command batching issue that could prevent query rematching
  • [core] Fix issues with commands for sparse components
  • [core] Fix issue with cloning named entities
  • [core] Fix assert when calling emplace after remove while deferred
  • [queries] Fix issue with not operator, traversal and wildcards
  • [queries] Fix issue with toggleable components and terms with #0 source
  • [queries] Fix issue with up traversal and (re)matching empty tables
  • [observers] Fix issue with updating observers to different callback kind
  • [observers] Fix issue with observer for sparse component (thanks @Megafunk!)
  • [systems] Fix issue with updating system to different callback kind
  • [script] Fix issue where anonymous entities wouldn't clear after script update
  • [script] Fix syntax error for scripts with only a using statement
  • [script] Fix issue where unresolved component in template didn't throw an error
  • [script] Fix issue with anonymous template instance creation
  • [script] Fix issues with partial component assignments
  • [script] Fix issues with assigning non-trivial components
  • [json] Fix issues in new deserializer, serialize full paths by default
  • [json] Fix issue with serializing entity to JSON from stage
  • [json] Fix issues with serializing sparse components
  • [json] Fix issue with serializing inherited components without reflection data
  • [rest] Ensure REST HTTP server always has valid delta_time value
  • [rest] Only enable time measurements when OS time API is initialized

This version includes the following improvements:

  • [cpp] Add flecs::ref<T> constructor that just takes an entity (thanks @RoyAwesome!)
  • [cpp] Add support for iterating sparse component queries with run callback
  • [core] Remove id and size fields from ecs_column_t
  • [core] Use one size/count member for all table columns
  • [core] Add component_map to tables to improve get/get_mut/has/owns performance
  • [core] Improve performance of ecs_table_get_*_index functions
  • [queries] Add dedicated iterator mode for queries that are fully cached
  • [queries] Add dedicated iterator mode for queries that are fully trivial
  • [queries] Don't evaluate first term of uncached queries twice
  • [queries] Reduce branching in trivial iterator code
  • [queries] Remove iterator mode that returned entities one by one
  • [queries] Replace ecs_iter_t::columns with table records array
  • [queries] Remove ecs_iter_t::ptrs
  • [queries] Reduce number of observers created per query
  • [queries] Reuse static sources/ids arrays for cached results where possible
  • [queries] Don't generate query plan for trivial queries
  • [queries] Implement fast query validation for simple queries
  • [meta] Add option to provide 0 offset without triggering automatic offset computation (thanks @Indra-db!)
  • [script] Suppress variable shadowing warning for parser on msvc
  • [json] Remove legacy (v3) deserializer
  • [log] Fix incorrect log color comparison (thanks @kagetu!)
  • [docs] Replace no_readonly with immediate in system manual
  • [docs] Fix link to migration guide
  • [docs] Fix grammar in Rust query examples (thanks @waywardmonkeys!)
  • [docs] Fix find/replace typos (thanks @waywardmonkeys!)
  • [docs] Remove references to EcsIteratble (thanks @waywardmonkeys!)
  • [misc] Create .gitattributes to preserve line endings on Windows (thanks @epreston!)
  • [ci] Prevent running workflows concurrently for same branch

Benchmark results
https://github.com/SanderMertens/ecs_benchmark/tree/bda57ec04f1cb9ebeacab8a17cf9a0c3353d267b

Breaking changes

  • Query results with inherited components now must be explicitly handled in C API (#466 (comment))
  • Sparse components must now be obtained with ecs_field_at (#466 (comment))
  • The columns/ptrs members got removed from iterators (#466 (comment))
  • Member target query results have changed (#466 (comment))

New Contributors

Full Changelog: v4.0.0...v4.0.1

Flecs v4.0.0

14 Jul 03:32
Compare
Choose a tag to compare

Flecs 4.0 is out! 🎉

This is a major release with many new features, improvements, bugfixes and breaking changes. Enjoy!

Release Notes

See the release announcement:
https://ajmmertens.medium.com/flecs-v4-0-is-out-58e99e331888

Upgrading to v4

To upgrade from v3 to v4, see the migration guide:
https://www.flecs.dev/flecs/md_docs_2MigrationGuide.html

Known issues

#1215
#714
#478

Flecs v3.2.12

12 Jul 05:28
3210bff
Compare
Choose a tag to compare

Highlights

  • This release marks the last commit before the v4 release, which is happening in the next few days!
  • This is by far the most stable v3 release, and recommended for anyone staying on v3
  • All of the changes below are already part of the v4 branch!

Release notes

This version includes the following bugfixes:

  • Fix issue where anonymous entity would be deserialized into named entity with same id
  • Fix query DSL issue where incorrect entity could get resolved for OneOf terms
  • Fix issue where module symbol lookup could interfere with name lookups
  • Fix typo in named query REST endpoint
  • Don't serialize entity ids as floats in JSON
  • Fix issues with assigning path names with deleted parent in deferred mode
  • Fix compiler error when application defines free macro
  • Fix integer conversion assert in JSON serializer
  • Fix issue where compiling JSON addon without REST didn't work
  • Fix issue with any pair terms in observers
  • Fix world deserialization issue with entities that have relationship cycles
  • Fix issue with sorting shared components
  • Fix potential divide by zero in JSON profiler code
  • Fix enum reflection issue on VS2019
  • Fix assert for invalid query with uninitialized dependent variable
  • Fix infinite loop in progress when using integer time type
  • Fix issues with yield_existing and observers with entity source
  • Fix offset on nullptr in JSON serializer code
  • Fix out of bounds write when bulk overriding components (thanks @Indra-db!)
  • Fix assert when moving component without ctor to existing table (thanks @Thinkofname!)
  • Remove declaration to non-existent ecs_meta_set_component (thanks @pfeodrippe!)
  • Fix potential buffer overflow with large compilers strings (thanks @apache-hb!)
  • Fix duplicate definition errors when using unity builds (thanks @apache-hb!)
  • Fix issue with sorting non-trivial components
  • Fix issue with OR/wildcard queries
  • Fix issue with overcounting nodata terms in query with OR terms

This version includes the following improvements:

  • [cpp] Don't rely on automatic registration of builtin components
  • [cpp] Improve robustness and flexibility of enum reflection (thanks @garrett-is-a-swann!)
  • [cpp] Add additional overloads that make use of enum reflection (thanks @RoyAwesome!)
  • [cpp] Add iter::field_at method, disallow usage of iter::field in each
  • [cpp] Change entity constructor to take entity_t instead of id_t
  • [cpp] Add pair overload to get_ref (thanks @TBlauwe!)
  • [cpp] Add missing get_mut singleton methods (thanks @Indra-db!)
  • [cpp] Improve performance of entity::children
  • [cpp] Remove static for improved compatibility with C++20 modules (thanks @alexv-ds!)
  • [cpp] Alow for creating owned flecs::world from custom C world
  • [cpp] Add term_index to flecs::iter (thanks @jpeletier!)
  • [cpp] Mark overridden methods with override (thanks @jpeletier!)
  • [queries] Add support for parsing special characters in entity names
  • [queries] Add support for matching empty tables for cached queries
  • [queries] Fix issue with query traversal that could cause duplicate results
  • [rules] Fix incorrectly initialized context in query engine
  • [observers] Add support for disabling observers
  • [observers] Add missing event propagation code paths
  • [pipelines] Add multi_threaded argument to readonly_begin
  • [core] Improve error messages for constraint violations
  • [core] Allow for setting component name through type_info_t::name
  • [core] Automatically add Module tag to parents of components (thanks @garrett-is-a-swann!)
  • [core] Rename of get_mut, ensure to ensure, make_alive
  • [core] Add new get_mut that doesn't add component
  • [core] Add ability to include user-defined header with compile-time settings
  • [core] Don't create intermediate tables when instantiating prefab children
  • [core] Fix uninitialized value in cleanup logic
  • [core] Add table type order check in sanitized mode
  • [core] Add ecs_get_build_info
  • [core] Implement Relationship, Target, Trait constraint traits
  • [core] Use destructive move semantics when move & move_ctor is not set (thanks @Indra-db!)
  • [core] Improve performance of ecs_children
  • [core] Add world-global parameter for specifying default query flags
  • [json] serialize prefabs when serializing world
  • [json] improve robustness when deserializing into world with missing reflection data
  • [json] Don't asert on invalid entity identifier in JSON deserializer
  • [json] Add query info JSON serializer
  • [json] Add query profiler
  • [json] Always serialize full path for parent fields
  • [rest] Add support for inspecting observers with REST API
  • [rest] Implement endpoint for capturing commands of a single frame
  • [doc] Merge COREDOC addon with doc addon
  • [monitor] Add frame_count to WorldSummary
  • [monitor] Add build info to WorldSummary
  • [doc] Fix incorrect comments in simple_module examples
  • [doc] Add code tabs and C# snippets to relationship manual (thanks @BeanCheeseBurrito!)
  • [doc] Fix inconsistent order_by docs
  • [doc] Fix headers and language example tabs in relationship manual
  • [doc] Fix issue with observer example in quickstart (thanks @lenis0012!)
  • [ci] Add deprecated CI platforms (thanks @waywardmonkeys!)
  • [ci] Fix warnings when using FLECS_USE_OS_ALLOC (thanks @waywardmonkeys!)
  • [ci] Fix issues with windows/clang64
  • [ci] Add test to make sure amalgamated files are updated
  • [ci] Fix asan issue with casting function pointers (thanks @darkuranium!)
  • [windows] Ensure windows version macro is set correctly for inet_pton (thanks @benjitrosch!)
  • [misc] Make ctx argument of world::atfini optional
  • [misc] Use fseek instead of rewind (thanks @waywardmonkeys!)
  • [misc] Add missing #ifndef which could cause macro redefinitions (thanks @Indra-db!)

Benchmark results
https://github.com/SanderMertens/ecs_benchmark/tree/4681e8606aa9204b97f6316d3611e9f0d2572852

Breaking changes

Known issues:
#844
#765
#714
#620
#478
#314

New Contributors

Full Changelog: v3.2.11...v3.2.12

Flecs v4.0.0-beta

21 May 06:07
e008ac2
Compare
Choose a tag to compare
Flecs v4.0.0-beta Pre-release
Pre-release

What is this?

This is the Flecs v4 beta release! 🎉

You can use this release to familiarize and play around with the new APIs and features before v4 comes out. The biggest difference between v3 and v4 is a new query engine that unifies filters, queries and rules in a single API.

What is a beta release?

Beta means that the v4 branch now has all the features that the final release will have! The next few weeks will be spent finding bugs, updating documentation, updating the Flecs demo's and on creating a migration guide.

What's new since v4.0.2-alpha

  • A new sparse component storage
  • Union relationships have been reimplemented for the v4 code base
  • On prefab instantiation, components are now copied to the instance instead of inherited.
  • New traits have been introduced to customize instantiation behavior
  • The iter and run query iteration callbacks have been replaced with a single run callback
  • OVERRIDE is renamed to AUTO_OVERRIDE
  • Flecs script assemblies have been renamed to templates
  • The existing query manual has been updated to v4
  • A new Flecs Query Language manual has been added that describes query DSL syntax
  • A new component traits manual has been added
  • Lots of C functions have been documented with doxygen
  • Bugfixes

This version does not work with the explorer because of a breaking change in the query DSL. To use the explorer with this release, use this URL: https://www.flecs.dev/explorer/v4?remote=true.

The release should be stable enough for experimentation.

What is missing?

  • There are a handful of known bugs that still need to be fixed
  • Performance testing hasn't finished yet
  • Documentation has not been updated yet

When will v4 come out?

The updated goal is to release in June.

Where can I share feedback?

Post v4 feedback in this discussion post: #1181 or on the Flecs discord server, whichever you prefer!

⚠️ Do not use this release in an actual project! ⚠️

Flecs v4.0.2-alpha

30 Apr 08:22
cf1a8ef
Compare
Choose a tag to compare
Flecs v4.0.2-alpha Pre-release
Pre-release

What is this?

This is another early preview of the upcoming v4 release! 🎉

You can use this release to familiarize and play around with the new APIs and features before v4 comes out. The biggest difference between v3 and v4 is a new query engine that unifies filters, queries and rules in a single API.

What's new since v4.0.1-alpha

  • A new Flecs Script parser with an improved syntax, new features and a new script manual!
  • A few tweaks to the query DSL that reduce complexity and make it (slightly) less verbose
  • Query fields are now indexed from zero! (so it.field(0) instead of it.field(1))
  • Lots of improvements to API ergonomics & removal of tech debt
  • Lots of bug fixes since the last alpha release

This version does not work with the explorer because of a breaking change in the query DSL. To use the explorer with the alpha, use this URL: https://www.flecs.dev/explorer/v4?remote=true.

The release should be stable enough for experimentation.

Flecs script example

// New: a cleaner syntax allows for more natural type descriptions
struct Position {
  x = f32
  y = f32
}

assembly CheckBox {
  prop checked = bool: false

  // New: conditional logic!
  if $checked {
    Image("checked.png") // New: improved anonymous entity notation
  } else {
    Image("unchecked.png")
  }
}

// New: new syntax that improves ergonomics of working with assemblies
CheckBox my_checkbox(checked: true) {
  Position: {x: 400, y: 300} // New: a more consistent way to specify components

  // Streamlined syntax for creating child entities
  Label my_lbl("Hello world") {
    Position: {x: 100, y: 0}
  }
}

Query DSL example

// Old
Item, Player($this:self|up(ContainedBy))
// New
Item, Player($this|self|up ContainedBy)

What is missing?

  • A big usability update to prefabs is still underway
  • There are a handful of known bugs that still need to be fixed
  • Performance testing hasn't finished yet
  • Documentation has not been updated yet

When will v4 come out?

The updated goal is to release around the end of May, with a beta release coming out in around two weeks.

Where can I share feedback?

Post v4 feedback in this discussion post: #1181 or on the Flecs discord server, whichever you prefer!

⚠️ Do not use this release in an actual project! ⚠️

Flecs v4.0.1-alpha

05 Apr 04:47
bb8ffca
Compare
Choose a tag to compare
Flecs v4.0.1-alpha Pre-release
Pre-release

What is this?

This is an early preview of the upcoming v4 release! 🎉

You can use this release to familiarize and play around with the new APIs and features before v4 comes out. The biggest difference between v3 and v4 is a new query engine that unifies filters, queries and rules in a single API.

Overview

  • All tests are passing on all platforms and compilers
  • The query API is mostly stable
  • Examples have been updated to the new APIs
  • Many parts of the API have been simplified
  • The release mostly works with the explorer and query editor

Code examples

// A system with query variables
world.system<Position>("SpaceshipsDockedToPlanet")
  .with<SpaceShip>()
  .with<DockedTo>("$obj")
  .with<Planet>().src("$obj")
  .each([](flecs::entity spaceship, Position& p) {
    // ...
  });
// By default queries are uncached. This is similar to a v3 filter/rule
world.query_builder<Position>()
  .with(flecs::ChildOf, "$parent")
  .each([](Position& p) {
    // ...
  });
// Adding .cached() enables caching, which is similar to a v3 query.
// Only the terms that are cacheable will be cached. This allows 
// for queries that are partially cached, which is not possible in v3.
auto q = world.query_builder<Position>()
  .with(flecs::ChildOf, "$parent")
  .cached()
  .build();
  
q.each([](Position& p) {
  // ...
});
// Queries can be named. This associates the query with an entity
// with the same name. Queries that are associated with an entity
// are cached. This means that by default all system queries enable 
// caching, just like in v3.
auto q = world.query_builder<Position>("Children")
  .with(flecs::ChildOf, "$parent")
  .build();

q.each([](Position& p) {
  // ...
});

// Queries that are associated with an entity need to be explicitly
// destructed. This is the same behavior as `flecs::entity`.
// Queries that are not associated with an entity are cleaned up
// when they go out of scope. This is the same behavior as
// `flecs::world` (RAII).
q.destruct();
flecs::world world_a;
{
  // World objects can now be copied. This just creates a handle to
  // the existing world, it doesn't create/copy a new world.
  flecs::world world_b = world_a;
}
void Move(ecs_iter_t *it) {
  Position *p = ecs_field(it, Position, 0); // Field indices now start from 0!
  Velocity *v = ecs_field(it, Velocity, 1);
  
  for (int i = 0; i < it->count; i ++) {
    p[i].x += v[i].x;
    p[i].y += v[i].y;
  }
}

The release should be stable enough for experimentation.

What is missing?

  • The APIs are not yet finalized. Big changes are still underway, especially in the C API
  • A few new features are still in development
  • There are a handful of known bugs that still need to be fixed
  • Performance testing hasn't finished yet
  • Documentation has not been updated yet

When will v4 come out?

There is still a lot that needs to happen before the release. The goal is to release around the end of April, with a higher probability of it being later than earlier.

Where can I share feedback?

Post v4 feedback in this discussion post: #1181 or on the Flecs discord server, whichever you prefer!

⚠️ Do not use this release in an actual project! ⚠️

Flecs v3.2.11

07 Feb 21:03
198607d
Compare
Choose a tag to compare

Highlights

  • Hytale is using Flecs as the backbone for their upcoming engine!
  • More than half of the contributions in this release are from the community ❤️
  • Work on Flecs 4.0 is well underway, with simpler query APIs and better performance! Follow progress here

Release notes

This version includes the following bugfixes:

  • Fix issue with parsing newlines in query strings
  • Fix issue with registration of nested types in module
  • Fix issue in rule engine with lookup variables and equality operators
  • Fix issue with rules that are partially trivial
  • Fix issue where a member with a missing MetaType wasn't correctly handled (thanks @ZeroErrors!)
  • Fix issue where query term with equality operator was incorrectly marked as trivial
  • Fix potential out of bounds read in rule engine
  • Fix JSON serialization error for labels with double quotes
  • Fix issue with evaluating R(_, _) and _(_, T) queries
  • Fix issues with not/optional operators and terms with any (_) source
  • Fix issue where rule compiler would not detect uninitialized lh of equality operator
  • Fix issue where ecs_ref_t could point to invalid component after table recycling
  • Fix issue in code that dedups events for multi-component observers
  • Fix issue where observer could access deleted id record during world cleanup

This version includes the following improvements:

  • [cpp] Add missing overloads for delete_with and remove_all (thanks @Charlie-83!)
  • [cpp] Add FLECS_CPP_NO_AUTO_REGISTRATION flag to disable automatic component registration
  • [cpp] Add flecs::string::contains
  • [cpp] Add support for associating a timer/tick source with a type (thanks @ZeroErrors!)
  • [cpp] Add missing const to entity_view methods (thanks @waywardmonkeys!)
  • [cpp] Add missing flecs::doc::get/set_color() functions (thanks @waywardmonkeys!)
  • [cpp] Mark explicit move ctors/operator= as noexcept (thanks @waywardmonkeys!)
  • [cpp] Remove redundant void arg of log function (thanks @waywardmonkeys!)
  • [query-dsl] Add support for R(A, B || C) syntax to DSL
  • [query] Fill out ecs_iter_t.system when using filters, queries and rules (thanks @BeanCheeseBurrito!)
  • [query] Improve string conversion of queries with equality operators
  • [rule] Skip empty ids for R(_, *) and *(_, T) queries
  • [json] Implement serializer for user-friendly JSON format
  • [json] Add option for serializing query field metadata
  • [rest] Fix issue where cached REST request would always return code 200
  • [rest] Add try parameter that prevents throwing HTTP error when trying out queries
  • [snapshot] Reduce copies when duplicating tables with non-POD components for snapshots (thanks @ZeroErrors!)
  • [strbuf] Simplify implementation of ecs_strbuf_t, improve performance
  • [http] Improve performance of ecs_http_server_request
  • [http] Enable caching of HTTP requests made from C API
  • [log] Don't mix writing to stderr/stdout in logging output
  • [log] Make output file used by logging functions configurable
  • [doc] Fix copy-paste issues with type names (thanks @waywardmonkeys!)
  • [doc] Fix relationship example by specifying inout (thanks @garrett-is-a-swann!)
  • [doc] Update Doxygen to v1.10.0 (thanks @ZeroErrors!)
  • [doc] Enable graphviz dot files in Doxygen (thanks @ZeroErrors!)
  • [doc] Change defgroup documents to use autobrief (thanks @ZeroErrors!)
  • [doc] Fix typos (thanks @waywardmonkeys!)
  • [doc] Fix typos and spelling errors (thanks @ZeroErrors!)
  • [doc] Fixed documentation link in quickstart addons section (thanks @DJLink!)
  • [doc] Remove spurious asterisk (thanks @waywardmonkeys!)
  • [doc] Use @code/@encode (thanks @waywardmonkeys!)
  • [doc] Fix grouping errors in C docs (thanks @waywardmonkeys!)
  • [doc] Link function names in doc comments (thanks @waywardmonkeys!)
  • [doc] Fix ecs_doc_get_name code samples (thanks @waywardmonkeys!)
  • [doc] Add tab widget for code snippets (thanks @ZeroErrors!)
  • [doc] Add Extermination Shock to readme
  • [doc] Add Hytale to readme
  • [doc] Improve doc addon docs (thanks @waywardmonkeys!)
  • [doc] Fix doxygen warnings (thanks @waywardmonkeys!)
  • [doc] Add missing doc.brief descriptions to flecs entities
  • [doc] Add C# example snippets to Quickstart, RestApi, System manuals (thanks @BeanCheeseBurrito!)
  • [ci] Update pages workflow actions (thanks @waywardmonkeys!)
  • [ci] Add macOS-14 Apple Silicon jobs (thanks @waywardmonkeys!)

Benchmark results
https://github.com/SanderMertens/ecs_benchmark/tree/4681e8606aa9204b97f6316d3611e9f0d2572852

Known issues:
#844
#765
#714
#620
#478
#314

New Contributors

Full Changelog: v3.2.10...v3.2.11