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":1038.5,"ttfb":350.5999994277954,"pageVisibility":"visible","entityId":124376,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":32,"apdex":0.5,"journeyId":"78ace182-8ab5-4213-93b6-881f7a16d028","navigationType":0,"readyForUser":1139.0999994277954,"redirectCount":0,"resourceLoadedEnd":1197.2999992370605,"resourceLoadedStart":356.5999994277954,"resourceTiming":[{"duration":86.40000057220459,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":356.5999994277954,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":356.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":443,"responseStart":0,"secureConnectionStart":0},{"duration":88,"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":356.8999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":356.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":444.8999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":145.4000005722046,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":357.0999994277954,"connectEnd":357.0999994277954,"connectStart":357.0999994277954,"domainLookupEnd":357.0999994277954,"domainLookupStart":357.0999994277954,"fetchStart":357.0999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":357.0999994277954,"responseEnd":502.5,"responseStart":502.5,"secureConnectionStart":357.0999994277954},{"duration":238.19999980926514,"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":357.19999980926514,"connectEnd":357.19999980926514,"connectStart":357.19999980926514,"domainLookupEnd":357.19999980926514,"domainLookupStart":357.19999980926514,"fetchStart":357.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":357.19999980926514,"responseEnd":595.3999996185303,"responseStart":595.3999996185303,"secureConnectionStart":357.19999980926514},{"duration":241.69999980926514,"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":357.5,"connectEnd":357.5,"connectStart":357.5,"domainLookupEnd":357.5,"domainLookupStart":357.5,"fetchStart":357.5,"redirectEnd":0,"redirectStart":0,"requestStart":357.5,"responseEnd":599.1999998092651,"responseStart":599.1999998092651,"secureConnectionStart":357.5},{"duration":242.0999994277954,"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":357.69999980926514,"connectEnd":357.69999980926514,"connectStart":357.69999980926514,"domainLookupEnd":357.69999980926514,"domainLookupStart":357.69999980926514,"fetchStart":357.69999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":357.69999980926514,"responseEnd":599.7999992370605,"responseStart":599.7999992370605,"secureConnectionStart":357.69999980926514},{"duration":242.4000005722046,"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":357.79999923706055,"connectEnd":357.79999923706055,"connectStart":357.79999923706055,"domainLookupEnd":357.79999923706055,"domainLookupStart":357.79999923706055,"fetchStart":357.79999923706055,"redirectEnd":0,"redirectStart":0,"requestStart":357.79999923706055,"responseEnd":600.1999998092651,"responseStart":600.1999998092651,"secureConnectionStart":357.79999923706055},{"duration":291.0999994277954,"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":358,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":358,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":649.0999994277954,"responseStart":0,"secureConnectionStart":0},{"duration":242.39999961853027,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":358.19999980926514,"connectEnd":358.19999980926514,"connectStart":358.19999980926514,"domainLookupEnd":358.19999980926514,"domainLookupStart":358.19999980926514,"fetchStart":358.19999980926514,"redirectEnd":0,"redirectStart":0,"requestStart":358.19999980926514,"responseEnd":600.5999994277954,"responseStart":600.5999994277954,"secureConnectionStart":358.19999980926514},{"duration":291,"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":358.3999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":358.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":649.3999996185303,"responseStart":0,"secureConnectionStart":0},{"duration":242.79999923706055,"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":358.5,"connectEnd":358.5,"connectStart":358.5,"domainLookupEnd":358.5,"domainLookupStart":358.5,"fetchStart":358.5,"redirectEnd":0,"redirectStart":0,"requestStart":358.5,"responseEnd":601.2999992370605,"responseStart":601.2999992370605,"secureConnectionStart":358.5},{"duration":799.5,"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":359.3999996185303,"connectEnd":359.3999996185303,"connectStart":359.3999996185303,"domainLookupEnd":359.3999996185303,"domainLookupStart":359.3999996185303,"fetchStart":359.3999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":359.3999996185303,"responseEnd":1158.8999996185303,"responseStart":1158.8999996185303,"secureConnectionStart":359.3999996185303},{"duration":799.7999992370605,"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":359.5,"connectEnd":359.5,"connectStart":359.5,"domainLookupEnd":359.5,"domainLookupStart":359.5,"fetchStart":359.5,"redirectEnd":0,"redirectStart":0,"requestStart":359.5,"responseEnd":1159.2999992370605,"responseStart":1159.2999992370605,"secureConnectionStart":359.5},{"duration":217.69999980926514,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":671.5999994277954,"connectEnd":671.5999994277954,"connectStart":671.5999994277954,"domainLookupEnd":671.5999994277954,"domainLookupStart":671.5999994277954,"fetchStart":671.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":671.5999994277954,"responseEnd":889.2999992370605,"responseStart":889.2999992370605,"secureConnectionStart":671.5999994277954},{"duration":262.69999980926514,"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":934.5999994277954,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":934.5999994277954,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1197.2999992370605,"responseStart":0,"secureConnectionStart":0},{"duration":344.5999994277954,"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":936,"connectEnd":936,"connectStart":936,"domainLookupEnd":936,"domainLookupStart":936,"fetchStart":936,"redirectEnd":0,"redirectStart":0,"requestStart":936,"responseEnd":1280.5999994277954,"responseStart":1280.5999994277954,"secureConnectionStart":936},{"duration":352.20000076293945,"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":936.2999992370605,"connectEnd":936.2999992370605,"connectStart":936.2999992370605,"domainLookupEnd":936.2999992370605,"domainLookupStart":936.2999992370605,"fetchStart":936.2999992370605,"redirectEnd":0,"redirectStart":0,"requestStart":936.2999992370605,"responseEnd":1288.5,"responseStart":1288.5,"secureConnectionStart":936.2999992370605},{"duration":297.30000019073486,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1031.8999996185303,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1031.8999996185303,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1329.1999998092651,"responseStart":0,"secureConnectionStart":0}],"fetchStart":1,"domainLookupStart":1,"domainLookupEnd":1,"connectStart":1,"connectEnd":1,"requestStart":141,"responseStart":351,"responseEnd":354,"domLoading":354,"domInteractive":1255,"domContentLoadedEventStart":1255,"domContentLoadedEventEnd":1321,"domComplete":1679,"loadEventStart":1679,"loadEventEnd":1679,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1216.2999992370605},{"name":"bigPipe.sidebar-id.end","time":1217.2999992370605},{"name":"bigPipe.activity-panel-pipe-id.start","time":1219.0999994277954},{"name":"bigPipe.activity-panel-pipe-id.end","time":1221.3999996185303},{"name":"activityTabFullyLoaded","time":1343}],"measures":[],"correlationId":"1a8d5ade9e07e9","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":144,"dbReadsTimeInMs":22,"dbConnsTimeInMs":32,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
I have proposed a fix at https://github.com/MariaDB/server/pull/2732 .