EASTL stands for Electronic Arts Standard Template Library. It is a C++ template library of containers, algorithms, and iterators useful for runtime and tool development across multiple platforms. It is a fairly extensive and robust implementation of such a library and has an emphasis on high performance above all other considerations.
- renamed many functions for my own codingstyle (push_back to pushBack, etc)
- vector-implementation:
- Fixed a bug when inserting elements referenced to own array, BUT ONLY WHEN EXCEPTIONS ARE DISABLED! with exceptions the error is NOT fixed (electronicarts/EASTL#524)
- growth-factor is NOT 2.0 but 1.618 (https://blog.demofox.org/2016/05/18/who-cares-about-dynamic-array-growth-strategies/)
- hash-function for float/double/..
- in functional.h use bit_cast and not static_cast as the later would map all values between 0..1 to the same value for example (electronicarts/EASTL#538)
- in string-view use manual search method to guarantee const-expr handling
- in string-view.h add manual search method to find-function
- added pattern-defeating-quicksort
- from https://github.com/wolfpld/tracy/blob/da60684b9f61b34afa5aa243a7838d6e79096783/server/TracyVector.hpp use short_ptr and uint8_t for capacity (expressed in powers of two) to get the structure from 24bytes to 11bytes
If you are familiar with the C++ STL or have worked with other templated container/algorithm libraries, you probably don't need to read this. If you have no familiarity with C++ templates at all, then you probably will need more than this document to get you up to speed. In this case, you need to understand that templates, when used properly, are powerful vehicles for the ease of creation of optimized C++ code. A description of C++ templates is outside the scope of this documentation, but there is plenty of such documentation on the Internet.
EASTL is suitable for any tools and shipping applications where the functionality of EASTL is useful. Modern compilers are capable of producing good code with templates and many people are using them in both current generation and future generation applications on multiple platforms from embedded systems to servers and mainframes.
You can download and install EASTL using the Conan package manager:
conan install eastl/3.15.00@
The EASTL package in conan is kept up to date by Conan team members and community contributors. If the version is out-of-date, please create an issue or pull request on the Conan Center Index repository.
You can download and install EASTL using the vcpkg dependency manager:
git clone https://github.com/Microsoft/vcpkg.git
cd vcpkg
./bootstrap-vcpkg.sh
./vcpkg integrate install
vcpkg install eastl
The EASTL port in vcpkg is kept up to date by Microsoft team members and community contributors. If the version is out of date, please create an issue or pull request on the vcpkg repository.
Please see EASTL Introduction.
Please see CONTRIBUTING.md for details on compiling and testing the source.
EASTL was created by Paul Pedriana and he maintained the project for roughly 10 years.
EASTL was subsequently maintained by Roberto Parolin for more than 8 years. He was the driver and proponent for getting EASTL opensourced. Rob was a mentor to all members of the team and taught us everything we ever wanted to know about C++ spookyness.
After Rob, maintenance of EASTL passed to Max Winkler for roughly a year, until landing with its current maintainer Liam Mitchell.
Significant EASTL contributions were made by (in alphabetical order):
- Avery Lee
- Colin Andrews
- JP Flouret
- Liam Mitchell
- Matt Newport
- Max Winkler
- Paul Pedriana
- Roberto Parolin
- Simon Everett
- Frostbite - Electronic Arts - [https://www.ea.com/frostbite]
Modified BSD License (3-Clause BSD license) see the file LICENSE in the project root.