using System; using System.IO; using Mono.Cecil; using Mono.Cecil.Cil; using CPUx86 = Indy.IL2CPU.Assembler.X86; namespace Indy.IL2CPU.IL.X86 { [OpCode(Code.Conv_R8)] public class Conv_R8: Op { public Conv_R8(Mono.Cecil.Cil.Instruction aInstruction, MethodInformation aMethodInfo) : base(aInstruction, aMethodInfo) { } public override void DoAssemble() { int xSource = Assembler.StackSizes.Peek(); switch (xSource) { case 1: case 2: case 4: { new CPUx86.Pop(CPUx86.Registers.EAX); new CPUx86.Pushd("0"); new CPUx86.Pushd(CPUx86.Registers.EAX); Assembler.StackSizes.Pop(); Assembler.StackSizes.Push(8); break; } case 8: { break; } default: throw new Exception("SourceSize " + xSource + " not supported!"); } } } }