All Downloads are FREE. Search and download functionalities are using the official Maven repository.

class.methods.Copy.scala Maven / Gradle / Ivy

The newest version!
package com.julianpeeters.caseclass.generator
import artisanal.pickle.maker._
import scala.reflect.internal.pickling._
import org.objectweb.asm._
import Opcodes._

import java.util.Arrays
import scala.io.Codec._
case class Copy(cw: ClassWriter, var mv: MethodVisitor, caseClassName: String, fieldData: List[EnrichedField]) {
  def dump = {

    mv = cw.visitMethod(ACC_PUBLIC, "copy", "(" + fieldData.map(fd => fd.typeData.typeDescriptor).mkString + ")L" + caseClassName + ";", "(" + fieldData.map(fd => fd.typeData.unerasedTypeDescriptor).mkString + ")L" + caseClassName + ";", null);
    mv.visitCode();
    mv.visitTypeInsn(NEW, caseClassName);
    mv.visitInsn(DUP);

    var argIndex = 1

    fieldData.map(fd => fd.typeData.loadInstr).foreach(lI => {
      if (lI == DLOAD | lI == LLOAD) {
        mv.visitVarInsn(lI, argIndex);
        argIndex += 2
      }
      else {
        mv.visitVarInsn(lI, argIndex);
        argIndex += 1;
      }
    })

    mv.visitMethodInsn(INVOKESPECIAL, caseClassName, "", "(" + fieldData.map(fd => fd.typeData.typeDescriptor).mkString + ")V");
    mv.visitInsn(ARETURN);
    mv.visitMaxs(5, 4);
    mv.visitEnd();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy