2015-08-23 03:40:49 +08:00
|
|
|
.. _index:
|
|
|
|
|
|
|
|
=============================
|
|
|
|
"libc++" C++ Standard Library
|
|
|
|
=============================
|
|
|
|
|
|
|
|
Overview
|
|
|
|
========
|
|
|
|
|
2017-01-26 01:00:30 +08:00
|
|
|
libc++ is a new implementation of the C++ standard library, targeting C++11 and
|
|
|
|
above.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
* Features and Goals
|
|
|
|
|
|
|
|
* Correctness as defined by the C++11 standard.
|
|
|
|
* Fast execution.
|
|
|
|
* Minimal memory use.
|
|
|
|
* Fast compile times.
|
|
|
|
* ABI compatibility with gcc's libstdc++ for some low-level features
|
|
|
|
such as exception objects, rtti and memory allocation.
|
|
|
|
* Extensive unit tests.
|
|
|
|
|
|
|
|
* Design and Implementation:
|
|
|
|
|
|
|
|
* Extensive unit tests
|
|
|
|
* Internal linker model can be dumped/read to textual format
|
|
|
|
* Additional linking features can be plugged in as "passes"
|
|
|
|
* OS specific and CPU specific code factored out
|
|
|
|
|
|
|
|
|
|
|
|
Getting Started with libc++
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 2
|
|
|
|
|
2018-09-06 23:05:43 +08:00
|
|
|
ReleaseNotes
|
2015-08-23 03:40:49 +08:00
|
|
|
UsingLibcxx
|
|
|
|
BuildingLibcxx
|
|
|
|
TestingLibcxx
|
|
|
|
|
2015-09-05 13:29:23 +08:00
|
|
|
|
2019-01-16 09:37:43 +08:00
|
|
|
.. toctree::
|
|
|
|
:hidden:
|
|
|
|
|
|
|
|
FeatureTestMacroTable
|
|
|
|
|
2015-08-23 03:40:49 +08:00
|
|
|
Current Status
|
|
|
|
--------------
|
|
|
|
|
|
|
|
After its initial introduction, many people have asked "why start a new
|
|
|
|
library instead of contributing to an existing library?" (like Apache's
|
|
|
|
libstdcxx, GNU's libstdc++, STLport, etc). There are many contributing
|
|
|
|
reasons, but some of the major ones are:
|
|
|
|
|
2015-09-05 14:50:03 +08:00
|
|
|
* From years of experience (including having implemented the standard
|
|
|
|
library before), we've learned many things about implementing
|
|
|
|
the standard containers which require ABI breakage and fundamental changes
|
|
|
|
to how they are implemented. For example, it is generally accepted that
|
|
|
|
building std::string using the "short string optimization" instead of
|
|
|
|
using Copy On Write (COW) is a superior approach for multicore
|
|
|
|
machines (particularly in C++11, which has rvalue references). Breaking
|
|
|
|
ABI compatibility with old versions of the library was
|
|
|
|
determined to be critical to achieving the performance goals of
|
|
|
|
libc++.
|
|
|
|
|
|
|
|
* Mainline libstdc++ has switched to GPL3, a license which the developers
|
|
|
|
of libc++ cannot use. libstdc++ 4.2 (the last GPL2 version) could be
|
|
|
|
independently extended to support C++11, but this would be a fork of the
|
|
|
|
codebase (which is often seen as worse for a project than starting a new
|
|
|
|
independent one). Another problem with libstdc++ is that it is tightly
|
|
|
|
integrated with G++ development, tending to be tied fairly closely to the
|
|
|
|
matching version of G++.
|
|
|
|
|
|
|
|
* STLport and the Apache libstdcxx library are two other popular
|
|
|
|
candidates, but both lack C++11 support. Our experience (and the
|
|
|
|
experience of libstdc++ developers) is that adding support for C++11 (in
|
|
|
|
particular rvalue references and move-only types) requires changes to
|
|
|
|
almost every class and function, essentially amounting to a rewrite.
|
|
|
|
Faced with a rewrite, we decided to start from scratch and evaluate every
|
|
|
|
design decision from first principles based on experience.
|
|
|
|
Further, both projects are apparently abandoned: STLport 5.2.1 was
|
|
|
|
released in Oct'08, and STDCXX 4.2.1 in May'08.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
Platform and Compiler Support
|
|
|
|
-----------------------------
|
|
|
|
|
2018-09-20 15:57:31 +08:00
|
|
|
libc++ is known to work on the following platforms, using gcc and
|
|
|
|
clang.
|
2015-08-23 03:40:49 +08:00
|
|
|
Note that functionality provided by ``<atomic>`` is only functional with clang
|
|
|
|
and GCC.
|
|
|
|
|
|
|
|
============ ==================== ============ ========================
|
|
|
|
OS Arch Compilers ABI Library
|
|
|
|
============ ==================== ============ ========================
|
[Docs] Modernize references to macOS
Summary:
This updates all places in documentation that refer to "Mac OS X", "OS X", etc.
to instead use the modern name "macOS" when no specific version number is
mentioned.
If a specific version is mentioned, this attempts to use the OS name at the time
of that version:
* Mac OS X for 10.0 - 10.7
* OS X for 10.8 - 10.11
* macOS for 10.12 - present
Reviewers: JDevlieghere
Subscribers: mgorny, christof, arphaman, cfe-commits, lldb-commits, libcxx-commits, llvm-commits
Tags: #clang, #lldb, #libc, #llvm
Differential Revision: https://reviews.llvm.org/D62654
llvm-svn: 362113
2019-05-31 00:46:22 +08:00
|
|
|
macOS i386, x86_64 Clang, GCC libc++abi
|
2015-08-23 03:40:49 +08:00
|
|
|
FreeBSD 10+ i386, x86_64, ARM Clang, GCC libcxxrt, libc++abi
|
|
|
|
Linux i386, x86_64 Clang, GCC libc++abi
|
|
|
|
============ ==================== ============ ========================
|
|
|
|
|
|
|
|
The following minimum compiler versions are strongly recommended.
|
|
|
|
|
2020-03-23 23:37:40 +08:00
|
|
|
* Clang 4.0 and above
|
Make GCC in C++03 Unsupported
Summary:
This patch make G++03 explicitly unsupported with libc++, as discussed on the mailing lists.
Below is the rational for this decision.
----------------------------------------------------------------------------------------------------
libc++ claims to support GCC with C++03 ("G++03"), and this is a problem for our users.
Our C++03 users are all using Clang. They must be. Less than 9% of the C++03 tests pass with GCC [1][2]. No non-trivial C++ program could work.
Attempting to support G++03 impacts our QoI considerably. Unlike Clang, G++03 offers almost no C++11 extensions. If we could remove all the fallbacks for G++03, it would mean libc++ could::
* Improve Correctness:
Every `#ifdef _LIBCPP_HAS_NO_<C++11-feature>` is a bug manifest. It exists to admit for deviant semantics.
* Achieve ABI stability between C++03 and C++11
Differences between our C++03 and C++Rest branches contain ABI bugs. For example `std::nullptr_t` and `std::function::operator()(...)` are currently incompatible between C++11 and C++03, but could be fixed.
* Decrease Compile Times and Memory Usage:
Writing efficient SFINAE requires C++11. Using alias templates, libc++ could reduce the number of instantiations it produces substantially.
* Decrease Binary Size
Similar to the last point, G++03 forces metaprogramming techniques that emit more debug information [3] [4]. Compared to libstdc++, debug information size increases of +10% are not uncommon.
Reviewers: ldionne, mclow.lists, EricWF
Reviewed By: ldionne, EricWF
Subscribers: zoecarver, aprantl, dexonsmith, arphaman, libcxx-commits, #libc
Differential Revision: https://reviews.llvm.org/D63154
llvm-svn: 363219
2019-06-13 08:37:25 +08:00
|
|
|
* GCC 5.0 and above.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
Make GCC in C++03 Unsupported
Summary:
This patch make G++03 explicitly unsupported with libc++, as discussed on the mailing lists.
Below is the rational for this decision.
----------------------------------------------------------------------------------------------------
libc++ claims to support GCC with C++03 ("G++03"), and this is a problem for our users.
Our C++03 users are all using Clang. They must be. Less than 9% of the C++03 tests pass with GCC [1][2]. No non-trivial C++ program could work.
Attempting to support G++03 impacts our QoI considerably. Unlike Clang, G++03 offers almost no C++11 extensions. If we could remove all the fallbacks for G++03, it would mean libc++ could::
* Improve Correctness:
Every `#ifdef _LIBCPP_HAS_NO_<C++11-feature>` is a bug manifest. It exists to admit for deviant semantics.
* Achieve ABI stability between C++03 and C++11
Differences between our C++03 and C++Rest branches contain ABI bugs. For example `std::nullptr_t` and `std::function::operator()(...)` are currently incompatible between C++11 and C++03, but could be fixed.
* Decrease Compile Times and Memory Usage:
Writing efficient SFINAE requires C++11. Using alias templates, libc++ could reduce the number of instantiations it produces substantially.
* Decrease Binary Size
Similar to the last point, G++03 forces metaprogramming techniques that emit more debug information [3] [4]. Compared to libstdc++, debug information size increases of +10% are not uncommon.
Reviewers: ldionne, mclow.lists, EricWF
Reviewed By: ldionne, EricWF
Subscribers: zoecarver, aprantl, dexonsmith, arphaman, libcxx-commits, #libc
Differential Revision: https://reviews.llvm.org/D63154
llvm-svn: 363219
2019-06-13 08:37:25 +08:00
|
|
|
The C++03 dialect is only supported for Clang compilers.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
C++ Dialect Support
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
* C++11 - Complete
|
2015-09-07 07:09:54 +08:00
|
|
|
* `C++14 - Complete <http://libcxx.llvm.org/cxx1y_status.html>`__
|
2018-09-20 15:57:31 +08:00
|
|
|
* `C++17 - In Progress <http://libcxx.llvm.org/cxx1z_status.html>`__
|
2015-09-07 07:09:54 +08:00
|
|
|
* `Post C++14 Technical Specifications - In Progress <http://libcxx.llvm.org/ts1z_status.html>`__
|
2019-01-16 09:37:43 +08:00
|
|
|
* :ref:`C++ Feature Test Macro Status <feature-status>`
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
Notes and Known Issues
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
This list contains known issues with libc++
|
|
|
|
|
|
|
|
* Building libc++ with ``-fno-rtti`` is not supported. However
|
|
|
|
linking against it with ``-fno-rtti`` is supported.
|
|
|
|
|
|
|
|
|
2015-09-07 07:22:02 +08:00
|
|
|
A full list of currently open libc++ bugs can be `found here`__.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
2017-02-17 16:37:03 +08:00
|
|
|
.. __: https://bugs.llvm.org/buglist.cgi?component=All%20Bugs&product=libc%2B%2B&query_format=advanced&resolution=---&order=changeddate%20DESC%2Cassigned_to%20DESC%2Cbug_status%2Cpriority%2Cbug_id&list_id=74184
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
Design Documents
|
|
|
|
----------------
|
|
|
|
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-14 06:12:02 +08:00
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
|
|
|
|
2017-05-05 01:08:54 +08:00
|
|
|
DesignDocs/AvailabilityMarkup
|
2016-12-28 12:58:52 +08:00
|
|
|
DesignDocs/DebugMode
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-14 06:12:02 +08:00
|
|
|
DesignDocs/CapturingConfigInfo
|
2015-10-14 08:22:05 +08:00
|
|
|
DesignDocs/ABIVersioning
|
2019-06-11 22:48:40 +08:00
|
|
|
DesignDocs/ExperimentalFeatures
|
2016-09-16 06:27:07 +08:00
|
|
|
DesignDocs/VisibilityMacros
|
2017-01-07 04:05:40 +08:00
|
|
|
DesignDocs/ThreadingSupportAPI
|
2018-07-25 10:53:53 +08:00
|
|
|
DesignDocs/FileTimeType
|
2019-01-16 09:37:43 +08:00
|
|
|
DesignDocs/FeatureTestMacros
|
2019-06-12 06:53:49 +08:00
|
|
|
DesignDocs/ExtendedCXX03Support
|
[libcxx] Capture configuration information when installing the libc++ headers
Summary:
Hi all,
This patch is a successor to D11963. However it has changed dramatically and I felt it would be best to start a new review thread.
Please read the design documentation added in this patch for a description of how it works.
Reviewers: mclow.lists, danalbert, jroelofs, EricWF
Subscribers: vkalintiris, rnk, ed, espositofulvio, asl, eugenis, cfe-commits
Differential Revision: http://reviews.llvm.org/D13407
llvm-svn: 250235
2015-10-14 06:12:02 +08:00
|
|
|
|
2015-08-23 03:40:49 +08:00
|
|
|
* `<atomic> design <http://libcxx.llvm.org/atomic_design.html>`_
|
|
|
|
* `<type_traits> design <http://libcxx.llvm.org/type_traits_design.html>`_
|
2015-09-07 07:09:54 +08:00
|
|
|
* `Notes by Marshall Clow`__
|
2015-08-23 03:40:49 +08:00
|
|
|
|
2015-09-07 07:09:54 +08:00
|
|
|
.. __: https://cplusplusmusings.wordpress.com/2012/07/05/clang-and-standard-libraries-on-mac-os-x/
|
2015-08-23 03:40:49 +08:00
|
|
|
|
2015-10-15 11:27:02 +08:00
|
|
|
Build Bots and Test Coverage
|
|
|
|
----------------------------
|
2015-09-05 14:50:03 +08:00
|
|
|
|
|
|
|
* `LLVM Buildbot Builders <http://lab.llvm.org:8011/console>`_
|
|
|
|
* `Apple Jenkins Builders <http://lab.llvm.org:8080/green/view/Libcxx/>`_
|
2017-05-04 15:40:23 +08:00
|
|
|
* `Windows Appveyor Builders <https://ci.appveyor.com/project/llvm-mirror/libcxx>`_
|
2015-10-15 11:27:02 +08:00
|
|
|
* `Code Coverage Results <http://efcs.ca/libcxx-coverage>`_
|
2015-09-05 14:50:03 +08:00
|
|
|
|
2015-08-23 03:40:49 +08:00
|
|
|
Getting Involved
|
|
|
|
================
|
|
|
|
|
2020-03-23 05:42:03 +08:00
|
|
|
First please review our `Developer's Policy <https://llvm.org/docs/DeveloperPolicy.html>`__
|
|
|
|
and `Getting started with LLVM <https://llvm.org/docs/GettingStarted.html>`__.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
**Bug Reports**
|
|
|
|
|
|
|
|
If you think you've found a bug in libc++, please report it using
|
2015-09-05 14:50:03 +08:00
|
|
|
the `LLVM Bugzilla`_. If you're not sure, you
|
2018-09-23 03:49:29 +08:00
|
|
|
can post a message to the `libcxx-dev mailing list`_ or on IRC.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
**Patches**
|
|
|
|
|
|
|
|
If you want to contribute a patch to libc++, the best place for that is
|
2020-03-23 05:42:03 +08:00
|
|
|
`Phabricator <https://llvm.org/docs/Phabricator.html>`_. Please add `libcxx-commits` as a subscriber.
|
2018-09-23 03:49:29 +08:00
|
|
|
Also make sure you are subscribed to the `libcxx-commits mailing list <http://lists.llvm.org/mailman/listinfo/libcxx-commits>`_.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
**Discussion and Questions**
|
|
|
|
|
2015-09-07 07:09:54 +08:00
|
|
|
Send discussions and questions to the
|
2018-09-23 03:49:29 +08:00
|
|
|
`libcxx-dev mailing list <http://lists.llvm.org/mailman/listinfo/libcxx-dev>`_.
|
2015-08-23 03:40:49 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2015-09-05 14:50:03 +08:00
|
|
|
Quick Links
|
|
|
|
===========
|
2020-03-23 05:42:03 +08:00
|
|
|
* `LLVM Homepage <https://llvm.org/>`_
|
2015-09-07 07:09:54 +08:00
|
|
|
* `libc++abi Homepage <http://libcxxabi.llvm.org/>`_
|
2017-02-17 16:37:03 +08:00
|
|
|
* `LLVM Bugzilla <https://bugs.llvm.org/>`_
|
2018-09-23 03:49:29 +08:00
|
|
|
* `libcxx-commits Mailing List`_
|
|
|
|
* `libcxx-dev Mailing List`_
|
2019-01-30 00:37:27 +08:00
|
|
|
* `Browse libc++ Sources <https://github.com/llvm/llvm-project/tree/master/libcxx/>`_
|