#6858 closed Bugs (fixed)
boost::get() calls wrongly resolved by g++
Reported by: | Owned by: | ebf | |
---|---|---|---|
Milestone: | To Be Determined | Component: | variant |
Version: | Boost 1.49.0 | Severity: | Problem |
Keywords: | Cc: |
Description
Boost 1.49.0 seems to make g++ wrongly resolve some calls to boost::get()
.
The attached C++ code boost-get-test-ko.cc
does not compile properly with all the g++ compiler I used (Apple g++ 4.2, MacPorts g++ 4.4, 4.5, 4.6, 4.7) on my machine (2010 MacBook Pro w/ Mac OS X version 10.6.8 and Boost 1.49.0 from the MacPorts). These compilers try to use boost::get()
from boost/graph/reverse_graph.hpp
instead of boost::get()
from boost/variant/get.hpp
, leading to this kind of error messages:
% g++-mp-4.7 -I/opt/local/include boost-get-test-ko.cc In file included from /opt/local/include/boost/graph/vector_as_graph.hpp:23:0, from /opt/local/include/boost/graph/transitive_closure.hpp:17, from boost-get-test-ko.cc:2: /opt/local/include/boost/graph/graph_traits.hpp: In instantiation of 'struct boost::graph_traits<int>': /opt/local/include/boost/graph/reverse_graph.hpp:472:1: required by substitution of 'template<class Graph, class GRef> typename boost::graph_traits<Graph>::edge_descriptor boost::get(boost::edge_underlying_t, const boost::reverse_graph<BidirectionalGraph, GraphRef>&, const typename boost::graph_traits<boost::reverse_graph<BidirectionalGraph, GraphRef> >::edge_descriptor&) [with Graph = int; GRef = <missing>]' boost-get-test-ko.cc:7:28: required from here /opt/local/include/boost/graph/graph_traits.hpp:30:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:31:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:32:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:33:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:34:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:35:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:36:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:38:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:39:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:40:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:42:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:43:52: error: 'int' is not a class, struct, or union type /opt/local/include/boost/graph/graph_traits.hpp:44:52: error: 'int' is not a class, struct, or union type
If the #include <boost/graph/transitive_closure.hpp>
statement is removed (see attached file boost-get-test-ok.cc
, no compiling error arises.
This problem looks very similar to ticket #4838.
I have obtained similar results with SVN Boost on this platform as well as on Debian GNU/Linux 6.0.4 on x86-64 with g++ 4.4.
The versions of clang++ I tried (MacPorts clang++ 2.9, 3.0 and 3.1 on Mac OS X version 10.6 and clang 3.0 on Debian GNU/Linux 6.0.4) have no trouble compiling both files.
Attachments (2)
Change History (5)
by , 10 years ago
Attachment: | boost-get-test-ko.cc added |
---|
by , 10 years ago
Attachment: | boost-get-test-ok.cc added |
---|
comment:1 by , 10 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
follow-up: 3 comment:2 by , 10 years ago
I've changed reverse_graph
to use enable_if
to work around this problem; that might break compilers with weak SFINAE support, however.
comment:3 by , 10 years ago
Replying to jewillco:
I've changed
reverse_graph
to useenable_if
to work around this problem; that might break compilers with weak SFINAE support, however.
Thanks!
(In [78315]) Edited reverse_graph to fix test case; fixes #6858