Date: Wed, 19 Mar 2008 16:10:02 GMT From: Jonathan Lennox <lennox@cs.columbia.edu> To: freebsd-multimedia@FreeBSD.org Subject: Re: ports/121707: fatal multimedia/vlc build error Message-ID: <200803191610.m2JGA2PT016041@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
The following reply was made to PR ports/121707; it has been noted by GNATS.
From: Jonathan Lennox <lennox@cs.columbia.edu>
To: bug-followup@FreeBSD.org,hg@cally.queue.to
Cc:
Subject: Re: ports/121707: fatal multimedia/vlc build error
Date: Wed, 19 Mar 2008 11:49:07 -0400
The actual build error here is the following:
mkv.cpp: In member function 'virtual bool dvd_chapter_codec_c::Enter()':
mkv.cpp:5848: error: no matching function for call to 'min(size_t&, long long unsigned int)'
mkv.cpp: In member function 'virtual bool dvd_chapter_codec_c::Leave()':
mkv.cpp:5871: error: no matching function for call to 'min(size_t&, long long unsigned int)'
I see this on FreeBSD 5.5 as well.
This occurs because there's a call to min (which is a template function)
taking arguments of type size_t and uint64_t, and min<size_t> and
min<unsigned long long> are equally good resolutions of that template.
The following patch file (added as,
e.g. multimedia/vlc/files/patch-modules_demux_mkv.cpp) fixes the problem by
making the choice of template instantiation explicit.
--- modules/demux/mkv.cpp.orig Sun Feb 24 14:01:53 2008
+++ modules/demux/mkv.cpp Wed Mar 19 11:45:02 2008
@@ -5845,7 +5845,7 @@ bool dvd_chapter_codec_c::Enter()
binary *p_data = (*index)->GetBuffer();
size_t i_size = *p_data++;
// avoid reading too much from the buffer
- i_size = min( i_size, ((*index)->GetSize() - 1) >> 3 );
+ i_size = min<size_t>( i_size, ((*index)->GetSize() - 1) >> 3 );
for ( ; i_size > 0; i_size--, p_data += 8 )
{
msg_Dbg( &sys.demuxer, "Matroska DVD enter command" );
@@ -5868,7 +5868,7 @@ bool dvd_chapter_codec_c::Leave()
binary *p_data = (*index)->GetBuffer();
size_t i_size = *p_data++;
// avoid reading too much from the buffer
- i_size = min( i_size, ((*index)->GetSize() - 1) >> 3 );
+ i_size = min<size_t>( i_size, ((*index)->GetSize() - 1) >> 3 );
for ( ; i_size > 0; i_size--, p_data += 8 )
{
msg_Dbg( &sys.demuxer, "Matroska DVD leave command" );
--
Jonathan Lennox
lennox@cs.columbia.edu
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200803191610.m2JGA2PT016041>
