Beispiel #1
0
        /// <summary>
        /// Main execution method
        /// </summary>
        /// <param name="programGraph"> Visual program to execute </param>
        /// <param name="writeToConsole"> Method to writing to console </param>
        public void Execute(Graph programGraph, Action <string> writeToConsole)
        {
            writeToMessageBox = writeToConsole;
            graph             = programGraph;

            NodeViewModel curNode = GetInitNode();

            if (curNode == null)
            {
                return;
            }

            writeToMessageBox("Running your code");
            var client = new MultirotorClient();

            while (curNode.Name != "aFinalNode")
            {
                Execution.ExecuteNode(curNode, client);
                curNode = Execution.GetNextNode(curNode, client);
                if (curNode == null)
                {
                    return;
                }
                writeToMessageBox($"Node {curNode.Name} done");
            }
            client.Land();
            client.Dispose();
            writeToMessageBox("Program done");
        }
Beispiel #2
0
 public virtual NodeViewModel GetNextNode(NodeViewModel node, MultirotorClient client)
 {
     if (graph.DataGraph.OutEdges(node).Count() > 1)
     {
         writeToMessageBox("Error: Node " + node.Name + " has more than the 1 out edge ");
         client.Dispose();
         return(null);
     }
     if (!graph.DataGraph.OutEdges(node).Any())
     {
         writeToMessageBox("Error: Node " + node.Name +
                           " has no out edges and it is not the final node ");
         client.Dispose();
         return(null);
     }
     return(graph.DataGraph.OutEdges(node).ToList()[0].Target);
 }
Beispiel #3
0
 public override NodeViewModel GetNextNode(NodeViewModel node, MultirotorClient client)
 {
     if (graph.DataGraph.OutEdges(node).Count() != 2)
     {
         writeToMessageBox("Error: ifNode out edges count is not equal 2 ");
         client.Dispose();
         return(null);
     }
     if (condition)
     {
         EdgeViewModel edge = graph.DataGraph.OutEdges(node).ToList()[0];
         return(edge.Attributes[0].Value == "true"
             ? edge.Target
             : graph.DataGraph.OutEdges(node).ToList()[1].Target);
     }
     else
     {
         EdgeViewModel edge = graph.DataGraph.OutEdges(node).ToList()[0];
         return(edge.Attributes[0].Value == "false"
             ? edge.Target
             : graph.DataGraph.OutEdges(node).ToList()[1].Target);
     }
 }