maintainer-feedback requested: [Bug 274740] www/qt5-webengine: fix build with libc++ 17
bugzilla-noreply at freebsd.org
bugzilla-noreply at freebsd.org
Thu Oct 26 17:30:09 BST 2023
Bugzilla Automation <bugzilla at FreeBSD.org> has asked freebsd-kde (group)
<kde at FreeBSD.org> for maintainer-feedback:
Bug 274740: www/qt5-webengine: fix build with libc++ 17
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=274740
--- Description ---
Building www/qt5-webengine with libc++ 17 results in the following
compile errors:
In file included from
../../../../kde-qtwebengine-5.15.15p0/src/3rdparty/chromium/third_party/perfett
o/src/trace_processor/trace_sorter.cc:17:
In file included from /usr/include/c++/v1/algorithm:1803:
In file included from /usr/include/c++/v1/__algorithm/nth_element.h:15:
/usr/include/c++/v1/__algorithm/sort.h:577:14: error: no viable overloaded
'='
577 | *__begin = _Ops::__iter_move(__pivot_pos);
| ~~~~~~~~ ^ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/usr/include/c++/v1/__algorithm/sort.h:802:20: note: in instantiation of
function template specialization
'std::__bitset_partition<std::_ClassicAlgPolicy,
perfetto::base::CircularQueue<perfetto::trace_processor::TimestampedTracePiece>
::Iterator,
std::__less<void, void> &>' requested here
802 | ? std::__bitset_partition<_AlgPolicy,
_RandomAccessIterator, _Compare>(__first, __last, __comp)
| ^
/usr/include/c++/v1/__algorithm/sort.h:878:8: note: in instantiation of
function template specialization 'std::__introsort<std::_ClassicAlgPolicy,
std::__less<void, void> &,
perfetto::base::CircularQueue<perfetto::trace_processor::TimestampedTracePiece>
::Iterator,
false>' requested here
878 | std::__introsort<_AlgPolicy,
| ^
/usr/include/c++/v1/__algorithm/sort.h:946:10: note: in instantiation of
function template specialization 'std::__sort_dispatch<std::_ClassicAlgPolicy,
perfetto::base::CircularQueue<perfetto::trace_processor::TimestampedTracePiece>
::Iterator,
std::__less<void, void>>' requested here
946 | std::__sort_dispatch<_AlgPolicy>(std::__unwrap_iter(__first),
std::__unwrap_iter(__last), __comp);
| ^
/usr/include/c++/v1/__algorithm/sort.h:954:8: note: in instantiation of
function template specialization 'std::__sort_impl<std::_ClassicAlgPolicy,
perfetto::base::CircularQueue<perfetto::trace_processor::TimestampedTracePiece>
::Iterator,
std::__less<void, void>>' requested here
954 | std::__sort_impl<_ClassicAlgPolicy>(std::move(__first),
std::move(__last), __comp);
| ^
/usr/include/c++/v1/__algorithm/sort.h:960:8: note: in instantiation of
function template specialization
'std::sort<perfetto::base::CircularQueue<perfetto::trace_processor::Timestamped
TracePiece>::Iterator,
std::__less<void, void>>' requested here
960 | std::sort(__first, __last, __less<>());
| ^
../../../../kde-qtwebengine-5.15.15p0/src/3rdparty/chromium/third_party/perfett
o/src/trace_processor/trace_sorter.cc:51:8:
note: in instantiation of function template specialization
'std::sort<perfetto::base::CircularQueue<perfetto::trace_processor::Timestamped
TracePiece>::Iterator>'
requested here
51 | std::sort(sort_begin, events_.end());
| ^
../../../../kde-qtwebengine-5.15.15p0/src/3rdparty/chromium/third_party/perfett
o/src/trace_processor/timestamped_trace_piece.h:191:26:
note: candidate function not viable: 'this' argument has type 'const
perfetto::trace_processor::TimestampedTracePiece', but method is not marked
const
191 | TimestampedTracePiece& operator=(TimestampedTracePiece&& ttp) {
| ^
../../../../kde-qtwebengine-5.15.15p0/src/3rdparty/chromium/third_party/perfett
o/src/trace_processor/timestamped_trace_piece.h:202:26:
note: candidate function not viable: 'this' argument has type 'const
perfetto::trace_processor::TimestampedTracePiece', but method is not marked
const
202 | TimestampedTracePiece& operator=(const TimestampedTracePiece&) =
delete;
| ^
This is because perfetto's CircularQueue template is only half
const-correct. Upstream fixed this in:
https://github.com/google/perfetto/commit/b82a213bcf71dd8e68b53941375936c7905c0
ff2
so apply that fix to qt5-webengine's older copy of perfetto.
More information about the kde-freebsd
mailing list