| # Abseil - C++ Common Libraries |
| |
| The repository contains the Abseil C++ library code. Abseil is an open-source |
| collection of C++ code (compliant to C++14) designed to augment the C++ |
| standard library. |
| |
| ## Table of Contents |
| |
| - [About Abseil](#about) |
| - [Quickstart](#quickstart) |
| - [Building Abseil](#build) |
| - [Support](#support) |
| - [Codemap](#codemap) |
| - [Releases](#releases) |
| - [License](#license) |
| - [Links](#links) |
| |
| <a name="about"></a> |
| ## About Abseil |
| |
| Abseil is an open-source collection of C++ library code designed to augment |
| the C++ standard library. The Abseil library code is collected from Google's |
| own C++ code base, has been extensively tested and used in production, and |
| is the same code we depend on in our daily coding lives. |
| |
| In some cases, Abseil provides pieces missing from the C++ standard; in |
| others, Abseil provides alternatives to the standard for special needs |
| we've found through usage in the Google code base. We denote those cases |
| clearly within the library code we provide you. |
| |
| Abseil is not meant to be a competitor to the standard library; we've |
| just found that many of these utilities serve a purpose within our code |
| base, and we now want to provide those resources to the C++ community as |
| a whole. |
| |
| <a name="quickstart"></a> |
| ## Quickstart |
| |
| If you want to just get started, make sure you at least run through the |
| [Abseil Quickstart](https://abseil.io/docs/cpp/quickstart). The Quickstart |
| contains information about setting up your development environment, downloading |
| the Abseil code, running tests, and getting a simple binary working. |
| |
| <a name="build"></a> |
| ## Building Abseil |
| |
| [Bazel](https://bazel.build) and [CMake](https://cmake.org/) are the official |
| build systems for Abseil. |
| |
| See the [quickstart](https://abseil.io/docs/cpp/quickstart) for more information |
| on building Abseil using the Bazel build system. |
| |
| If you require CMake support, please check the [CMake build |
| instructions](CMake/README.md) and [CMake |
| Quickstart](https://abseil.io/docs/cpp/quickstart-cmake). |
| |
| ## Support |
| |
| Abseil follows Google's [Foundational C++ Support |
| Policy](https://opensource.google/documentation/policies/cplusplus-support). See |
| [this |
| table](https://github.com/google/oss-policies-info/blob/main/foundational-cxx-support-matrix.md) |
| for a list of currently supported versions compilers, platforms, and build |
| tools. |
| |
| ## Codemap |
| |
| Abseil contains the following C++ library components: |
| |
| * [`base`](absl/base/) Abseil Fundamentals |
| <br /> The `base` library contains initialization code and other code which |
| all other Abseil code depends on. Code within `base` may not depend on any |
| other code (other than the C++ standard library). |
| * [`algorithm`](absl/algorithm/) |
| <br /> The `algorithm` library contains additions to the C++ `<algorithm>` |
| library and container-based versions of such algorithms. |
| * [`cleanup`](absl/cleanup/) |
| <br /> The `cleanup` library contains the control-flow-construct-like type |
| `absl::Cleanup` which is used for executing a callback on scope exit. |
| * [`container`](absl/container/) |
| <br /> The `container` library contains additional STL-style containers, |
| including Abseil's unordered "Swiss table" containers. |
| * [`debugging`](absl/debugging/) |
| <br /> The `debugging` library contains code useful for enabling leak |
| checks, and stacktrace and symbolization utilities. |
| * [`hash`](absl/hash/) |
| <br /> The `hash` library contains the hashing framework and default hash |
| functor implementations for hashable types in Abseil. |
| * [`memory`](absl/memory/) |
| <br /> The `memory` library contains memory management facilities that |
| augment C++'s `<memory>` library. |
| * [`meta`](absl/meta/) |
| <br /> The `meta` library contains compatible versions of type checks |
| available within C++14 and C++17 versions of the C++ `<type_traits>` library. |
| * [`numeric`](absl/numeric/) |
| <br /> The `numeric` library contains 128-bit integer types as well as |
| implementations of C++20's bitwise math functions. |
| * [`profiling`](absl/profiling/) |
| <br /> The `profiling` library contains utility code for profiling C++ |
| entities. It is currently a private dependency of other Abseil libraries. |
| * [`status`](absl/status/) |
| <br /> The `status` contains abstractions for error handling, specifically |
| `absl::Status` and `absl::StatusOr<T>`. |
| * [`strings`](absl/strings/) |
| <br /> The `strings` library contains a variety of strings routines and |
| utilities, including a C++14-compatible version of the C++17 |
| `std::string_view` type. |
| * [`synchronization`](absl/synchronization/) |
| <br /> The `synchronization` library contains concurrency primitives (Abseil's |
| `absl::Mutex` class, an alternative to `std::mutex`) and a variety of |
| synchronization abstractions. |
| * [`time`](absl/time/) |
| <br /> The `time` library contains abstractions for computing with absolute |
| points in time, durations of time, and formatting and parsing time within |
| time zones. |
| * [`types`](absl/types/) |
| <br /> The `types` library contains non-container utility types, like a |
| C++14-compatible version of the C++17 `std::optional` type. |
| * [`utility`](absl/utility/) |
| <br /> The `utility` library contains utility and helper code. |
| |
| ## Releases |
| |
| Abseil recommends users "live-at-head" (update to the latest commit from the |
| master branch as often as possible). However, we realize this philosophy doesn't |
| work for every project, so we also provide [Long Term Support |
| Releases](https://github.com/abseil/abseil-cpp/releases) to which we backport |
| fixes for severe bugs. See our [release |
| management](https://abseil.io/about/releases) document for more details. |
| |
| ## License |
| |
| The Abseil C++ library is licensed under the terms of the Apache |
| license. See [LICENSE](LICENSE) for more information. |
| |
| ## Links |
| |
| For more information about Abseil: |
| |
| * Consult our [Abseil Introduction](https://abseil.io/about/intro) |
| * Read [Why Adopt Abseil](https://abseil.io/about/philosophy) to understand our |
| design philosophy. |
| * Peruse our |
| [Abseil Compatibility Guarantees](https://abseil.io/about/compatibility) to |
| understand both what we promise to you, and what we expect of you in return. |