On Thu, Jan 17, 2013 at 5:25 AM, Jeffrey Lee Hellrung, Jr.
<jeffrey.hellrung@gmail.com> wrote:
The following snippet is the mock-up of the problem I am having in order to be able to reproduce.
--------------------------------------------------------------------------------
#include <iostream>
#include <boost/range.hpp>
#include <boost/range/adaptors.hpp>
#include <boost/range/algorithm.hpp>
#include <boost/bind.hpp>
#include <boost/assign.hpp>
using namespace boost::assign;
struct wxSize
{
wxSize(int height=0,int width=0):m_height(height),m_width(width)
{ }
int GetWidth() const {return m_width;}
int m_height;
int m_width;
};
class wxWindowBase
{
public:
wxSize GetTextExtent(const std::string val)
{
return wxSize(0,val.length());
}
void DoLayout(std::vector<std::string> m_FilteredItems)
{
using boost::adaptors::transformed;
wxSize longest = *boost::max_element(m_FilteredItems | transformed(boost::bind(&wxWindowBase::GetTextExtent,this,_1)),
boost::bind(std::less<int>(),boost::bind(&wxSize::GetWidth,_1),boost::bind(&wxSize::GetWidth,_2)));
std::cout <<longest.GetWidth();
}
};
int main()
{
std::vector<std::string> input;
input += "o","two","threexxx","four";
wxWindowBase window;
window.DoLayout(input);
}
-----------------------------------------------------------------------------------------
The above code fails to compile on GCC4.7.2 and MSVC10 although
it compiles and runs fine on clang3.3
From what I understand ,transformed returns a Single Pass Range and max_element expects a ForwardRange
and that's the gist of the problem.But it works for something like
max_element(someint_vector | transformed(doubleit()),std::less<int>()); without problems.
Is there a elegant way to achieve what I am trying to without using a intermediate container?
Thanks in advance..
I would try simplifying things (e.g., replace the uses of bind with explicit function objects; define an operator< for wxSize), then if you're still lost, paste the error (I don't have immediate access to MSVC 10 or gcc 4.7).
- Jeff
I am pretty convinced that Akira has nailed it. The problem was in the first line and in any case it does not make sense defining operator < for size objects unless you are comparing areas and as for functors I've used bind exclusively to avoid writing them (hence the std::less) .
Seeing that it compiles fine on clang I've disabled concept checks by defining BOOST_RANGE_ENABLE_CONCEPT_ASSERT 0 .
Apparently clang bypasses concept check or maybe it's disabled for that particular compiler (Is it?) . It works fine on both MSVC and gcc now. Although I might be shooting
myself in the foot
_______________________________________________
Boost-users mailing list
Boost-users@lists.boost.org
http://lists.boost.org/mailman/listinfo.cgi/boost-users