================================ Frequently Asked Questions (FAQ) ================================ .. contents:: :local: Driver ====== I run ``clang -cc1 ...`` and get weird errors about missing headers ------------------------------------------------------------------- Given this source file: .. code-block:: c #include <stdio.h> int main() { printf("Hello world\n"); } If you run: .. code-block:: console $ clang -cc1 hello.c hello.c:1:10: fatal error: 'stdio.h' file not found #include <stdio.h> ^ 1 error generated. ``clang -cc1`` is the frontend, ``clang`` is the :doc:`driver <DriverInternals>`. The driver invokes the frontend with options appropriate for your system. To see these options, run: .. code-block:: console $ clang -### -c hello.c Some clang command line options are driver-only options, some are frontend-only options. Frontend-only options are intended to be used only by clang developers. Users should not run ``clang -cc1`` directly, because ``-cc1`` options are not guaranteed to be stable. If you want to use a frontend-only option ("a ``-cc1`` option"), for example ``-ast-dump``, then you need to take the ``clang -cc1`` line generated by the driver and add the option you need. Alternatively, you can run ``clang -Xclang <option> ...`` to force the driver pass ``<option>`` to ``clang -cc1``. I get errors about some headers being missing (``stddef.h``, ``stdarg.h``) -------------------------------------------------------------------------- Some header files (``stddef.h``, ``stdarg.h``, and others) are shipped with Clang --- these are called builtin includes. Clang searches for them in a directory relative to the location of the ``clang`` binary. If you moved the ``clang`` binary, you need to move the builtin headers, too. More information can be found in the :ref:`libtooling_builtin_includes` section.