From f5965b387f5a6a991dd89697f74ba5e51b302d01 Mon Sep 17 00:00:00 2001 From: Daniela Engert Date: Sat, 29 May 2021 20:00:41 +0200 Subject: [PATCH] Re-enable module testing Prepare for compilation with gcc (modules branch). --- src/fmt.cc | 8 ++++++++ test/CMakeLists.txt | 4 ++-- test/module-test.cc | 6 ++++++ 3 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/fmt.cc b/src/fmt.cc index 728436ffca1d6..b4910336e7c64 100644 --- a/src/fmt.cc +++ b/src/fmt.cc @@ -75,6 +75,11 @@ export module fmt; #define FMT_END_DETAIL_NAMESPACE \ } \ export { + +#if defined(_MSC_FULL_VER) && _MSC_FULL_VER > 192930036 +#define FMT_USE_NONTYPE_TEMPLATE_PARAMETERS 0 +#endif + // all library-provided declarations and definitions // must be in the module purview to be exported #include "fmt/args.h" @@ -86,7 +91,10 @@ export module fmt; #include "fmt/printf.h" #include "fmt/xchar.h" +// gcc doesn't yet implement private module fragments +#if !FMT_GCC_VERSION module : private; +#endif #include "format.cc" #include "os.cc" diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index bd94b95ec23fc..abaef78a8e31d 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -94,10 +94,10 @@ if (FMT_CAN_MODULE) $) enable_module(test-module) - #add_fmt_test(module-test MODULE) + add_fmt_test(module-test MODULE) if (MSVC) target_compile_options(test-module PRIVATE /utf-8) - #target_compile_options(module-test PRIVATE /utf-8) + target_compile_options(module-test PRIVATE /utf-8) endif () endif () diff --git a/test/module-test.cc b/test/module-test.cc index fe38a79a344bf..f0399d4ee5b6d 100644 --- a/test/module-test.cc +++ b/test/module-test.cc @@ -9,6 +9,12 @@ // All Rights Reserved // {fmt} module. +#ifdef _MSC_FULL_VER +// hide some implementation bugs in msvc +// that are not essential to users of the module. +#define FMT_HIDE_MODULE_BUGS +#endif + #include #include #include