1.. _using-libcxx:
2
3============
4Using libc++
5============
6
7.. contents::
8  :local:
9
10Usually, libc++ is packaged and shipped by a vendor through some delivery vehicle
11(operating system distribution, SDK, toolchain, etc) and users don't need to do
12anything special in order to use the library.
13
14This page contains information about configuration knobs that can be used by
15users when they know libc++ is used by their toolchain, and how to use libc++
16when it is not the default library used by their toolchain.
17
18
19Using a different version of the C++ Standard
20=============================================
21
22Libc++ implements the various versions of the C++ Standard. Changing the version of
23the standard can be done by passing ``-std=c++XY`` to the compiler. Libc++ will
24automatically detect what Standard is being used and will provide functionality that
25matches that Standard in the library.
26
27.. code-block:: bash
28
29  $ clang++ -std=c++17 test.cpp
30
31.. warning::
32  Using ``-std=c++XY`` with a version of the Standard that has not been ratified yet
33  is considered unstable. Libc++ reserves the right to make breaking changes to the
34  library until the standard has been ratified.
35
36
37Enabling experimental C++ Library features
38==========================================
39
40Libc++ provides implementations of some experimental features. Experimental features
41are either Technical Specifications (TSes) or official features that were voted to
42the Standard but whose implementation is not complete or stable yet in libc++. Those
43are disabled by default because they are neither API nor ABI stable. However, the
44``-fexperimental-library`` compiler flag can be defined to turn those features on.
45
46.. warning::
47  Experimental libraries are experimental.
48    * The contents of the ``<experimental/...>`` headers and the associated static
49      library will not remain compatible between versions.
50    * No guarantees of API or ABI stability are provided.
51    * When the standardized version of an experimental feature is implemented,
52      the experimental feature is removed two releases after the non-experimental
53      version has shipped. The full policy is explained :ref:`here <experimental features>`.
54
55.. note::
56  On compilers that do not support the ``-fexperimental-library`` flag, users can
57  define the ``_LIBCPP_ENABLE_EXPERIMENTAL`` macro and manually link against the
58  appropriate static library (usually shipped as ``libc++experimental.a``) to get
59  access to experimental library features.
60
61
62Using libc++ when it is not the system default
63==============================================
64
65On systems where libc++ is provided but is not the default, Clang provides a flag
66called ``-stdlib=`` that can be used to decide which standard library is used.
67Using ``-stdlib=libc++`` will select libc++:
68
69.. code-block:: bash
70
71  $ clang++ -stdlib=libc++ test.cpp
72
73On systems where libc++ is the library in use by default such as macOS and FreeBSD,
74this flag is not required.
75
76
77.. _alternate libcxx:
78
79Using a custom built libc++
80===========================
81
82Most compilers provide a way to disable the default behavior for finding the
83standard library and to override it with custom paths. With Clang, this can
84be done with:
85
86.. code-block:: bash
87
88  $ clang++ -nostdinc++ -nostdlib++           \
89            -isystem <install>/include/c++/v1 \
90            -L <install>/lib                  \
91            -Wl,-rpath,<install>/lib          \
92            -lc++                             \
93            test.cpp
94
95The option ``-Wl,-rpath,<install>/lib`` adds a runtime library search path,
96which causes the system's dynamic linker to look for libc++ in ``<install>/lib``
97whenever the program is loaded.
98
99GCC does not support the ``-nostdlib++`` flag, so one must use ``-nodefaultlibs``
100instead. Since that removes all the standard system libraries and not just libc++,
101the system libraries must be re-added manually. For example:
102
103.. code-block:: bash
104
105  $ g++ -nostdinc++ -nodefaultlibs           \
106        -isystem <install>/include/c++/v1    \
107        -L <install>/lib                     \
108        -Wl,-rpath,<install>/lib             \
109        -lc++ -lc++abi -lm -lc -lgcc_s -lgcc \
110        test.cpp
111
112
113GDB Pretty printers for libc++
114==============================
115
116GDB does not support pretty-printing of libc++ symbols by default. However, libc++ does
117provide pretty-printers itself. Those can be used as:
118
119.. code-block:: bash
120
121  $ gdb -ex "source <libcxx>/utils/gdb/libcxx/printers.py" \
122        -ex "python register_libcxx_printer_loader()" \
123        <args>
124
125
126.. _assertions-mode:
127
128Enabling the "safe libc++" mode
129===============================
130
131Libc++ contains a number of assertions whose goal is to catch undefined behavior in the
132library, usually caused by precondition violations. Those assertions do not aim to be
133exhaustive -- instead they aim to provide a good balance between safety and performance.
134In particular, these assertions do not change the complexity of algorithms. However, they
135might, in some cases, interfere with compiler optimizations.
136
137By default, these assertions are turned off. Vendors can decide to turn them on while building
138the compiled library by defining ``LIBCXX_ENABLE_ASSERTIONS=ON`` at CMake configuration time.
139When ``LIBCXX_ENABLE_ASSERTIONS`` is used, the compiled library will be built with assertions
140enabled, **and** user code will be built with assertions enabled by default. If
141``LIBCXX_ENABLE_ASSERTIONS=OFF`` at CMake configure time, the compiled library will not contain
142assertions and the default when building user code will be to have assertions disabled.
143As a user, you can consult your vendor to know whether assertions are enabled by default.
144
145Furthermore, independently of any vendor-selected default, users can always control whether
146assertions are enabled in their code by defining ``_LIBCPP_ENABLE_ASSERTIONS=0|1`` before
147including any libc++ header (we recommend passing ``-D_LIBCPP_ENABLE_ASSERTIONS=X`` to the
148compiler). Note that if the compiled library was built by the vendor without assertions,
149functions compiled inside the static or shared library won't have assertions enabled even
150if the user defines ``_LIBCPP_ENABLE_ASSERTIONS=1`` (the same is true for the inverse case
151where the static or shared library was compiled **with** assertions but the user tries to
152disable them). However, most of the code in libc++ is in the headers, so the user-selected
153value for ``_LIBCPP_ENABLE_ASSERTIONS`` (if any) will usually be respected.
154
155When an assertion fails, the program is aborted through a special verbose termination function. The
156library provides a default function that prints an error message and calls ``std::abort()``. Note
157that this function is provided by the static or shared library, so it is only available when deploying
158to a platform where the compiled library is sufficiently recent. On older platforms, the program will
159terminate in an unspecified unsuccessful manner, but the quality of diagnostics won't be great.
160However, users can also override that function with their own, which can be useful to either provide
161custom behavior or when deploying to an older platform where the default function isn't available.
162
163Replacing the default verbose termination function is done by defining the
164``_LIBCPP_AVAILABILITY_CUSTOM_VERBOSE_ABORT_PROVIDED`` macro in all translation units of your program
165and defining the following function in exactly one translation unit:
166
167.. code-block:: cpp
168
169  void __libcpp_verbose_abort(char const* format, ...)
170
171This mechanism is similar to how one can replace the default definition of ``operator new``
172and ``operator delete``. For example:
173
174.. code-block:: cpp
175
176  // In HelloWorldHandler.cpp
177  #include <version> // must include any libc++ header before defining the function (C compatibility headers excluded)
178
179  void std::__libcpp_verbose_abort(char const* format, ...) {
180    va_list list;
181    va_start(list, format);
182    std::vfprintf(stderr, format, list);
183    va_end(list);
184
185    std::abort();
186  }
187
188  // In HelloWorld.cpp
189  #include <vector>
190
191  int main() {
192    std::vector<int> v;
193    int& x = v[0]; // Your termination function will be called here if _LIBCPP_ENABLE_ASSERTIONS=1
194  }
195
196Also note that the verbose termination function should never return. Since assertions in libc++
197catch undefined behavior, your code will proceed with undefined behavior if your function is called
198and does return.
199
200Furthermore, exceptions should not be thrown from the function. Indeed, many functions in the
201library are ``noexcept``, and any exception thrown from the termination function will result
202in ``std::terminate`` being called.
203
204Libc++ Configuration Macros
205===========================
206
207Libc++ provides a number of configuration macros which can be used to enable
208or disable extended libc++ behavior, including enabling "debug mode" or
209thread safety annotations.
210
211**_LIBCPP_ENABLE_THREAD_SAFETY_ANNOTATIONS**:
212  This macro is used to enable -Wthread-safety annotations on libc++'s
213  ``std::mutex`` and ``std::lock_guard``. By default, these annotations are
214  disabled and must be manually enabled by the user.
215
216**_LIBCPP_DISABLE_VISIBILITY_ANNOTATIONS**:
217  This macro is used to disable all visibility annotations inside libc++.
218  Defining this macro and then building libc++ with hidden visibility gives a
219  build of libc++ which does not export any symbols, which can be useful when
220  building statically for inclusion into another library.
221
222**_LIBCPP_DISABLE_ADDITIONAL_DIAGNOSTICS**:
223  This macro disables the additional diagnostics generated by libc++ using the
224  `diagnose_if` attribute. These additional diagnostics include checks for:
225
226    * Giving `set`, `map`, `multiset`, `multimap` and their `unordered_`
227      counterparts a comparator which is not const callable.
228    * Giving an unordered associative container a hasher that is not const
229      callable.
230
231**_LIBCPP_NO_VCRUNTIME**:
232  Microsoft's C and C++ headers are fairly entangled, and some of their C++
233  headers are fairly hard to avoid. In particular, `vcruntime_new.h` gets pulled
234  in from a lot of other headers and provides definitions which clash with
235  libc++ headers, such as `nothrow_t` (note that `nothrow_t` is a struct, so
236  there's no way for libc++ to provide a compatible definition, since you can't
237  have multiple definitions).
238
239  By default, libc++ solves this problem by deferring to Microsoft's vcruntime
240  headers where needed. However, it may be undesirable to depend on vcruntime
241  headers, since they may not always be available in cross-compilation setups,
242  or they may clash with other headers. The `_LIBCPP_NO_VCRUNTIME` macro
243  prevents libc++ from depending on vcruntime headers. Consequently, it also
244  prevents libc++ headers from being interoperable with vcruntime headers (from
245  the aforementioned clashes), so users of this macro are promising to not
246  attempt to combine libc++ headers with the problematic vcruntime headers. This
247  macro also currently prevents certain `operator new`/`operator delete`
248  replacement scenarios from working, e.g. replacing `operator new` and
249  expecting a non-replaced `operator new[]` to call the replaced `operator new`.
250
251**_LIBCPP_ENABLE_NODISCARD**:
252  Allow the library to add ``[[nodiscard]]`` attributes to entities not specified
253  as ``[[nodiscard]]`` by the current language dialect. This includes
254  backporting applications of ``[[nodiscard]]`` from newer dialects and
255  additional extended applications at the discretion of the library. All
256  additional applications of ``[[nodiscard]]`` are disabled by default.
257  See :ref:`Extended Applications of [[nodiscard]] <nodiscard extension>` for
258  more information.
259
260**_LIBCPP_DISABLE_NODISCARD_EXT**:
261  This macro prevents the library from applying ``[[nodiscard]]`` to entities
262  purely as an extension. See :ref:`Extended Applications of [[nodiscard]] <nodiscard extension>`
263  for more information.
264
265**_LIBCPP_DISABLE_DEPRECATION_WARNINGS**:
266  This macro disables warnings when using deprecated components. For example,
267  using `std::auto_ptr` when compiling in C++11 mode will normally trigger a
268  warning saying that `std::auto_ptr` is deprecated. If the macro is defined,
269  no warning will be emitted. By default, this macro is not defined.
270
271C++17 Specific Configuration Macros
272-----------------------------------
273**_LIBCPP_ENABLE_CXX17_REMOVED_FEATURES**:
274  This macro is used to re-enable all the features removed in C++17. The effect
275  is equivalent to manually defining each macro listed below.
276
277**_LIBCPP_ENABLE_CXX17_REMOVED_AUTO_PTR**:
278  This macro is used to re-enable `auto_ptr`.
279
280**_LIBCPP_ENABLE_CXX17_REMOVED_BINDERS**:
281  This macro is used to re-enable the `binder1st`, `binder2nd`,
282  `pointer_to_unary_function`, `pointer_to_binary_function`, `mem_fun_t`,
283  `mem_fun1_t`, `mem_fun_ref_t`, `mem_fun1_ref_t`, `const_mem_fun_t`,
284  `const_mem_fun1_t`, `const_mem_fun_ref_t`, and `const_mem_fun1_ref_t`
285  class templates, and the `bind1st`, `bind2nd`, `mem_fun`, `mem_fun_ref`,
286  and `ptr_fun` functions.
287
288**_LIBCPP_ENABLE_CXX17_REMOVED_RANDOM_SHUFFLE**:
289  This macro is used to re-enable the `random_shuffle` algorithm.
290
291**_LIBCPP_ENABLE_CXX17_REMOVED_UNEXPECTED_FUNCTIONS**:
292  This macro is used to re-enable `set_unexpected`, `get_unexpected`, and
293  `unexpected`.
294
295C++20 Specific Configuration Macros
296-----------------------------------
297**_LIBCPP_DISABLE_NODISCARD_AFTER_CXX17**:
298  This macro can be used to disable diagnostics emitted from functions marked
299  ``[[nodiscard]]`` in dialects after C++17.  See :ref:`Extended Applications of [[nodiscard]] <nodiscard extension>`
300  for more information.
301
302**_LIBCPP_ENABLE_CXX20_REMOVED_FEATURES**:
303  This macro is used to re-enable all the features removed in C++20. The effect
304  is equivalent to manually defining each macro listed below.
305
306**_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_MEMBERS**:
307  This macro is used to re-enable redundant members of `allocator<T>`,
308  including `pointer`, `reference`, `rebind`, `address`, `max_size`,
309  `construct`, `destroy`, and the two-argument overload of `allocate`.
310
311**_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_VOID_SPECIALIZATION**:
312  This macro is used to re-enable the library-provided specializations of
313  `allocator<void>` and `allocator<const void>`.
314  Use it in conjunction with `_LIBCPP_ENABLE_CXX20_REMOVED_ALLOCATOR_MEMBERS`
315  to ensure that removed members of `allocator<void>` can be accessed.
316
317**_LIBCPP_ENABLE_CXX20_REMOVED_BINDER_TYPEDEFS**:
318  This macro is used to re-enable the `argument_type`, `result_type`,
319  `first_argument_type`, and `second_argument_type` members of class
320  templates such as `plus`, `logical_not`, `hash`, and `owner_less`.
321
322**_LIBCPP_ENABLE_CXX20_REMOVED_NEGATORS**:
323  This macro is used to re-enable `not1`, `not2`, `unary_negate`,
324  and `binary_negate`.
325
326**_LIBCPP_ENABLE_CXX20_REMOVED_RAW_STORAGE_ITERATOR**:
327  This macro is used to re-enable `raw_storage_iterator`.
328
329**_LIBCPP_ENABLE_CXX20_REMOVED_TYPE_TRAITS**:
330  This macro is used to re-enable `is_literal_type`, `is_literal_type_v`,
331  `result_of` and `result_of_t`.
332
333
334Libc++ Extensions
335=================
336
337This section documents various extensions provided by libc++, how they're
338provided, and any information regarding how to use them.
339
340.. _nodiscard extension:
341
342Extended applications of ``[[nodiscard]]``
343------------------------------------------
344
345The ``[[nodiscard]]`` attribute is intended to help users find bugs where
346function return values are ignored when they shouldn't be. After C++17 the
347C++ standard has started to declared such library functions as ``[[nodiscard]]``.
348However, this application is limited and applies only to dialects after C++17.
349Users who want help diagnosing misuses of STL functions may desire a more
350liberal application of ``[[nodiscard]]``.
351
352For this reason libc++ provides an extension that does just that! The
353extension must be enabled by defining ``_LIBCPP_ENABLE_NODISCARD``. The extended
354applications of ``[[nodiscard]]`` takes two forms:
355
3561. Backporting ``[[nodiscard]]`` to entities declared as such by the
357   standard in newer dialects, but not in the present one.
358
3592. Extended applications of ``[[nodiscard]]``, at the library's discretion,
360   applied to entities never declared as such by the standard.
361
362Users may also opt-out of additional applications ``[[nodiscard]]`` using
363additional macros.
364
365Applications of the first form, which backport ``[[nodiscard]]`` from a newer
366dialect, may be disabled using macros specific to the dialect in which it was
367added. For example, ``_LIBCPP_DISABLE_NODISCARD_AFTER_CXX17``.
368
369Applications of the second form, which are pure extensions, may be disabled
370by defining ``_LIBCPP_DISABLE_NODISCARD_EXT``.
371
372
373Entities declared with ``_LIBCPP_NODISCARD_EXT``
374~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
375
376This section lists all extended applications of ``[[nodiscard]]`` to entities
377which no dialect declares as such (See the second form described above).
378
379* ``adjacent_find``
380* ``all_of``
381* ``any_of``
382* ``binary_search``
383* ``clamp``
384* ``count_if``
385* ``count``
386* ``equal_range``
387* ``equal``
388* ``find_end``
389* ``find_first_of``
390* ``find_if_not``
391* ``find_if``
392* ``find``
393* ``get_temporary_buffer``
394* ``includes``
395* ``is_heap_until``
396* ``is_heap``
397* ``is_partitioned``
398* ``is_permutation``
399* ``is_sorted_until``
400* ``is_sorted``
401* ``lexicographical_compare``
402* ``lower_bound``
403* ``max_element``
404* ``max``
405* ``min_element``
406* ``min``
407* ``minmax_element``
408* ``minmax``
409* ``mismatch``
410* ``none_of``
411* ``remove_if``
412* ``remove``
413* ``search_n``
414* ``search``
415* ``unique``
416* ``upper_bound``
417* ``lock_guard``'s constructors
418* ``as_const``
419* ``bit_cast``
420* ``forward``
421* ``move``
422* ``move_if_noexcept``
423* ``identity::operator()``
424* ``to_integer``
425* ``to_underlying``
426
427Additional types supported in random distributions
428~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
429
430The `C++ Standard <http://eel.is/c++draft/rand#req.genl-1.5>`_ mentions that instantiating several random number
431distributions with types other than ``short``, ``int``, ``long``, ``long long``, and their unsigned versions is
432undefined. As an extension, libc++ supports instantiating ``binomial_distribution``, ``discrete_distribution``,
433``geometric_distribution``, ``negative_binomial_distribution``, ``poisson_distribution``, and ``uniform_int_distribution``
434with ``int8_t``, ``__int128_t`` and their unsigned versions.
435