예제 #1
0
        private static bool ExtractLastIf(DoStatement stat)
        {
            // search for an if condition at the end of the loop
            Statement last = stat.GetFirst();

            while (last.type == Statement.Type_Sequence)
            {
                last = last.GetStats().GetLast();
            }
            if (last.type == Statement.Type_If)
            {
                IfStatement lastif = (IfStatement)last;
                if (lastif.iftype == IfStatement.Iftype_If && lastif.GetIfstat() != null)
                {
                    Statement ifstat   = lastif.GetIfstat();
                    StatEdge  elseedge = lastif.GetAllSuccessorEdges()[0];
                    if (elseedge.GetType() == StatEdge.Type_Continue && elseedge.closure == stat)
                    {
                        HashSet <Statement> set = stat.GetNeighboursSet(StatEdge.Type_Continue, Statement.
                                                                        Direction_Backward);
                        set.Remove(last);
                        if ((set.Count == 0))
                        {
                            // no direct continues in a do{}while loop
                            if (IsExternStatement(stat, ifstat, ifstat))
                            {
                                ExtractIfBlock(stat, lastif);
                                return(true);
                            }
                        }
                    }
                }
            }
            return(false);
        }
예제 #2
0
        private static void MatchDoWhile(DoStatement stat)
        {
            // search for an if condition at the end of the loop
            Statement last = stat.GetFirst();

            while (last.type == Statement.Type_Sequence)
            {
                last = last.GetStats().GetLast();
            }
            if (last.type == Statement.Type_If)
            {
                IfStatement lastif = (IfStatement)last;
                if (lastif.iftype == IfStatement.Iftype_If && lastif.GetIfstat() == null)
                {
                    StatEdge ifedge   = lastif.GetIfEdge();
                    StatEdge elseedge = lastif.GetAllSuccessorEdges()[0];
                    if ((ifedge.GetType() == StatEdge.Type_Break && elseedge.GetType() == StatEdge.Type_Continue &&
                         elseedge.closure == stat && IsDirectPath(stat, ifedge.GetDestination())) ||
                        (ifedge.GetType() == StatEdge.Type_Continue && elseedge.GetType() == StatEdge.Type_Break &&
                         ifedge.closure == stat && IsDirectPath(stat, elseedge.GetDestination())))
                    {
                        HashSet <Statement> set = stat.GetNeighboursSet(StatEdge.Type_Continue, Statement.
                                                                        Direction_Backward);
                        set.Remove(last);
                        if (!(set.Count == 0))
                        {
                            return;
                        }
                        stat.SetLooptype(DoStatement.Loop_Dowhile);
                        IfExprent ifexpr = (IfExprent)lastif.GetHeadexprent().Copy();
                        if (ifedge.GetType() == StatEdge.Type_Break)
                        {
                            ifexpr.NegateIf();
                        }
                        stat.SetConditionExprent(ifexpr.GetCondition());
                        lastif.GetFirst().RemoveSuccessor(ifedge);
                        lastif.RemoveSuccessor(elseedge);
                        // remove empty if
                        if ((lastif.GetFirst().GetExprents().Count == 0))
                        {
                            RemoveLastEmptyStatement(stat, lastif);
                        }
                        else
                        {
                            lastif.SetExprents(lastif.GetFirst().GetExprents());
                            StatEdge newedge = new StatEdge(StatEdge.Type_Continue, lastif, stat);
                            lastif.AddSuccessor(newedge);
                            stat.AddLabeledEdge(newedge);
                        }
                        if ((stat.GetAllSuccessorEdges().Count == 0))
                        {
                            StatEdge edge = elseedge.GetType() == StatEdge.Type_Continue ? ifedge : elseedge;
                            edge.SetSource(stat);
                            if (edge.closure == stat)
                            {
                                edge.closure = stat.GetParent();
                            }
                            stat.AddSuccessor(edge);
                        }
                    }
                }
            }
        }
예제 #3
0
        private static void MatchFor(DoStatement stat)
        {
            Exprent   lastDoExprent;
            Exprent   initDoExprent;
            Statement lastData;
            Statement preData = null;

            // get last exprent
            lastData = GetLastDirectData(stat.GetFirst());
            if (lastData == null || (lastData.GetExprents().Count == 0))
            {
                return;
            }
            List <Exprent> lstExpr = lastData.GetExprents();

            lastDoExprent = lstExpr[lstExpr.Count - 1];
            bool issingle = false;

            if (lstExpr.Count == 1)
            {
                // single exprent
                if (lastData.GetAllPredecessorEdges().Count > 1)
                {
                    // break edges
                    issingle = true;
                }
            }
            bool haslast = issingle || lastDoExprent.type == Exprent.Exprent_Assignment || lastDoExprent
                           .type == Exprent.Exprent_Function;

            if (!haslast)
            {
                return;
            }
            bool hasinit = false;
            // search for an initializing exprent
            Statement current = stat;

            while (true)
            {
                Statement parent = current.GetParent();
                if (parent == null)
                {
                    break;
                }
                if (parent.type == Statement.Type_Sequence)
                {
                    if (current == parent.GetFirst())
                    {
                        current = parent;
                    }
                    else
                    {
                        preData = current.GetNeighbours(StatEdge.Type_Regular, Statement.Direction_Backward
                                                        )[0];
                        preData = GetLastDirectData(preData);
                        if (preData != null && !(preData.GetExprents().Count == 0))
                        {
                            initDoExprent = preData.GetExprents()[preData.GetExprents().Count - 1];
                            if (initDoExprent.type == Exprent.Exprent_Assignment)
                            {
                                hasinit = true;
                            }
                        }
                        break;
                    }
                }
                else
                {
                    break;
                }
            }
            if (hasinit || issingle)
            {
                // FIXME: issingle sufficient?
                HashSet <Statement> set = stat.GetNeighboursSet(StatEdge.Type_Continue, Statement.
                                                                Direction_Backward);
                set.Remove(lastData);
                if (!(set.Count == 0))
                {
                    return;
                }
                stat.SetLooptype(DoStatement.Loop_For);
                if (hasinit)
                {
                    stat.SetInitExprent(preData.GetExprents().RemoveAtReturningValue(preData.GetExprents
                                                                                         ().Count - 1));
                }
                stat.SetIncExprent(lastData.GetExprents().RemoveAtReturningValue(lastData.GetExprents
                                                                                     ().Count - 1));
            }
            if ((lastData.GetExprents().Count == 0))
            {
                List <StatEdge> lst = lastData.GetAllSuccessorEdges();
                if (!(lst.Count == 0))
                {
                    lastData.RemoveSuccessor(lst[0]);
                }
                RemoveLastEmptyStatement(stat, lastData);
            }
        }