// Note: %s and %S must be preceded by --, otherwise it may be interpreted as a // command-line option, e.g. on Mac where %s is commonly under /Users. // The main test for clang-cl pch handling is cl-pch.cpp. This file only checks // a few things for .c inputs. // /Yc with a .c file should build a c pch file. // RUN: %clang_cl -Werror /Ycpchfile.h /FIpchfile.h /c -### -- %s 2>&1 \ // RUN: | FileCheck -check-prefix=CHECK-YC %s // CHECK-YC: cc1 // CHECK-YC: -emit-pch // CHECK-YC: -o // CHECK-YC: pchfile.pch // CHECK-YC: -x // CHECK-YC: "c" // But not if /TP changes the input language to C++. // RUN: %clang_cl /TP -Werror /Ycpchfile.h /FIpchfile.h /c -### -- %s 2>&1 \ // RUN: | FileCheck -check-prefix=CHECK-YCTP %s // CHECK-YCTP: cc1 // CHECK-YCTP: -emit-pch // CHECK-YCTP: -o // CHECK-YCTP: pchfile.pch // CHECK-YCTP: -x // CHECK-YCTP: "c++" // Except if a later /TC changes it back. // RUN: %clang_cl -Werror /Ycpchfile.h /FIpchfile.h /c -### -- %s 2>&1 \ // RUN: | FileCheck -check-prefix=CHECK-YCTPTC %s // CHECK-YCTPTC: cc1 // CHECK-YCTPTC: -emit-pch // CHECK-YCTPTC: -o // CHECK-YCTPTC: pchfile.pch // CHECK-YCTPTC: -x // CHECK-YCTPTC: "c" // Also check lower-case /Tp flag. // RUN: %clang_cl -Werror /Tp%s /Ycpchfile.h /FIpchfile.h /c -### 2>&1 \ // RUN: | FileCheck -check-prefix=CHECK-YCTp %s // CHECK-YCTp: cc1 // CHECK-YCTp: -emit-pch // CHECK-YCTp: -o // CHECK-YCTp: pchfile.pch // CHECK-YCTp: -x // CHECK-YCTp: "c++"