Skip to content
Snippets Groups Projects
Commit b17dedc4 authored by Sunil Srivastava's avatar Sunil Srivastava
Browse files

Support '#pragma once' in headers when using PCH

    
The '#pragma once' directive was erroneously ignored when encountered
in the header-file specified in generate-PCH-mode. This resulted in
compile-time errors in some cases with legal code, and also a misleading
warning being produced.

Patch by Warren Ristow!

Differential Revision: http://reviews.llvm.org/D19815


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@276653 91177308-0d34-0410-b5e6-96231b3b80d8
parent 705ef199
No related branches found
No related tags found
No related merge requests found
......@@ -352,7 +352,9 @@ void Preprocessor::HandleMicrosoft__pragma(Token &Tok) {
/// HandlePragmaOnce - Handle \#pragma once. OnceTok is the 'once'.
///
void Preprocessor::HandlePragmaOnce(Token &OnceTok) {
if (isInPrimaryFile()) {
// Don't honor the 'once' when handling the primary source file, unless
// this is a prefix to a TU, which indicates we're generating a PCH file.
if (isInPrimaryFile() && TUKind != TU_Prefix) {
Diag(OnceTok, diag::pp_pragma_once_in_main_file);
return;
}
......
#pragma once
/* For use with the pragma-once.c test */
int x = 3;
// Test this without pch.
// RUN: %clang_cc1 -include %S/Inputs/pragma-once.h -fsyntax-only -verify %s
// Test with pch.
// RUN: %clang_cc1 -emit-pch -o %t %S/Inputs/pragma-once.h
// RUN: %clang_cc1 -include-pch %t -fsyntax-only -verify %s
// expected-no-diagnostics
// Including "pragma-once.h" twice, to verify the 'once' aspect is honored.
#include "Inputs/pragma-once.h"
#include "Inputs/pragma-once.h"
int foo(void) { return 0; }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment