[clang] Implement lifetime analysis for lifetime_capture_by(X) (#115921)
[llvm-project.git] / clang / test / Modules / no-transitive-identifier-change.cppm
blob541c8ae754960b02fe5a70c89215433c23ba6bbd
1 // Testing that adding an new identifier in an unused module file won't change 
2 // the BMI of the current module file.
3 //
4 // RUN: rm -rf %t
5 // RUN: split-file %s %t
6 //
7 // RUN: %clang_cc1 -std=c++20 %t/m-partA.cppm -emit-reduced-module-interface -o %t/m-partA.pcm
8 // RUN: %clang_cc1 -std=c++20 %t/m-partA.v1.cppm -emit-reduced-module-interface -o \
9 // RUN:     %t/m-partA.v1.pcm
10 // RUN: %clang_cc1 -std=c++20 %t/m-partB.cppm -emit-reduced-module-interface -o %t/m-partB.pcm
11 // RUN: %clang_cc1 -std=c++20 %t/m.cppm -emit-reduced-module-interface -o %t/m.pcm \
12 // RUN:     -fmodule-file=m:partA=%t/m-partA.pcm -fmodule-file=m:partB=%t/m-partB.pcm
13 // RUN: %clang_cc1 -std=c++20 %t/m.cppm -emit-reduced-module-interface -o %t/m.v1.pcm \
14 // RUN:     -fmodule-file=m:partA=%t/m-partA.v1.pcm -fmodule-file=m:partB=%t/m-partB.pcm
16 // RUN: %clang_cc1 -std=c++20 %t/useBOnly.cppm -emit-reduced-module-interface -o %t/useBOnly.pcm \
17 // RUN:     -fmodule-file=m=%t/m.pcm -fmodule-file=m:partA=%t/m-partA.pcm \
18 // RUN:     -fmodule-file=m:partB=%t/m-partB.pcm
19 // RUN: %clang_cc1 -std=c++20 %t/useBOnly.cppm -emit-reduced-module-interface -o %t/useBOnly.v1.pcm \
20 // RUN:     -fmodule-file=m=%t/m.v1.pcm -fmodule-file=m:partA=%t/m-partA.v1.pcm \
21 // RUN:     -fmodule-file=m:partB=%t/m-partB.pcm
22 // Since useBOnly only uses partB from module M, the change in partA shouldn't affect
23 // useBOnly.
24 // RUN: diff %t/useBOnly.pcm %t/useBOnly.v1.pcm &> /dev/null
26 // RUN: %clang_cc1 -std=c++20 %t/useAOnly.cppm -emit-reduced-module-interface -o %t/useAOnly.pcm \
27 // RUN:     -fmodule-file=m=%t/m.pcm -fmodule-file=m:partA=%t/m-partA.pcm \
28 // RUN:     -fmodule-file=m:partB=%t/m-partB.pcm
29 // RUN: %clang_cc1 -std=c++20 %t/useAOnly.cppm -emit-reduced-module-interface -o %t/useAOnly.v1.pcm \
30 // RUN:     -fmodule-file=m=%t/m.v1.pcm -fmodule-file=m:partA=%t/m-partA.v1.pcm \
31 // RUN:     -fmodule-file=m:partB=%t/m-partB.pcm
32 // useAOnly should differ
33 // RUN: not diff %t/useAOnly.pcm %t/useAOnly.v1.pcm &> /dev/null
35 //--- m-partA.cppm
36 export module m:partA;
38 export inline int getA() {
39     return 43;
42 export class A {
43 public:
44     int getMem();
47 export template <typename T>
48 class ATempl {
49 public:
50     T getT();
53 //--- m-partA.v1.cppm
54 export module m:partA;
56 export inline int getA() {
57     return 43;
60 // The consuming module which didn't use m:partA completely is expected to be
61 // not changed.
62 export inline int getA2() {
63     return 88;
66 export class A {
67 public:
68     int getMem();
70     // The consuming module which didn't use m:partA completely is expected to be
71     // not changed.
72     int getMem2();
75 export template <typename T>
76 class ATempl {
77 public:
78     T getT();
79     T getT2();
82 //--- m-partB.cppm
83 export module m:partB;
85 export inline int getB() {
86     return 430;
89 //--- m.cppm
90 export module m;
91 export import :partA;
92 export import :partB;
94 //--- useBOnly.cppm
95 export module useBOnly;
96 import m;
98 export inline int get() {
99     return getB();
102 //--- useAOnly.cppm
103 export module useAOnly;
104 import m;
106 export inline int get() {
107     return getA();