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