[llvm-bugs] [Bug 26751] New: clang-cl: Come up with a way to do the equivalent of %INCLUDE% via command-line flags
via llvm-bugs
llvm-bugs at lists.llvm.org
Fri Feb 26 10:18:42 PST 2016
https://llvm.org/bugs/show_bug.cgi?id=26751
Bug ID: 26751
Summary: clang-cl: Come up with a way to do the equivalent of
%INCLUDE% via command-line flags
Product: clang
Version: unspecified
Hardware: PC
OS: Linux
Status: NEW
Severity: normal
Priority: P
Component: Driver
Assignee: unassignedclangbugs at nondot.org
Reporter: nicolasweber at gmx.de
CC: llvm-bugs at lists.llvm.org
Classification: Unclassified
clang-cl currently supports a bunch of magic env vars, like cl.exe. Passing
things in env vars is messy (for example: if you want to use clang-cl on Linux,
should the env var item separator be : or ;?), so we should have the ability to
do the same with flags.
I thought just exposing -isystem and then passing one -isystem flag per INCLUDE
entry would be enough, but that's sadly not the case:
1. If I misspell the -isystem flag to point to a nonexistent directory, they're
ignored and the "real" system includes are still picked up. -nostdlibinc fixes
that, but clang-cl doesn't expose that. We could expose this flag too, seems
like a good and easy fix.
2. But even then, the -isystem flags are now searched before the built-in
headers, which has the effect of e.g. `#include <stddef.h>` picking up the msvs
header instead of clang's version (and now offsetof is no longer constexpr
etc). I guess one fix for this would be to add an explicit -isystem flag
pointing to clang's builtin header dir, but this is getting a bit ugly.
Does anyone happen to have better suggestions on how to get the exact same
effect as setting %INCLUDE% with flags?
--
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20160226/7ef6080f/attachment.html>
More information about the llvm-bugs
mailing list