llvm-project/clang/test/AST/ast-print-attr.c
Giuliano Belinassi 46f3ade508 Fix ast print of variables with attributes
Previously clang AST prints the following declaration:

int fun_var_unused() {

  int x __attribute__((unused)) = 0;
  return x;
}

and

int __declspec(thread) x = 0;

as:

int fun_var_unused() {

  int x = 0 __attribute__((unused));
  return x;
}

and

int x = __declspec(thread) 0;

which is rejected by C/C++ parser. This patch modifies the logic to
print old C attributes for variables as:

int __attribute__((unused)) x = 0;
and the __declspec case as:

int __declspec(thread) x = 0;
Fixes: https://github.com/llvm/llvm-project/issues/59973

Previous version: D141714.

Differential Revision:https://reviews.llvm.org/D141714
2023-09-07 13:35:50 -07:00

41 lines
1.2 KiB
C

// RUN: %clang_cc1 -ast-print -x objective-c++ -fms-extensions %s -o - | FileCheck %s
// CHECK: using A = __kindof id (*)[1];
using A = __kindof id (*)[1];
// CHECK: using B = int ** __ptr32 *[3];
using B = int ** __ptr32 *[3];
// FIXME: This is the wrong spelling for the attribute.
// FIXME: Too many parens here!
// CHECK: using C = int ((*))() __attribute__((cdecl));
using C = int (*)() [[gnu::cdecl]];
// CHECK: int fun_asm() asm("test");
int fun_asm() asm("test");
// CHECK: int var_asm asm("test");
int var_asm asm("test");
@interface NSString
@end
extern NSString *const MyErrorDomain;
// CHECK: enum __attribute__((ns_error_domain(MyErrorDomain))) MyErrorEnum {
enum __attribute__((ns_error_domain(MyErrorDomain))) MyErrorEnum {
MyErrFirst,
MyErrSecond,
};
// CHECK: int *fun_returns() __attribute__((ownership_returns(fun_returns)));
int *fun_returns() __attribute__((ownership_returns(fun_returns)));
// CHECK: void fun_holds(int *a) __attribute__((ownership_holds(fun_holds, 1)));
void fun_holds(int *a) __attribute__((ownership_holds(fun_holds, 1)));
// CHECK: int fun_var_unused() {
// CHECK-NEXT: int x __attribute__((unused)) = 0;
// CHECK-NEXT: return x;
// CHECK-NEXT: }
int fun_var_unused() { int x __attribute__((unused)) = 0; return x; }