This reverts the following commits: 37ca7a795b277c20c02a218bf44052278c03344b 9aa6c72b92b6c89cc6d23b693257df9af7de2d15 705387c5074bcca36d626882462ebbc2bcc3bed4 8ca4b3ef19fe82d7ad6a6e1515317dcc01b41515 80dba72a669b5416e97a42fd2c2a7bc5a6d3f44a
37 lines
952 B
C++
37 lines
952 B
C++
// RUN: %clang_cc1 -triple=i386-pc-solaris2.11 -w -emit-llvm %s -o - | FileCheck %s
|
|
|
|
extern "C" {
|
|
struct statvfs64 {
|
|
int f;
|
|
};
|
|
#pragma redefine_extname statvfs64 statvfs
|
|
int statvfs64(struct statvfs64 *);
|
|
}
|
|
|
|
void some_func() {
|
|
struct statvfs64 st;
|
|
statvfs64(&st);
|
|
// Check that even if there is a structure with redefined name before the
|
|
// pragma, subsequent function name redefined properly. PR5172, Comment 11.
|
|
// CHECK: call i32 @statvfs(%struct.statvfs64* %st)
|
|
}
|
|
|
|
// This is a case when redefenition is deferred *and* we have a local of the
|
|
// same name. PR23923.
|
|
#pragma redefine_extname foo bar
|
|
int f() {
|
|
int foo = 0;
|
|
return foo;
|
|
}
|
|
extern "C" {
|
|
int foo() { return 1; }
|
|
// CHECK: define{{.*}} i32 @bar()
|
|
}
|
|
|
|
// Check that #pragma redefine_extname applies to C code only, and shouldn't be
|
|
// applied to C++.
|
|
#pragma redefine_extname foo_cpp bar_cpp
|
|
extern int foo_cpp() { return 1; }
|
|
// CHECK-NOT: define{{.*}} i32 @bar_cpp()
|
|
|