mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-23 07:52:06 +00:00
47972afd10
We used to have a flag to enable module maps, and two more flags to enable implicit module maps. This is all redundant; we don't need any flag for enabling module maps in the abstract, and we don't usually have -fno- flags for -cc1. We now have just a single flag, -fimplicit-module-maps, that enables implicitly searching the file system for module map files and loading them. The driver interface is unchanged for now. We should probably rename -fmodule-maps to -fimplicit-module-maps at some point. llvm-svn: 239789
25 lines
1.1 KiB
C++
25 lines
1.1 KiB
C++
// RUN: rm -rf %t
|
|
|
|
// First, build two modules that both re-export the same header.
|
|
// RUN: %clang_cc1 -x c++ -std=c++11 -fmodules -fimplicit-module-maps -fmodule-name=b -o %t/b.pcm \
|
|
// RUN: -emit-module %S/Inputs/merge-vtable-codegen/merge-vtable-codegen.modulemap \
|
|
// RUN: -I %S/Inputs/merge-vtable-codegen
|
|
// RUN: %clang_cc1 -x c++ -std=c++11 -fmodules -fimplicit-module-maps -fmodule-name=c -o %t/c.pcm \
|
|
// RUN: -emit-module %S/Inputs/merge-vtable-codegen/merge-vtable-codegen.modulemap \
|
|
// RUN: -I %S/Inputs/merge-vtable-codegen
|
|
|
|
// Use the two modules in a single compile.
|
|
// RUN: %clang_cc1 -x c++ -std=c++11 -fmodules -fimplicit-module-maps -fmodule-file=%t/b.pcm -fmodule-file=%t/c.pcm \
|
|
// RUN: -fmodule-map-file=%S/Inputs/merge-vtable-codegen/merge-vtable-codegen.modulemap \
|
|
// RUN: -emit-llvm -o %t/test.o %s
|
|
|
|
// Note that order is important:
|
|
// Module 'c' just reexports A, while module 'b' defines a method that uses a
|
|
// virtual method of A.
|
|
#include "Inputs/merge-vtable-codegen/c.h"
|
|
#include "Inputs/merge-vtable-codegen/b.h"
|
|
|
|
void t() {
|
|
b(nullptr);
|
|
}
|