/* * Copyright (C) 2010-2013 JPEXS * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ package com.jpexs.decompiler.graph.model; import com.jpexs.decompiler.flash.helpers.GraphTextWriter; import com.jpexs.decompiler.flash.helpers.LoopWithType; import com.jpexs.decompiler.flash.helpers.NulWriter; import com.jpexs.decompiler.graph.Block; import com.jpexs.decompiler.graph.GraphSourceItem; import com.jpexs.decompiler.graph.GraphTargetItem; import com.jpexs.decompiler.graph.Loop; import com.jpexs.decompiler.graph.SourceGenerator; import java.util.ArrayList; import java.util.List; public class ForItem extends LoopItem implements Block { public List firstCommands; public GraphTargetItem expression; public List finalCommands; public List commands; private boolean labelUsed; @Override public List> getSubs() { List> ret = new ArrayList<>(); ret.add(firstCommands); ret.add(commands); ret.add(finalCommands); return ret; } public ForItem(GraphSourceItem src, Loop loop, List firstCommands, GraphTargetItem expression, List finalCommands, List commands) { super(src, loop); this.firstCommands = firstCommands; this.expression = expression; this.finalCommands = finalCommands; this.commands = commands; } @Override protected GraphTextWriter appendTo(GraphTextWriter writer, LocalData localData) { if (writer instanceof NulWriter) { ((NulWriter)writer).startLoop(loop.id, LoopWithType.LOOP_TYPE_LOOP); } if (labelUsed) { writer.append("loop" + loop.id + ":").newLine(); } writer.append("for("); int p = 0; for (int i = 0; i < firstCommands.size(); i++) { if (firstCommands.get(i).isEmpty()) { continue; } if (p > 0) { writer.append(","); } firstCommands.get(i).toString(writer, localData); writer.stripSemicolon(); p++; } writer.append(";"); expression.toString(writer, localData); writer.append(";"); p = 0; for (int i = 0; i < finalCommands.size(); i++) { if (finalCommands.get(i).isEmpty()) { continue; } if (p > 0) { writer.append(","); } finalCommands.get(i).toString(writer, localData); writer.stripSemicolon(); p++; } writer.append(")").newLine(); writer.append("{").newLine(); writer.indent(); for (GraphTargetItem ti : commands) { if (!ti.isEmpty()) { ti.toStringSemicoloned(writer, localData).newLine(); } } writer.unindent(); writer.append("}"); if (writer instanceof NulWriter) { LoopWithType loopOjb = ((NulWriter)writer).endLoop(loop.id); labelUsed = loopOjb.used; } return writer; } @Override public boolean needsSemicolon() { return false; } @Override public List getContinues() { List ret = new ArrayList<>(); for (GraphTargetItem ti : commands) { if (ti instanceof ContinueItem) { ret.add((ContinueItem) ti); } if (ti instanceof Block) { ret.addAll(((Block) ti).getContinues()); } } return ret; } @Override public List toSource(List localData, SourceGenerator generator) { return generator.generate(localData, this); } @Override public boolean hasReturnValue() { return false; } }