nuttx/libs/libxx
SPRESENSE 25b7bdf943 libs/libxx/libcxx.defs: Fix build error on Windows platform
The libcxx-X.Y.Z.src.tar.xz contains a symbolic link to a directory
that not exist as below.

`libcxx-X.Y.Z.src/test/std/pstl -> ../../../pstl/test/std`

Linux and macOS environment have no problem, but it causes an error
when extracting tarball on Windows platform. This symbolic link is not
actually used, so exclude it from extracting the tarball.
2021-07-21 08:59:22 -07:00
..
.gitignore libcxx: Don't remove the downloaded file eagerly 2020-12-20 23:16:11 -06:00
cxx.defs Fix typos in comments and identifiers 2021-07-19 22:55:30 -03:00
Kconfig libxx: Use Kconfig "choice" to specify an implemenetation 2020-10-28 14:10:30 -03:00
libcxx.defs libs/libxx/libcxx.defs: Fix build error on Windows platform 2021-07-21 08:59:22 -07:00
libxx_cxa_atexit.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_cxa_guard.cxx
libxx_cxapurevirtual.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_delete_sized.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_delete.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_deletea_sized.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_deletea.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_eabi_atexit.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_impure.cxx
libxx_new.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_newa.cxx libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
libxx_stdthrow.cxx libs: libxx: update licenses to Apache 2021-05-27 08:07:25 +09:00
libxx.hxx libc: Remove the duplication lib_xxx macro 2021-07-01 11:28:34 -07:00
Makefile libcxx: : Author Gregory Nutt: update licenses to Apache 2021-02-25 01:44:30 -08:00
README.txt
system_configuration.h
uClibc++.defs Replace all wget with curl 2020-12-22 03:36:10 -06:00

libs/libxx/README.txt
^^^^^^^^^^^^^^^^^^^^^

This directory contains three C++ library:

 - A fragmentary C++ library that will allow to build only the simplest of
   C++ applications. In the deeply embedded world, that is probably all
   that is necessary.

   At present, only the following are supported here:

     - void *operator new(std::size_t nbytes);
     - void operator delete(void* ptr);
     - void operator delete[](void *ptr);
     - void __cxa_pure_virtual(void);
     - int __aeabi_atexit(void* object, void (*destroyer)(void*),
                          void *dso_handle);
     - int __cxa_atexit(__cxa_exitfunc_t func, FAR void *arg,
                        FAR void *dso_handle);

   This implementation is selected when neither of the following
   two options are enabled.

 - LLVM "libc++" C++ library (http://libcxx.llvm.org/)
   This implementation is selected with CONFIG_LIBCXX=y.

 - uClibc++ C++ library (http://cxx.uclibc.org/)
   This implementation is selected with CONFIG_UCLIBCXX=y.

operator new
------------

  This operator should take a type of size_t.  But size_t has an unknown underlying
  type.  In the nuttx sys/types.h header file, size_t is typed as uint32_t
  (which is determined by architecture-specific logic).  But the C++
  compiler may believe that size_t is of a different type resulting in
  compilation errors in the operator.  Using the underlying integer type
  instead of size_t seems to resolve the compilation issues. Need to
  REVISIT this.

  Once some C++ compilers, this will cause an error:

    Problem:     "'operator new' takes size_t ('...') as first parameter"
    Workaround:  Add -fpermissive to the compilation flags