summaryrefslogtreecommitdiffstats
path: root/src/server/PatchImpl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/PatchImpl.cpp')
-rw-r--r--src/server/PatchImpl.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/server/PatchImpl.cpp b/src/server/PatchImpl.cpp
index de1fe43f..95bb2132 100644
--- a/src/server/PatchImpl.cpp
+++ b/src/server/PatchImpl.cpp
@@ -424,6 +424,23 @@ PatchImpl::build_ports_array() const
return result;
}
+static inline void
+compile_recursive(NodeImpl* n, CompiledPatch* output)
+{
+ if (n == NULL || n->traversed())
+ return;
+
+ n->traversed(true);
+ assert(output != NULL);
+
+ for (std::list<NodeImpl*>::iterator i = n->providers().begin();
+ i != n->providers().end(); ++i)
+ if (!(*i)->traversed())
+ compile_recursive(*i, output);
+
+ output->push_back(CompiledNode(n, n->providers().size(), n->dependants()));
+}
+
/** Find the process order for this Patch.
*
* The process order is a flat list that the patch will execute in order