#include #include #include #include #include #include typedef CGAL::Simple_cartesian Kernel; typedef CGAL::Linear_cell_complex_traits<3, Kernel> LCC_traits; typedef CGAL::Linear_cell_complex_for_bgl_combinatorial_map_helper <2, 3, LCC_traits>::type LCC; typedef boost::graph_traits GraphTraits; typedef GraphTraits::vertex_descriptor vertex_descriptor; typedef GraphTraits::halfedge_descriptor halfedge_descriptor; typedef CGAL::Halfedge_around_target_iterator halfedge_around_target_iterator; template struct Source { const G* g; Source() : g(NULL) {} Source(const G& g) : g(&g) {} typedef typename boost::graph_traits::vertex_descriptor result_type; typedef typename boost::graph_traits::halfedge_descriptor argument_type; result_type operator()(argument_type h) const { return source(h, *g); } }; int main(int, char** argv) { LCC lcc; CGAL::read_off(argv[1], lcc); GraphTraits::vertex_descriptor vd = *(vertices(lcc).first); typedef boost::transform_iterator,halfedge_around_target_iterator> adjacent_vertex_iterator; halfedge_around_target_iterator hb,he; boost::tie(hb,he) = halfedges_around_target(halfedge(vd,lcc),lcc); adjacent_vertex_iterator avib, avie; avib = boost::make_transform_iterator(hb, Source(lcc)); avie = boost::make_transform_iterator(he, Source(lcc)); std::list V; std::copy(avib,avie, std::back_inserter(V)); return 0; }