diff --git a/clang/lib/Frontend/ASTUnit.cpp b/clang/lib/Frontend/ASTUnit.cpp index 42a67720c353..d0aadfd29ea9 100644 --- a/clang/lib/Frontend/ASTUnit.cpp +++ b/clang/lib/Frontend/ASTUnit.cpp @@ -525,6 +525,8 @@ public: Context.InitBuiltinTypes(*Target); InitializedLanguage = true; + + applyLangOptsToTarget(); return false; } @@ -541,6 +543,8 @@ public: TargetOpts.Features.clear(); TargetOpts.Triple = Triple; Target = TargetInfo::CreateTargetInfo(PP.getDiagnostics(), TargetOpts); + + applyLangOptsToTarget(); return false; } @@ -562,6 +566,17 @@ public: virtual void ReadCounter(unsigned Value) { Counter = Value; } + +private: + void applyLangOptsToTarget() { + if (Target && InitializedLanguage) { + // Inform the target of the language options. + // + // FIXME: We shouldn't need to do this, the target should be immutable once + // created. This complexity should be lifted elsewhere. + Target->setForcedLangOptions(LangOpt); + } + } }; class StoredDiagnosticConsumer : public DiagnosticConsumer { diff --git a/clang/test/Index/index-pch.cpp b/clang/test/Index/index-pch.cpp new file mode 100644 index 000000000000..c8da7b2fbf2a --- /dev/null +++ b/clang/test/Index/index-pch.cpp @@ -0,0 +1,6 @@ +// RUN: c-index-test -write-pch %t.pch -fshort-wchar %s +// RUN: c-index-test -index-tu %t.pch | FileCheck %s + +const wchar_t *wideStr = L"123"; + +// CHECK: [indexDeclaration]: kind: variable | name: wideStr