llvm-project/clang/test/SemaOpenACC/data-construct-default-clause.c
erichkeane 8313d2a8db [OpenACC] Fixup previous-clause diagnostics
Brought up in a previous review as a TODO, we could be better about how
we highlight what hte previous clause was, and how to show that the
'device_type' is the one being targetted.  This patch rewords the
diagnostics and updates a massive number of tests.
2025-05-02 09:35:32 -07:00

29 lines
1.4 KiB
C

// RUN: %clang_cc1 %s -fopenacc -verify
void use() {
// expected-error@+2{{OpenACC 'data' construct must have at least one 'attach', 'copy', 'copyin', 'copyout', 'create', 'default', 'deviceptr', 'no_create', or 'present' clause}}
// expected-error@+1{{invalid value for 'default' clause; expected 'present' or 'none'}}
#pragma acc data default(garbage)
;
#pragma acc data default(present)
;
#pragma acc data default(none)
;
// expected-error@+2{{OpenACC 'default' clause cannot appear more than once on a 'data' directive}}
// expected-note@+1{{previous 'default' clause is here}}
#pragma acc data default(none) default(present)
;
// expected-error@+2{{OpenACC 'enter data' construct must have at least one 'attach', 'copyin', or 'create' clause}}
// expected-error@+1{{OpenACC 'default' clause is not valid on 'enter data' directive}}
#pragma acc enter data default(present)
;
// expected-error@+2{{OpenACC 'exit data' construct must have at least one 'copyout', 'delete', or 'detach' clause}}
// expected-error@+1{{OpenACC 'default' clause is not valid on 'exit data' directive}}
#pragma acc exit data default(none)
;
// expected-error@+2{{OpenACC 'host_data' construct must have at least one 'use_device' clause}}
// expected-error@+1{{OpenACC 'default' clause is not valid on 'host_data' directive}}
#pragma acc host_data default(present)
;
}