X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fgraph.C;h=93533274320245531a83823130879494b04840c7;hb=b9aa557b359463dfb0a2132b665570c8d1e5d605;hp=054799fb9292fc25dc0ad8754abeb75c901d4925;hpb=468df2b583da2c202a48808e64afd822a8319866;p=lyx.git diff --git a/src/graph.C b/src/graph.C index 054799fb92..9353327432 100644 --- a/src/graph.C +++ b/src/graph.C @@ -5,20 +5,22 @@ * * \author Dekel Tsur * - * Full author contact details are available in file CREDITS + * Full author contact details are available in file CREDITS. */ -#include "config.h" +#include + #include "graph.h" #include "format.h" -#include -#include #include -using std::queue; -using std::vector; +namespace lyx { + +using std::vector; +using std::reverse; +using std::fill; int Graph::bfs_init(int s, bool clear_visited) @@ -79,11 +81,14 @@ Graph::getReachable(int from, bool only_viewable, int const i = Q_.front(); Q_.pop(); Format const & format = formats.get(i); - if (format.name() == "lyx") - continue; - if (!only_viewable || !format.viewer().empty() || - format.isChildFormat()) + if (!only_viewable || !format.viewer().empty()) result.push_back(i); + else if (format.isChildFormat()) { + Format const * const parent = + formats.getFormat(format.parentFormat()); + if (parent && !parent->viewer().empty()) + result.push_back(i); + } vector::const_iterator cit = vertices_[i].out_vertices.begin(); @@ -195,3 +200,6 @@ void Graph::addEdge(int s, int t) } vector Graph::vertices_; + + +} // namespace lyx