c3_clang_extensions 0.3.7

Ugly hacks to get information hidden/malformed by libclang See C3 for usable interface.
docs.rs failed to build c3_clang_extensions-0.3.7
Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.


Internal for the C3 project.


  • Run cargo clean if upgrading from a previous version of LLVM.
  • Build LLVM 4 or 5 and Clang from source (libclang.a is needed, and pre-built packages won't have it).
  • Add directory containing llvm-config to your PATH, or set LLVM_CONFIG_PATH env variable poiting to the llvm-config executable file.
  • Set LIBCLANG_INCLUDE_PATH pointing to Clang's include directory (<clang install dir>/clang/include/)

Building clang (Linux and macOS)

This will require 20GB of disk space and 16GB of RAM. This method creates static binaries, which can be redistributed without hassle.

  1. Install cmake, subversion, build-essential, libffi-dev, libncursesw5-dev
  2. curl -LO http://releases.llvm.org/5.0.0/llvm-5.0.0.src.tar.xz
  3. tar xf llvm-5.0.0.src.tar.xz
  4. curl -LO http://releases.llvm.org/5.0.0/cfe-5.0.0.src.tar.xz
  5. tar xf cfe-5.0.0.src.tar.xz
  6. mv cfe-5.0.0.src llvm-5.0.0.src/tools/clang
  7. cd llvm-5.0.0.src
  8. mkdir build; cd build
  10. make -j8; make install
  11. Take a nap.
  12. cp lib/libclang.a "$HOME/llvm-5-c3/lib/"
  13. Set the following variables. Note that you will need to set them every time you compile, so add them to your bashrc or make a script and source it.
    • export LIBCLANG_INCLUDE_PATH="$HOME/llvm-5-c3/tools/clang/include/:$HOME/llvm-5-c3/include/"
    • export LIBCLANG_STATIC_PATH="$HOME/llvm-5-c3/lib/"
    • export LLVM_CONFIG_PATH="$HOME/llvm-5-c3/bin/llvm-config"