Mercurial > hg > CbC > CbC_llvm
view clang/test/Modules/merge-concepts-cxx-modules.cpp @ 266:00f31e85ec16 default tip
Added tag current for changeset 31d058e83c98
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 14 Oct 2023 10:13:55 +0900 |
parents | c4bab56944e8 |
children |
line wrap: on
line source
// RUN: rm -rf %t // RUN: mkdir %t // RUN: split-file %s %t // // RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/same_as.cppm -o %t/same_as.pcm // RUN: %clang_cc1 -std=c++20 -emit-module-interface -fprebuilt-module-path=%t %t/concepts.cppm -o %t/concepts.pcm // RUN: %clang_cc1 -std=c++20 -emit-module-interface -fprebuilt-module-path=%t %t/format.cppm -o %t/format.pcm // RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/conflicting.cppm -o %t/conflicting.pcm // RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t %t/Use.cppm -fsyntax-only -verify //--- same_as.cppm export module same_as; export template <class T, class U> concept same_as = __is_same(T, U); //--- concepts.cppm export module concepts; export import same_as; export template <class T> concept ConflictingConcept = true; //--- format.cppm export module format; export import concepts; export import same_as; export template <class T> void foo() requires same_as<T, int> {} //--- conflicting.cppm export module conflicting; export template <class T, class U = int> concept ConflictingConcept = true; //--- Use.cppm import format; import conflicting; template <class T> void foo() requires same_as<T, T> {} ConflictingConcept auto x = 10; // expected-error {{reference to 'ConflictingConcept' is ambiguous}} // expected-note@* 2 {{candidate}}