File: n1460.c

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (54 lines) | stat: -rw-r--r-- 1,495 bytes parent folder | download | duplicates (12)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// RUN: %clang_cc1 -verify -Wno-vla %s

/* WG14 N1460: Yes
 * Subsetting the standard
 */

// If we claim to not support the feature then we expect diagnostics when
// using that feature. Otherwise, we expect no diagnostics.
#ifdef __STDC_NO_COMPLEX__
  // PS4/PS5 set this to indicate no <complex.h> but still support the
  // _Complex syntax.
  #ifdef __SCE__
    #define HAS_COMPLEX
  #else
    // We do not have any other targets which do not support complex, so we
    // don't expect to get into this block.
    #error "it's unexpected that we don't support complex"
  #endif
  float _Complex fc;
  double _Complex dc;
  long double _Complex ldc;
#else
  #define HAS_COMPLEX
  float _Complex fc;
  double _Complex dc;
  long double _Complex ldc;
#endif

#ifdef __STDC_NO_VLA__
  // We do not have any targets which do not support VLAs, so we don't expect
  // to get into this block.
  #error "it's unexpected that we don't support VLAs"

  void func(int n, int m[n]) {
    int array[n];
  }
#else
  #define HAS_VLA
  void func(int n, int m[n]) {
    int array[n];
  }
#endif

// NB: it's not possible to test for __STDC_NO_THREADS__ because that is
// specifically about whether <threads.h> exists and is supported, which is
// outside the control of the compiler. It does not cover use of thread_local.

#if defined(HAS_COMPLEX) && defined(HAS_VLA)
// If we support all these optional features, we don't expect any other
// diagnostics to have fired.

// expected-no-diagnostics
#endif