File: modules-cas-trees-input-files.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 (92 lines) | stat: -rw-r--r-- 3,030 bytes parent folder | download
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
// Ensure all files references by a cached module can be found.

// REQUIRES: ondisk_cas

// RUN: rm -rf %t
// RUN: split-file %s %t
// RUN: sed "s|DIR|%/t|g" %t/cdb_pch.json.template > %t/cdb_pch.json
// RUN: sed "s|DIR|%/t|g" %t/cdb.json.template > %t/cdb.json

// == Scan PCH
// RUN: clang-scan-deps -compilation-database %t/cdb_pch.json \
// RUN:   -cas-path %t/cas -module-files-dir %t/outputs \
// RUN:   -format experimental-full -mode preprocess-dependency-directives \
// RUN:   > %t/deps_pch.json

// == Build PCH
// RUN: %deps-to-rsp %t/deps_pch.json --module-name A > %t/A.rsp
// RUN: %deps-to-rsp %t/deps_pch.json --tu-index 0 > %t/pch.rsp

// RUN: %clang @%t/A.rsp
// RUN: %clang @%t/pch.rsp

// == Scan TU, including PCH
// RUN: clang-scan-deps -compilation-database %t/cdb.json \
// RUN:   -cas-path %t/cas -module-files-dir %t/outputs \
// RUN:   -format experimental-full -mode preprocess-dependency-directives \
// RUN:   > %t/deps.json

// == Build TU, including PCH
// RUN: %deps-to-rsp %t/deps.json --module-name C > %t/C.rsp
// RUN: %deps-to-rsp %t/deps.json --tu-index 0 > %t/tu.rsp

// RUN: %clang @%t/C.rsp
// RUN: %clang @%t/tu.rsp

//--- cdb_pch.json.template
[
  {
    "directory" : "DIR",
    "command" : "clang_tool -I DIR -x c-header DIR/prefix.h -o DIR/prefix.h.pch -fmodules -fimplicit-modules -fimplicit-module-maps -fmodules-cache-path=DIR/module-cache -Rcompile-job-cache",
    "file" : "DIR/prefix.h"
  },
]

//--- cdb.json.template
[
  {
    "directory" : "DIR",
    "command" : "clang_tool -I DIR -fsyntax-only DIR/tu.c -include DIR/prefix.h -fmodules -fimplicit-modules -fimplicit-module-maps -fmodules-cache-path=DIR/module-cache -Rcompile-job-cache",
    "file" : "DIR/tu.c"
  },
]

// The test below is a specific instance that was failing in the past. The test
// complexity is required to trigger looking up an input file of a module that
// would not be automatically visited when importing that module during
// dependency scanning, because it is only triggered incidentally. The anatomy
// of the specific test case is:
// * module A has a reference to B's modulemap but does not import B
//   because it was for an excluded header
// * module C imports A and performs macro expansion of module_macro
// * looking up the location for the macro definition does binary search and
//   incidentally deserializes the SLocEntry for B's modulemap. With small
//   modules such as in this test case, the binary search is *likely* to hit
//   that specific SLocEntry, and it did at the time this test was written.
// * module A must be "prebuilt"; otherwise the scanner will visit all inputs
//   during implicit module validation; so we load it via PCH.

//--- A/module.modulemap
module A { header "A.h" }

//--- A/A.h
#include "B/B.h"
#define module_macro int

//--- B/module.modulemap
module B { exclude header "B.h" }

//--- B/B.h

//--- module.modulemap
module C { header "C.h" }

//--- C.h
#include "A/A.h"
module_macro x;

//--- prefix.h
#include "A/A.h"

//--- tu.c
#include "C.h"