mike919192 c13d01319e etl array checks (#1188)
* Regression fix: Support zero arguments emplace() in etl::optional (#1183)

* Added coderabbitai configuration

* Added builtin mem function tests

* Modified etl::typed_storage

* Modified etl::typed_storage

# Conflicts:
#	include/etl/alignment.h

* Added ETL_NOEXCEPT and ETL_NOEXCEPT_IF_NO_THROW

* Added etl::typed_storage_ext and swap for same

* Added etl::typed_storage_ext and swap for same

# Conflicts:
#	include/etl/alignment.h

* Added release notes

* Fixes to GCC -O2 errors

* Changed char* parameters to value_type* parameters

* Fixed compilation issues for const containers unit tests

* Added automatic selection of __builtin_memxxx functions for GCC and clang

* Added enhanced coderabbit configuration

* Updated version and release notes

* Disabled constexpr const container tests for C++11

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Updated version and release notes

* feat: removed unreachable break statements (#1169)

* Updated version and release notes

* Modified etl::typed_storage

# Conflicts:
#	include/etl/alignment.h

* Support zero arguments emplace() in etl::optional

For non-fundamental types, a recent change in etl::optional was
introduced that doesn't support zero arguments emplace() anymore.

This change fixes it and adds the respective test.

---------

Co-authored-by: John Wellbelove <john.wellbelove@asterconsulting.co.uk>
Co-authored-by: Drew Rife <darife@jlg.com>

* Fix etl::typed_storage by supporting omitted destructors (#1182)

* Added coderabbitai configuration

* Added builtin mem function tests

* Modified etl::typed_storage

* Modified etl::typed_storage

# Conflicts:
#	include/etl/alignment.h

* Added ETL_NOEXCEPT and ETL_NOEXCEPT_IF_NO_THROW

* Added etl::typed_storage_ext and swap for same

* Added etl::typed_storage_ext and swap for same

# Conflicts:
#	include/etl/alignment.h

* Added release notes

* Fixes to GCC -O2 errors

* Changed char* parameters to value_type* parameters

* Fixed compilation issues for const containers unit tests

* Added automatic selection of __builtin_memxxx functions for GCC and clang

* Added enhanced coderabbit configuration

* Updated version and release notes

* Disabled constexpr const container tests for C++11

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Attempted fixes for MacOS compilation

* Updated version and release notes

* feat: removed unreachable break statements (#1169)

* Updated version and release notes

* Modified etl::typed_storage

# Conflicts:
#	include/etl/alignment.h

* Fix etl::typed_storage by supporting omitted destructors

In a recent change to alignment.h, the etl::typed_storage was
changed in a way that in case of an already constructed object,
the object is created via assignment.

However, this contradicts the original use case that led to
etl::typed_storage in the first place:
https://github.com/ETLCPP/etl/pull/1023

The goal is to omit destructors (and at the same time support
classes with deleted assignment operators), so they can be optimized out
at link time.

This change reverts commit ac7b268 to restore the original
functionality and changes the test to reflect the original
use case.

* Fix missing create() in non-C++11 typed_storage_ext constructor

* Typo fix

---------

Co-authored-by: John Wellbelove <john.wellbelove@asterconsulting.co.uk>
Co-authored-by: Drew Rife <darife@jlg.com>
Co-authored-by: John Wellbelove <jwellbelove@users.noreply.github.com>

* removed navis file from project

* Updated version and release notes

* Removed forced unsigned int cast in type_def bit-shift operators (#1178)

* Removed UB in type_def bit-shift operators

* Changed shift operators to allow both signed and unsigned operands for shifts
This allows the library user to explicitly use unsigned values to avoid UB

* Fixed constexpr errors for CPP11

* Changed is_arithmetic checks to use is_integral since valid shifts require integral operands

* Removed need for CPP11 since changes are CPP03 compatible

* Delete project navis files

* Add force CI check on piull requests

* Removed ETL_NOEXCEPT from delegate operator(), call_if(), and call_or()

Removed ETL_NOEXCEPT from closureoperator(), call_if(), and call_or()

* Updated version and release notes

* Updated version and release notes

* Remove noexcept from delegate method stubs. (#1185)

In addition to removing noexcept from call_if, this is also needed to prevent
an abort when cancelling a pthread that is executing a delegate.

* Updated version and release notes

* Re architect the extra checks

* Add CHECK_EXTRA

* Fix newline at end of file

* The check index macro also needs to be defined to throw

* Remove ETL_VERBOSE_ERRORS macros

---------

Co-authored-by: Roland Reichwein <Roland.Reichwein@bmw.de>
Co-authored-by: John Wellbelove <john.wellbelove@asterconsulting.co.uk>
Co-authored-by: Drew Rife <darife@jlg.com>
Co-authored-by: John Wellbelove <jwellbelove@users.noreply.github.com>
Co-authored-by: David Ockey <2897027+ockeydockey@users.noreply.github.com>
Co-authored-by: Marco Nilsson <marco@zyax.se>
2025-10-08 10:22:54 +01:00
.circleci Resolve 0U ambiguity in string utility tests 2020-08-02 15:14:52 +01:00
.devcontainer Add Devcontainer configurations (#1093) 2025-05-22 09:44:18 +01:00
.github Add force CI check on piull requests 2025-09-11 18:21:54 +01:00
arduino Updated version and release notes 2025-09-13 08:28:22 +01:00
cmake Fix cmake helper functions collision (#1065) 2025-04-30 16:55:57 +01:00
examples Removed releaser and destroyer in favour of lambdas and similar 2025-08-19 16:01:46 +01:00
images Coverty shield URLs 2024-07-30 13:36:08 +01:00
include/etl etl array checks (#1188) 2025-10-08 10:22:54 +01:00
scripts Updated release notes and version 2025-08-19 18:50:57 +01:00
subprojects Update test sources in meson build (#604) 2022-10-19 12:22:52 +01:00
support Updated version and release notes 2025-09-13 08:28:22 +01:00
test etl array checks (#1188) 2025-10-08 10:22:54 +01:00
uml Re-committed UML diagrams after HD crash 2024-03-04 12:57:02 +00:00
zephyr Workaround for link libraries call on Zephyr platform (#1145) 2025-07-10 10:17:01 +01:00
.clang-format Fix .clang-format (#1177) 2025-09-06 14:12:34 +01:00
.coderabbit.yaml Fix .clang-format (#1177) 2025-09-06 14:12:34 +01:00
.gitattributes Merge branch 'hotfix/issue-303-etl-not-compatible-with-arduino-ide' into development 2020-12-08 13:19:42 +00:00
.gitignore Rebased on development 2025-09-20 11:25:09 +01:00
.gitlab-ci.yml Update cmake & meson version handling (#522) 2022-04-08 09:37:21 +02:00
appveyor.yml Removed appveyor notification for Slack 2025-04-02 12:59:06 +01:00
CMakeLists.txt Restore CMake < 3.14 compatibility (#1098) 2025-05-22 10:06:06 +01:00
CONTRIBUTING.md Cleanup fixes for C++03 (#1089) 2025-05-13 21:21:50 +01:00
Converting header guards.txt Added instructions and scripts the convert ETL header guards 2025-07-27 11:23:20 +01:00
Doxyfile Feature/add pair functors (#610) 2022-10-19 12:20:42 +01:00
library.json Updated version and release notes 2025-09-13 08:28:22 +01:00
library.properties Updated version and release notes 2025-09-13 08:28:22 +01:00
LICENSE Update LICENSE 2024-01-10 08:51:03 +00:00
meson_options.txt Update test sources in meson build (#604) 2022-10-19 12:22:52 +01:00
meson.build fix set of ETL_NO_STL flag (#628) 2022-11-07 14:53:58 +00:00
README.md Update README.md 2025-07-13 10:19:09 +01:00
todo.txt Merge remote-tracking branch 'origin/feature/etl__make_string' into development 2019-12-04 20:55:18 +00:00
version.txt Updated version and release notes 2025-09-13 08:28:22 +01:00

Embedded Template Library (ETL)

GitHub release (latest by date) Release date Standard License GitHub contributors GitHub forks GitHub Repo stars

CI Build status

CI CI CI CI CI CI

CI CI CI CI CI CI

Codacy Badge

Project documentation

Motivation

C++ is a powerful language for embedded systems development, with templates offering a great deal of flexibility and type safety. While the C++ Standard Library provides a wealth of well-tested functionality, its often not well suited to environments with strict deterministic behavior and limited resources.

In many embedded applications, dynamic memory allocation is discouraged or outright prohibited, making standard STL containers and many other components impractical or unusable.

Whats needed is a template library specifically designed for embedded systems — one that allows developers to define fixed or maximum sizes for containers and other objects at compile time. Additionally, since many embedded toolchains still lack full support for standards beyond C++03, it's valuable to have access to a library that backports select features from later versions of the C++ Standard Library.

About the ETL

The Embedded Template Library (ETL) is not intended as a full replacement for the C++ Standard Template Library (STL), but rather as a complementary solution tailored specifically for embedded systems.

Its design goals include:

  • Providing a set of containers with fixed or maximum sizes defined at compile-time.

  • Offering APIs that closely resemble those of the STL, enabling familiar and consistent usage.

  • Maintaining compatibility with C++98 while implementing many features introduced in later standards (C++11/14/17/20/23) where possible.

  • Ensuring deterministic behavior, which is critical in real-time and resource-constrained environments.

  • Introducing additional components and utilities useful in embedded contexts but absent from the STL.

The ETL avoids dynamic memory allocation entirely; the heap is never used. All non-intrusive containers have a fixed capacity, allowing memory requirements to be fully determined at compile-time. This makes the ETL ideal for lower-resource embedded applications where predictability, performance, and memory control are essential.

The library is compatible with any compiler that supports C++03 or later.

Help on integrating the ETL with your project may be found here.

Key features of the ETL

  • Actively Maintained: Developed and maintained on GitHub since 2014.

  • Open Source: MIT licensed.

  • No STL Dependency: Designed to operate independently of the C++ Standard Template Library.

  • No Dynamic Memory Allocation: All storage is allocated either at compile-time or on the stack; heap usage is entirely avoided.

  • RTTI and Virtual Functions: No runtime type information (RTTI) is required. Virtual functions are used sparingly and only when strictly necessary.

  • Header-Only Library: All functionality is provided via header files; No separate compilation needed.

  • Fixed-Capacity Containers: Offers STL-like containers with fixed or maximum capacity, plus additional non-standard container types.

  • Cache Efficiency: Containers use contiguous memory layouts for optimal cache performance.

  • Compact Codebase: Shared base classes (based on type) help reduce overall container code size.

  • Compile-Time Features:

    • Templated compile-time constants
    • Template-based design pattern base classes (e.g., Visitor, Observer)
    • Type-safe smart enumerations
    • Type-safe typedefs and constants
  • Embedded System Frameworks:

    • Message routing
    • Finite state machines
    • Task scheduling
  • C++11 Backports: Implements many C++11 features (type traits, algorithms, containers) for use in C++03 environments.

  • Utilities:

    • CRC calculations (8, 16, 32 & 64-bit)
    • Checksums and hash functions
    • Variants (type-safe unions)
    • Extensive template support utilities
  • Robust Error Handling: Configurable error checking using asserts, exceptions, error handlers, or no checks; users choice.

  • Thoroughly Tested:

    • Over 10,000 unit tests
    • Tested with Visual Studio 2022, GCC 12, and Clang 14
    • Continuous integration via GitHub Actions.
  • Readable and Well-Documented: Clean, maintainable source code with clear documentation.

  • Support: Free email support available. A Slack group is available. Paid support on request.

  • Archived: A snapshot of the ETL is preserved in the Arctic Code Vault for long-term digital preservation.

Any help porting the library to work under different platforms and compilers would be gratefully received. I am especially interested in people who are using Keil, IAR, Green Hills, TI Code Composer etc, bare metal or RTOS, and DSPs.

See (https://www.etlcpp.com) for up-to-date information.

Installing this library

You can find the setup steps here.

CMake

One way to use this library is to drop it somewhere in your project directory and then make the library available by using add_subdirectory

add_subdirectory(etl)
add_executable(foo main.cpp)
target_link_libraries(foo PRIVATE etl::etl)

If ETL library is used as a Git submodule it may require additional configuration for proper ETL version resolution by allowing the lookup for Git folder outside of the library root directory.

set(GIT_DIR_LOOKUP_POLICY ALLOW_LOOKING_ABOVE_CMAKE_SOURCE_DIR)
add_subdirectory(etl)

If you want to install this library with CMake, you can perform the following steps. On Linux, super user rights might be required to install the library, so it might be necessary to add sudo before the last command:

git clone https://github.com/ETLCPP/etl.git
cd etl
git checkout <targetVersion>
cmake -B build .
cmake --install build/

After the library has been installed, you can use find_package to use the library. Replace <majorVersionRequirement> with your desired major version:

find_package(etl <majorVersionRequirement>)
add_executable(foo main.cpp)
target_link_libraries(foo PRIVATE etl::etl)

Alternatively you can use FetchContent, replacing <targetVersion> with the version to install based on a git tag:

Include(FetchContent)

FetchContent_Declare(
  etl
  GIT_REPOSITORY https://github.com/ETLCPP/etl
  GIT_TAG        <targetVersion>
)

FetchContent_MakeAvailable(etl)

add_executable(foo main.cpp)
target_link_libraries(foo PRIVATE etl::etl)

Arduino library

The content of this repo is available as a library in the Arduino IDE (search for the "Embedded Template Library" in the IDE library manager). The Arduino library repository is available at https://github.com/ETLCPP/etl-arduino, see there for more details.