blob: 0bf24b9821503b4ff851ade09662e16dcb67d6a5 [file] [log] [blame]
Hans Wennborg003a9982019-07-18 11:51:05 +00001=========================================
Tom Stellard688b1e22022-02-01 23:29:29 -08002Libc++ 15.0.0 (In-Progress) Release Notes
Hans Wennborg003a9982019-07-18 11:51:05 +00003=========================================
Louis Dionne42222072018-09-06 14:46:22 +00004
5.. contents::
6 :local:
7 :depth: 2
8
Hans Wennborg3329a842018-09-10 08:57:12 +00009Written by the `Libc++ Team <https://libcxx.llvm.org>`_
Louis Dionne42222072018-09-06 14:46:22 +000010
11.. warning::
12
Tom Stellard688b1e22022-02-01 23:29:29 -080013 These are in-progress notes for the upcoming libc++ 15 release.
Louis Dionne42222072018-09-06 14:46:22 +000014 Release notes for previous releases can be found on
Hans Wennborg3329a842018-09-10 08:57:12 +000015 `the Download Page <https://releases.llvm.org/download.html>`_.
Louis Dionne42222072018-09-06 14:46:22 +000016
17Introduction
18============
19
20This document contains the release notes for the libc++ C++ Standard Library,
Tom Stellard688b1e22022-02-01 23:29:29 -080021part of the LLVM Compiler Infrastructure, release 15.0.0. Here we describe the
Louis Dionne42222072018-09-06 14:46:22 +000022status of libc++ in some detail, including major improvements from the previous
23release and new feature work. For the general LLVM release notes, see `the LLVM
Hans Wennborg3329a842018-09-10 08:57:12 +000024documentation <https://llvm.org/docs/ReleaseNotes.html>`_. All LLVM releases may
25be downloaded from the `LLVM releases web site <https://llvm.org/releases/>`_.
Louis Dionne42222072018-09-06 14:46:22 +000026
27For more information about libc++, please see the `Libc++ Web Site
Hans Wennborg3329a842018-09-10 08:57:12 +000028<https://libcxx.llvm.org>`_ or the `LLVM Web Site <https://llvm.org>`_.
Louis Dionne42222072018-09-06 14:46:22 +000029
Hans Wennborgfc14f4e2020-01-15 10:02:56 +010030Note that if you are reading this file from a Git checkout or the
Louis Dionne42222072018-09-06 14:46:22 +000031main Libc++ web page, this document applies to the *next* release, not
32the current one. To see the release notes for a specific release, please
Hans Wennborg3329a842018-09-10 08:57:12 +000033see the `releases page <https://llvm.org/releases/>`_.
Louis Dionne42222072018-09-06 14:46:22 +000034
Tom Stellard688b1e22022-02-01 23:29:29 -080035What's New in Libc++ 15.0.0?
Hans Wennborg003a9982019-07-18 11:51:05 +000036============================
Louis Dionne42222072018-09-06 14:46:22 +000037
38New Features
39------------
40
Louis Dionne14918c82021-10-18 13:58:31 -040041API Changes
42-----------
Mark de Wever494905b2021-06-09 20:26:34 +020043
Louis Dionne15b1cdf2022-02-07 14:52:17 -050044- The ``_LIBCPP_ABI_UNSTABLE`` macro has been removed in favour of setting
45 ``_LIBCPP_ABI_VERSION=2``. This should not have any impact on users because
46 they were not supposed to set ``_LIBCPP_ABI_UNSTABLE`` manually, however we
47 still feel that it is worth mentioning in the release notes in case some users
48 had been doing it.
49
Joe Loser8fcb1d92021-10-28 15:38:02 -040050ABI Changes
51-----------
52
Louis Dionne9bb7cf42021-09-08 12:57:58 -040053- The ``_LIBCPP_ABI_USE_CXX03_NULLPTR_EMULATION`` macro controlling whether we use an
54 emulation for ``std::nullptr_t`` in C++03 mode has been removed. After this change,
55 ``_LIBCPP_ABI_USE_CXX03_NULLPTR_EMULATION`` will not be honoured anymore and there
56 will be no way to opt back into the C++03 emulation of ``std::nullptr_t``.
57
Louis Dionne14918c82021-10-18 13:58:31 -040058Build System Changes
59--------------------
Louis Dionne6e1a6532022-02-08 11:38:29 -050060
61- Support for standalone builds have been entirely removed from libc++, libc++abi and
62 libunwind. Please use :ref:`these instructions <build instructions>` for building
63 libc++, libc++abi and/or libunwind.