MariaDB fails to build with the latest libfmt 10.1.0 (https://github.com/fmtlib/fmt/releases/tag/10.1.0 ). CMake configuration fails with the following:
CMake Error at cmake/libfmt.cmake:45 (MESSAGE):
system libfmt library is not found or unusable
The underlying error is that the code snippet in cmake/libfmt.cmake fails to compile (compiler explorer: https://godbolt.org/z/bWGoW55x3 ):
#define FMT_STATIC_THOUSANDS_SEPARATOR ','
#define FMT_HEADER_ONLY 1
#include <fmt/format-inl.h>
#include <iostream>
int main() {
fmt::format_args::format_arg arg=
fmt::detail::make_arg<fmt::format_context>(42);
std::cout << fmt::vformat( "The answer is {}." ,
fmt::format_args(&arg, 1));
}
<source>: In function 'int main()':
<source>:7:47: error: no matching function for call to 'make_arg<fmt::v10::format_context>(int)'
7 | fmt::detail::make_arg<fmt::format_context>(42);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~
In file included from /opt/compiler-explorer/libs/fmt/trunk/include/fmt/format.h:49,
from /opt/compiler-explorer/libs/fmt/trunk/include/fmt/format-inl.h:25,
from <source>:3:
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1588:20: note: candidate: 'constexpr fmt::v10::basic_format_arg<Context> fmt::v10::detail::make_arg(T&) [with Context = fmt::v10::basic_format_context<fmt::v10::appender, char>; T = int]' (near match)
1588 | FMT_CONSTEXPR auto make_arg(T& val) -> basic_format_arg<Context> {
| ^~~~~~~~
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1588:20: note: conversion of argument 1 would be ill-formed:
<source>:7:48: error: cannot bind non-const lvalue reference of type 'int&' to an rvalue of type 'int'
7 | fmt::detail::make_arg<fmt::format_context>(42);
| ^~
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1559:31: note: candidate: 'template<bool PACKED, class Context, class T, typename std::enable_if<PACKED, int>::type <anonymous> > constexpr fmt::v10::detail::value<Context> fmt::v10::detail::make_arg(T&)'
1559 | FMT_CONSTEXPR FMT_INLINE auto make_arg(T& val) -> value<Context> {
| ^~~~~~~~
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1559:31: note: template argument deduction/substitution failed:
<source>:7:47: error: type/value mismatch at argument 1 in template parameter list for 'template<bool PACKED, class Context, class T, typename std::enable_if<PACKED, int>::type <anonymous> > constexpr fmt::v10::detail::value<Context> fmt::v10::detail::make_arg(T&)'
7 | fmt::detail::make_arg<fmt::format_context>(42);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~
<source>:7:47: note: expected a constant of type 'bool', got 'fmt::v10::format_context' {aka 'fmt::v10::basic_format_context<fmt::v10::appender, char>'}
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1596:27: note: candidate: 'template<bool PACKED, class Context, class T, typename std::enable_if<(! PACKED), int>::type <anonymous> > constexpr fmt::v10::basic_format_arg<Context> fmt::v10::detail::make_arg(T&)'
1596 | FMT_CONSTEXPR inline auto make_arg(T& val) -> basic_format_arg<Context> {
| ^~~~~~~~
/opt/compiler-explorer/libs/fmt/trunk/include/fmt/core.h:1596:27: note: template argument deduction/substitution failed:
<source>:7:47: error: type/value mismatch at argument 1 in template parameter list for 'template<bool PACKED, class Context, class T, typename std::enable_if<(! PACKED), int>::type <anonymous> > constexpr fmt::v10::basic_format_arg<Context> fmt::v10::detail::make_arg(T&)'
7 | fmt::detail::make_arg<fmt::format_context>(42);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~
<source>:7:47: note: expected a constant of type 'bool', got 'fmt::v10::format_context' {aka 'fmt::v10::basic_format_context<fmt::v10::appender, char>'}
Compiler returned: 1
sql/item_strfunc.cc also fails to compile, with basically the same error. Error output can be found in the attachment item_strfunc.log .
The reason behind this is that fmt::detail::make_arg does not accept temporaries, as mentioned in https://github.com/fmtlib/fmt/issues/3596#issuecomment-1679244746 .
This error was observed while packaging MariaDB 10.9.8 (https://github.com/Homebrew/homebrew-core/pull/139568 ), 10.10.6 (https://github.com/Homebrew/homebrew-core/pull/139563 ), 10.11.5 (https://github.com/Homebrew/homebrew-core/pull/139564 ), and 11.0.3 (https://github.com/Homebrew/homebrew-core/pull/139562 ) for Homebrew. I believe that this also affects all other versions where libfmt is used, including the newest 11.3 that's still under development.
is duplicated by
MDEV-32564
Mariadb not detect libfmt libs existing in system
Closed
Ruoyu Zhong
made changes -
2023-08-20 12:18
Field
Original Value
New Value
Summary
MariaDB
MariaDB fails to build with libfmt 10.1.0
Sergei Golubchik
made changes -
2023-08-20 20:24
Priority
Minor
[ 4
]
Major
[ 3
]
Daniel Black
made changes -
2023-08-28 05:52
issue.field.resolutiondate
2023-08-28 05:52:10.0
2023-08-28 05:52:10.338
Daniel Black
made changes -
2023-08-28 05:52
Fix Version/s
10.10.7
[ 29018
]
Fix Version/s
10.11.6
[ 29020
]
Fix Version/s
11.0.4
[ 29021
]
Fix Version/s
11.1.3
[ 29023
]
Fix Version/s
11.2.2
[ 29035
]
Assignee
Daniel Black
[ danblack
]
Resolution
Fixed
[ 1
]
Status
Open
[ 1
]
Closed
[ 6
]
{"report":{"fcp":1041.8000001907349,"ttfb":312.30000019073486,"pageVisibility":"visible","entityId":124376,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":32,"apdex":0.5,"journeyId":"e42236e0-e15e-443c-964a-b47932cf836b","navigationType":0,"readyForUser":1127.0999994277954,"redirectCount":0,"resourceLoadedEnd":1471.5999994277954,"resourceLoadedStart":317.3999996185303,"resourceTiming":[{"duration":197.19999980926514,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":317.3999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":317.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":514.5999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":197.39999961853027,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/css/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":317.69999980926514,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":317.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":515.0999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":251.69999980926514,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":317.8999996185303,"connectEnd":317.8999996185303,"connectStart":317.8999996185303,"domainLookupEnd":317.8999996185303,"domainLookupStart":317.8999996185303,"fetchStart":317.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":317.8999996185303,"responseEnd":569.5999994277954,"responseStart":569.5999994277954,"secureConnectionStart":317.8999996185303},{"duration":313.70000076293945,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/js/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":318.0999994277954,"connectEnd":318.0999994277954,"connectStart":318.0999994277954,"domainLookupEnd":318.0999994277954,"domainLookupStart":318.0999994277954,"fetchStart":318.0999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":318.0999994277954,"responseEnd":631.8000001907349,"responseStart":631.8000001907349,"secureConnectionStart":318.0999994277954},{"duration":317.0999994277954,"initiatorType":"script","name":"https://jira.mariadb.org/s/a9324d6758d385eb45c462685ad88f1d-CDN/lu2cib/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":318.30000019073486,"connectEnd":318.30000019073486,"connectStart":318.30000019073486,"domainLookupEnd":318.30000019073486,"domainLookupStart":318.30000019073486,"fetchStart":318.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":318.30000019073486,"responseEnd":635.3999996185303,"responseStart":635.3999996185303,"secureConnectionStart":318.30000019073486},{"duration":317.3999996185303,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":318.5,"connectEnd":318.5,"connectStart":318.5,"domainLookupEnd":318.5,"domainLookupStart":318.5,"fetchStart":318.5,"redirectEnd":0,"redirectStart":0,"requestStart":318.5,"responseEnd":635.8999996185303,"responseStart":635.8999996185303,"secureConnectionStart":318.5},{"duration":317.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":318.69999980926514,"connectEnd":318.69999980926514,"connectStart":318.69999980926514,"domainLookupEnd":318.69999980926514,"domainLookupStart":318.69999980926514,"fetchStart":318.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":318.69999980926514,"responseEnd":636.1999998092651,"responseStart":636.1999998092651,"secureConnectionStart":318.69999980926514},{"duration":392.4000005722046,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2cib/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":318.8999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":318.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":711.3000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":317.69999980926514,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":319,"connectEnd":319,"connectStart":319,"domainLookupEnd":319,"domainLookupStart":319,"fetchStart":319,"redirectEnd":0,"redirectStart":0,"requestStart":319,"responseEnd":636.6999998092651,"responseStart":636.6999998092651,"secureConnectionStart":319},{"duration":392.30000019073486,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.css?jira.create.linked.issue=true","startTime":319.0999994277954,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":319.0999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":711.3999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":317.8999996185303,"initiatorType":"script","name":"https://jira.mariadb.org/s/5d5e8fe91fbc506585e83ea3b62ccc4b-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.js?jira.create.linked.issue=true&locale=en","startTime":319.30000019073486,"connectEnd":319.30000019073486,"connectStart":319.30000019073486,"domainLookupEnd":319.30000019073486,"domainLookupStart":319.30000019073486,"fetchStart":319.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":319.30000019073486,"responseEnd":637.1999998092651,"responseStart":637.1999998092651,"secureConnectionStart":319.30000019073486},{"duration":1126.1000003814697,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":324.5999994277954,"connectEnd":324.5999994277954,"connectStart":324.5999994277954,"domainLookupEnd":324.5999994277954,"domainLookupStart":324.5999994277954,"fetchStart":324.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":324.5999994277954,"responseEnd":1450.6999998092651,"responseStart":1450.6999998092651,"secureConnectionStart":324.5999994277954},{"duration":1127.1999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":324.69999980926514,"connectEnd":324.69999980926514,"connectStart":324.69999980926514,"domainLookupEnd":324.69999980926514,"domainLookupStart":324.69999980926514,"fetchStart":324.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":324.69999980926514,"responseEnd":1451.8999996185303,"responseStart":1451.8999996185303,"secureConnectionStart":324.69999980926514},{"duration":222.89999961853027,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":722.6999998092651,"connectEnd":722.6999998092651,"connectStart":722.6999998092651,"domainLookupEnd":722.6999998092651,"domainLookupStart":722.6999998092651,"fetchStart":722.6999998092651,"redirectEnd":0,"redirectStart":0,"requestStart":722.6999998092651,"responseEnd":945.5999994277954,"responseStart":945.5999994277954,"secureConnectionStart":722.6999998092651},{"duration":489.5,"initiatorType":"link","name":"https://jira.mariadb.org/s/d5715adaadd168a9002b108b2b039b50-CDN/lu2cib/820016/12ta74/be4b45e9cec53099498fa61c8b7acba4/_/download/contextbatch/css/jira.project.sidebar,-_super,-project.issue.navigator,-jira.general,-jira.browse.project,-jira.view.issue,-jira.global,-atl.general,-com.atlassian.jira.projects.sidebar.init/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":982.0999994277954,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":982.0999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1471.5999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":501,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/e65b778d185daf5aee24936755b43da6/_/download/contextbatch/js/browser-metrics-plugin.contrib,-_super,-project.issue.navigator,-jira.view.issue,-atl.general/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":982.8999996185303,"connectEnd":982.8999996185303,"connectStart":982.8999996185303,"domainLookupEnd":982.8999996185303,"domainLookupStart":982.8999996185303,"fetchStart":982.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":982.8999996185303,"responseEnd":1483.8999996185303,"responseStart":1483.8999996185303,"secureConnectionStart":982.8999996185303},{"duration":514.6999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/s/097ae97cb8fbec7d6ea4bbb1f26955b9-CDN/lu2cib/820016/12ta74/be4b45e9cec53099498fa61c8b7acba4/_/download/contextbatch/js/jira.project.sidebar,-_super,-project.issue.navigator,-jira.general,-jira.browse.project,-jira.view.issue,-jira.global,-atl.general,-com.atlassian.jira.projects.sidebar.init/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":983.3000001907349,"connectEnd":983.3000001907349,"connectStart":983.3000001907349,"domainLookupEnd":983.3000001907349,"domainLookupStart":983.3000001907349,"fetchStart":983.3000001907349,"redirectEnd":0,"redirectStart":0,"requestStart":983.3000001907349,"responseEnd":1498,"responseStart":1498,"secureConnectionStart":983.3000001907349}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":112,"responseStart":312,"responseEnd":318,"domLoading":315,"domInteractive":1475,"domContentLoadedEventStart":1475,"domContentLoadedEventEnd":1518,"domComplete":1835,"loadEventStart":1835,"loadEventEnd":1836,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1454.1999998092651},{"name":"bigPipe.sidebar-id.end","time":1455.0999994277954},{"name":"bigPipe.activity-panel-pipe-id.start","time":1455.1999998092651},{"name":"bigPipe.activity-panel-pipe-id.end","time":1457.1999998092651},{"name":"activityTabFullyLoaded","time":1535}],"measures":[],"correlationId":"6e24d19b6c2d7c","effectiveType":"4g","downlink":9,"rtt":0,"serverDuration":132,"dbReadsTimeInMs":22,"dbConnsTimeInMs":33,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}