// RUN: rm -rf %t
// RUN: mkdir -p %t
// RUN: split-file %s %t
//
// RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/Cache.cppm -o %t/Cache.pcm
// RUN: %clang_cc1 -std=c++20 %t/Use.cpp -fmodule-file=Fibonacci.Cache=%t/Cache.pcm \
// RUN: -fsyntax-only -verify
// RUN: %clang_cc1 -std=c++20 -emit-reduced-module-interface %t/Cache.cppm -o %t/Cache.pcm
// RUN: %clang_cc1 -std=c++20 %t/Use.cpp -fmodule-file=Fibonacci.Cache=%t/Cache.pcm \
// RUN: -fsyntax-only -verify
//--- Cache.cppm
export module Fibonacci.Cache;
export namespace Fibonacci
{
constexpr unsigned long Recursive(unsigned long n)
{
if (n == 0)
return 0;
if (n == 1)
return 1;
return Recursive(n - 2) + Recursive(n - 1);
}
template<unsigned long N>
struct Number{};
struct DefaultStrategy
{
constexpr unsigned long operator()(unsigned long n, auto... other) const
{
return (n + ... + other);
}
};
constexpr unsigned long Compute(Number<10ul>, auto strategy)
{
return strategy(Recursive(10ul));
}
template<unsigned long N, typename Strategy = DefaultStrategy>
constexpr unsigned long Cache = Compute(Number<N>{}, Strategy{});
template constexpr unsigned long Cache<10ul>;
}
//--- Use.cpp
// expected-no-diagnostics
import Fibonacci.Cache;
constexpr bool value = Fibonacci::Cache<10ul> == 55;
static_assert(value == true, "");