/* * Copyright (C) 2010-2016 JPEXS, All rights reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3.0 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. */ package com.jpexs.decompiler.flash.abc.avm2.model; import com.jpexs.decompiler.flash.SourceGeneratorLocalData; import com.jpexs.decompiler.flash.abc.avm2.instructions.AVM2Instruction; import com.jpexs.decompiler.flash.abc.avm2.instructions.AVM2Instructions; import com.jpexs.decompiler.flash.abc.avm2.parser.script.AVM2SourceGenerator; import com.jpexs.decompiler.flash.ecma.Null; import com.jpexs.decompiler.flash.ecma.Undefined; import com.jpexs.decompiler.flash.helpers.GraphTextWriter; import com.jpexs.decompiler.graph.CompilationException; import com.jpexs.decompiler.graph.GraphSourceItem; import com.jpexs.decompiler.graph.GraphTargetItem; import com.jpexs.decompiler.graph.SourceGenerator; import com.jpexs.decompiler.graph.TypeItem; import com.jpexs.decompiler.graph.model.LocalData; import java.util.List; import java.util.Set; /** * * @author JPEXS */ public class CoerceAVM2Item extends AVM2Item { public GraphTargetItem typeObj; public CoerceAVM2Item(GraphSourceItem instruction, GraphSourceItem lineStartIns, GraphTargetItem value, GraphTargetItem typeObj) { super(instruction, lineStartIns, value.getPrecedence(), value); this.typeObj = typeObj; } @Override public GraphTextWriter appendTo(GraphTextWriter writer, LocalData localData) throws InterruptedException { //return hilight("(" + type + ")", highlight)+ return value.toString(writer, localData); } @Override public GraphTargetItem getNotCoerced() { return value.getNotCoerced(); } @Override public GraphTargetItem getNotCoercedNoDup() { return value.getNotCoercedNoDup(); } @Override public boolean isCompileTime(Set<GraphTargetItem> dependencies) { if (dependencies.contains(value)) { return false; } dependencies.add(value); return value.isConvertedCompileTime(dependencies); } @Override public Object getResult() { Object ret = value.getResult(); switch (typeObj.toString()) { case "String": if (ret == Null.INSTANCE) { return ret; } if (ret == Undefined.INSTANCE) { return Null.INSTANCE; } return value.getResultAsString(); case "*": break; } return ret; } @Override public GraphTargetItem returnType() { return new TypeItem(typeObj.toString()); } @Override public boolean hasReturnValue() { return true; } @Override public List<GraphSourceItem> toSource(SourceGeneratorLocalData localData, SourceGenerator generator) throws CompilationException { /*if (value.returnType().toString().equals(type)) { return toSourceMerge(localData, generator, value); }*/ AVM2Instruction ins; switch (typeObj.toString()) { case "*": ins = new AVM2Instruction(0, AVM2Instructions.CoerceA, null); break; case "String": ins = new AVM2Instruction(0, AVM2Instructions.CoerceS, null); break; case "Boolean": ins = new AVM2Instruction(0, AVM2Instructions.ConvertB, null); break; case "int": ins = new AVM2Instruction(0, AVM2Instructions.ConvertI, null); break; case "uint": ins = new AVM2Instruction(0, AVM2Instructions.ConvertU, null); break; case "Number": ins = new AVM2Instruction(0, AVM2Instructions.ConvertD, null); break; default: int type_index = AVM2SourceGenerator.resolveType(localData, typeObj, ((AVM2SourceGenerator) generator).abcIndex); ins = new AVM2Instruction(0, AVM2Instructions.Coerce, new int[]{type_index}); break; } return toSourceMerge(localData, generator, value, ins); } }