boost graph library, default_dfs_visitor, dfs
data:image/s3,"s3://crabby-images/93260/9326051334f47c5a59ee9b9181a4bccb512a264a" alt=""
Hi
Please see the code below.
class my_visitor: public default_dfs_visitor {
public:
my_visitor(){}
void finish_vertex(Vertex u, const Graph & g);
vector<Vertex> getFinishingOrder(void){return finishingOrder;}
//private:
vector<Vertex> finishingOrder;//stores the vertices in the finishing
order
};
template
data:image/s3,"s3://crabby-images/7f777/7f7771ee86c5da2a699be0810d7d84c1bc346101" alt=""
Hi!
My problem: size of the finishingOrder vector is zero outside the my_visitor::finish_vertex method. I checked its size inside the my_visitor::finish_vertex method and its value is increasing...
All visitors have to be copy constructible and depth_first_search will operate on the copied object. Gabe
data:image/s3,"s3://crabby-images/a55a6/a55a6d41dc1a1e54f17e10a97169b73ea4c3700b" alt=""
My problem: size of the finishingOrder vector is zero outside the my_visitor::finish_vertex method. I checked its size inside the my_visitor::finish_vertex method and its value is increasing...
All visitors have to be copy constructible and depth_first_search will operate on the copied object.
Actually, it's the fact that the visitor is copied that's causing the problem. The visitor needs to declare it's vector member as a reference (to a vector declared somewhere else). For example: struct my_visitor : default_dfs_visitor { my_visitor(vector<Vertex>& order) : finishingOrder(order) { } vector<Vertex>& finishingOrder; }; Andrew Sutton andrew.n.sutton@gmail.com
data:image/s3,"s3://crabby-images/7afac/7afacd1c1b7921c9863436fda35e4a28f306363d" alt=""
I understood, thanks Andrew Sutton,
suresh
On Wed, Dec 16, 2009 at 5:52 AM, Andrew Sutton
My problem: size of the finishingOrder vector is zero outside the my_visitor::finish_vertex method. I checked its size inside the my_visitor::finish_vertex method and its value is increasing...
All visitors have to be copy constructible and depth_first_search will operate on the copied object.
Actually, it's the fact that the visitor is copied that's causing the problem. The visitor needs to declare it's vector member as a reference (to a vector declared somewhere else). For example:
struct my_visitor : default_dfs_visitor { my_visitor(vector<Vertex>& order) : finishingOrder(order) { } vector<Vertex>& finishingOrder; };
Andrew Sutton andrew.n.sutton@gmail.com
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
-- R. Suresh Kumar PhD Student, Vislab #216, Engineering II Bldg University of California, Riverside, CA 92521
participants (4)
-
Andrew Sutton
-
Gábor Szuromi
-
List User
-
Suresh Kumar