私は現在、Emscripten と呼ばれる驚くべき LLVM->Javascript プロジェクトを使用して、CGAL を Javascript に変換しようとしています。私はこれをコアコンポーネントのみで行っています(ImageIOやQtのものではありません)
私はその依存関係の 2 つ (GMP と MPFR) でそれを行うことができました。驚いたことに、両方の C テスト クラスを Javascript にコンパイルすることができました (ビットコード形式で生成された LLVM ライブラリに対して)。nodejs で実行される出力は、ネイティブの結果と正確に一致します。
libboost-thread の 1 つを除いて、他のすべての依存関係はヘッダーのみ (Eigen、Boost) です。現在、明らかに JS はシングル スレッドであるため、これを CGAL コードから削除できることを望んでいます。幸いなことに、私が定義した CGAL_HAS_NO_THREADS マクロがあります。
add_definitions( -DCGAL_HAS_NO_THREADS=1 )
そして、それは -D オプションとしてコマンドラインに渡されるようです
ただし、clang でコンパイルしようとすると (clang などをセットアップする Emscripten ツールを介して cmake を実行してセットアップします)、gcc でコンパイルするときには得られない大量のエラーが発生します。
1)まず、次のようなものです。
#if defined (__GLIBC__)
# include <endian.h>
# if (__BYTE_ORDER == __LITTLE_ENDIAN)
# define CGAL_LITTLE_ENDIAN
# elif (__BYTE_ORDER == __BIG_ENDIAN)
# define CGAL_BIG_ENDIAN
# else
# error Unknown endianness
# endif
#elif defined(__sparc) || defined(__sparc__) \
|| defined(_POWER) || defined(__powerpc__) \
|| defined(__ppc__) || defined(__hppa) \
|| defined(_MIPSEB) || defined(_POWER) \
|| defined(__s390__)
# define CGAL_BIG_ENDIAN
#elif defined(__i386__) || defined(__alpha__) \
|| defined(__x86_64) || defined(__x86_64__) \
|| defined(__ia64) || defined(__ia64__) \
|| defined(_M_IX86) || defined(_M_IA64) \
|| defined(_M_ALPHA) || defined(_WIN64)
# define CGAL_LITTLE_ENDIAN
#else
# error Unknown endianness
#endif
これにより、「不明なエンディアン」エラーが発生します。ClangコンパイラがGLIBCマクロを定義していないことが原因だと思いますか?
もう一つは次のようなものです。
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/src/CGAL/all_files.cpp:1:
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/src/CGAL/Random.cpp:25:
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/include/CGAL/Random.h:30:
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/include/CGAL/basic.h:44:
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/include/CGAL/number_type_basic.h:77:
In file included from /home/marcosscriven/sources/openscadjs/build/CGAL-4.1/include/CGAL/FPU.h:60:
In file included from /usr/lib/gcc/i686-linux-gnu/4.7/../../../../include/c++/4.7/fenv.h:33:
In file included from /usr/lib/gcc/i686-linux-gnu/4.7/../../../../include/c++/4.7/i686-linux-gnu/bits/c++config.h:414:
In file included from /usr/lib/gcc/i686-linux-gnu/4.7/../../../../include/c++/4.7/i686-linux-gnu/bits/os_defines.h:40:
/home/marcosscriven/sources/includes/features.h:324:10: fatal error: 'bits/predefs.h' file not found
#include <bits/predefs.h>
ライブラリを見つけるために別のパッチ(またはパスのセット、またはパスの順序)を使用してclangにダウンしているようです。
どちらも明らかに少しずつハッキングできますが、それは「正しい」方法ではないと思います。
私が抱えている問題は、clang (または gcc) を実行するときに定義されているマクロをよく知っていることですか? /usr/include/ のルートにあるすべてのインクルードが何であるかもわかりませんか?
それらのいくつかはGNUCであり、これは何らかの方法で標準のlibcおよびlibcxxライブラリとは異なることを知っていますか? しかし、それらのすべてではありませんか?
どんな助けでも大歓迎です。
マルコス