You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
jianglk.darker
7ee447c011
|
4 months ago | |
---|---|---|
.. | ||
.clang-format | 4 months ago | |
Android.bp | 4 months ago | |
README.md | 4 months ago | |
future_test.cpp | 4 months ago | |
small_map_test.cpp | 4 months ago | |
small_vector_test.cpp | 4 months ago | |
static_vector_test.cpp | 4 months ago |
README.md
FTL
FTL is a template library shared by SurfaceFlinger and InputFlinger, inspired by and supplementing the C++ Standard Library. The intent is to fill gaps for areas not (yet) covered—like cache-efficient data structures and lock-free concurrency primitives—and implement proposals that are missing or experimental in Android's libc++ branch. The design takes some liberties with standard compliance, notably assuming that exceptions are disabled.
Tests
atest ftl_test
Style
- Based on Google C++ Style.
- Informed by C++ Core Guidelines.
Naming conventions are as follows:
PascalCase
- Types and aliases, except standard interfaces.
- Template parameters, including non-type ones.
snake_case
- Variables, and data members with trailing underscore.
- Functions, free and member alike.
- Type traits, with standard
_t
and_v
suffixes.
kCamelCase
- Enumerators and
constexpr
constants with static storage duration.
- Enumerators and
MACRO_CASE
- Macros, with
FTL_
prefix unless#undef
ed.
- Macros, with
Template parameter packs are named with the following convention:
typename T, typename... Ts
typename Arg, typename... Args
std::size_t I, std::size_t... Is
std::size_t Size, std::size_t... Sizes
The details
namespace contains implementation details.