Package javassist.bytecode

Examples of javassist.bytecode.MethodInfo


  private void addWriteMethod(ClassFile classfile, FieldInfo finfo) throws CannotCompileException, BadBytecode {
    final ConstPool constPool = classfile.getConstPool();
    final int thisClassInfo = constPool.getThisClassInfo();
    final String writeMethodDescriptor = "(" + finfo.getDescriptor() + ")V";
    final MethodInfo writeMethodInfo = new MethodInfo(
        constPool,
        EACH_WRITE_METHOD_PREFIX+ finfo.getName(),
        writeMethodDescriptor
    );

    /* local variables | target obj | each oldvalue | */
    final Bytecode code = new Bytecode(constPool, 6, 3);
    // aload_0
    code.addAload( 0 );
    // invokeinterface : enabled.getInterceptFieldCallback()
    final int enabledClassIndex = constPool.addClassInfo( FIELD_HANDLED_TYPE_NAME );
    code.addInvokeinterface(
        enabledClassIndex,
        GETFIELDHANDLER_METHOD_NAME, GETFIELDHANDLER_METHOD_DESCRIPTOR,
        1
    );
    // ifnonnull (label1)
    code.addOpcode( Opcode.IFNONNULL );
    code.addIndex( 9 );
    // aload_0
    code.addAload( 0 );
    // *load_1
    addTypeDependDataLoad( code, finfo.getDescriptor(), 1 );
    // putfield
    code.addOpcode( Opcode.PUTFIELD );
    final int baseFieldIndex = constPool.addFieldrefInfo( thisClassInfo, finfo.getName(), finfo.getDescriptor() );
    code.addIndex( baseFieldIndex );
    code.growStack( -Descriptor.dataSize( finfo.getDescriptor() ) );
    // return ;
    code.addOpcode( Opcode.RETURN );
    // aload_0
    code.addAload( 0 );
    // dup
    code.addOpcode( Opcode.DUP );
    // invokeinterface // enabled.getInterceptFieldCallback()
    code.addInvokeinterface(
        enabledClassIndex,
        GETFIELDHANDLER_METHOD_NAME,
        GETFIELDHANDLER_METHOD_DESCRIPTOR,
        1
    );
    // aload_0
    code.addAload( 0 );
    // ldc // field name
    code.addLdc( finfo.getName() );
    // aload_0
    code.addAload( 0 );
    // getfield // old value of the field
    code.addOpcode( Opcode.GETFIELD );
    code.addIndex( baseFieldIndex );
    code.growStack( Descriptor.dataSize( finfo.getDescriptor() ) - 1 );
    // *load_1
    addTypeDependDataLoad( code, finfo.getDescriptor(), 1 );
    // invokeinterface // callback.write*(..)
    addInvokeFieldHandlerMethod( classfile, code, finfo.getDescriptor(), false );
    // putfield // new value of the field
    code.addOpcode( Opcode.PUTFIELD );
    code.addIndex( baseFieldIndex );
    code.growStack( -Descriptor.dataSize( finfo.getDescriptor() ) );
    // return
    code.addOpcode( Opcode.RETURN );

    writeMethodInfo.setCodeAttribute( code.toCodeAttribute() );
    writeMethodInfo.setAccessFlags( AccessFlag.PUBLIC );
    final CodeAttribute codeAttribute = writeMethodInfo.getCodeAttribute();
    if ( codeAttribute != null ) {
      final StackMapTable smt = MapMaker.make( classPool, writeMethodInfo );
      codeAttribute.setAttribute( smt );
    }
    classfile.addMethod( writeMethodInfo );
View Full Code Here


    classfile.addMethod( writeMethodInfo );
  }

  private void transformInvokevirtualsIntoPutAndGetfields(ClassFile classfile) throws CannotCompileException, BadBytecode {
    for ( Object o : classfile.getMethods() ) {
      final MethodInfo methodInfo = (MethodInfo) o;
      final String methodName = methodInfo.getName();
      if ( methodName.startsWith( EACH_READ_METHOD_PREFIX )
          || methodName.startsWith( EACH_WRITE_METHOD_PREFIX )
          || methodName.equals( GETFIELDHANDLER_METHOD_NAME )
          || methodName.equals( SETFIELDHANDLER_METHOD_NAME ) ) {
        continue;
      }

      final CodeAttribute codeAttr = methodInfo.getCodeAttribute();
      if ( codeAttr == null ) {
        continue;
      }

      final CodeIterator iter = codeAttr.iterator();
View Full Code Here

   * @throws CannotCompileException Indicates trouble with the underlying Javassist calls
   */
  private void addDefaultConstructor(ClassFile classfile) throws CannotCompileException {
    final ConstPool constPool = classfile.getConstPool();
    final String constructorSignature = "()V";
    final MethodInfo constructorMethodInfo = new MethodInfo( constPool, MethodInfo.nameInit, constructorSignature );

    final Bytecode code = new Bytecode( constPool, 0, 1 );
    // aload_0
    code.addAload( 0 );
    // invokespecial
    code.addInvokespecial( BulkAccessor.class.getName(), MethodInfo.nameInit, constructorSignature );
    // return
    code.addOpcode( Opcode.RETURN );

    constructorMethodInfo.setCodeAttribute( code.toCodeAttribute() );
    constructorMethodInfo.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( constructorMethodInfo );
  }
View Full Code Here

  private void addGetter(ClassFile classfile, final Method[] getters) throws CannotCompileException {
    final ConstPool constPool = classfile.getConstPool();
    final int targetBeanConstPoolIndex = constPool.addClassInfo( this.targetBean.getName() );
    final String desc = GET_SETTER_DESC;
    final MethodInfo getterMethodInfo = new MethodInfo( constPool, GENERATED_GETTER_NAME, desc );

    final Bytecode code = new Bytecode( constPool, 6, 4 );
    /* | this | bean | args | raw bean | */
    if ( getters.length >= 0 ) {
      // aload_1 // load bean
      code.addAload( 1 );
      // checkcast // cast bean
      code.addCheckcast( this.targetBean.getName() );
      // astore_3 // store bean
      code.addAstore( 3 );
      for ( int i = 0; i < getters.length; ++i ) {
        if ( getters[i] != null ) {
          final Method getter = getters[i];
          // aload_2 // args
          code.addAload( 2 );
          // iconst_i // continue to aastore
          // growing stack is 1
          code.addIconst( i );
          final Class returnType = getter.getReturnType();
          int typeIndex = -1;
          if ( returnType.isPrimitive() ) {
            typeIndex = FactoryHelper.typeIndex( returnType );
            // new
            code.addNew( FactoryHelper.wrapperTypes[typeIndex] );
            // dup
            code.addOpcode( Opcode.DUP );
          }

          // aload_3 // load the raw bean
          code.addAload( 3 );
          final String getterSignature = RuntimeSupport.makeDescriptor( getter );
          final String getterName = getter.getName();
          if ( this.targetBean.isInterface() ) {
            // invokeinterface
            code.addInvokeinterface( targetBeanConstPoolIndex, getterName, getterSignature, 1 );
          }
          else {
            // invokevirtual
            code.addInvokevirtual( targetBeanConstPoolIndex, getterName, getterSignature );
          }

          if ( typeIndex >= 0 ) {
            // is a primitive type
            // invokespecial
            code.addInvokespecial(
                FactoryHelper.wrapperTypes[typeIndex],
                MethodInfo.nameInit,
                FactoryHelper.wrapperDesc[typeIndex]
            );
          }

          // aastore // args
          code.add( Opcode.AASTORE );
          code.growStack( -3 );
        }
      }
    }
    // return
    code.addOpcode( Opcode.RETURN );

    getterMethodInfo.setCodeAttribute( code.toCodeAttribute() );
    getterMethodInfo.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( getterMethodInfo );
  }
View Full Code Here

  private void addSetter(ClassFile classfile, final Method[] setters) throws CannotCompileException {
    final ConstPool constPool = classfile.getConstPool();
    final int targetTypeConstPoolIndex = constPool.addClassInfo( this.targetBean.getName() );
    final String desc = GET_SETTER_DESC;
    final MethodInfo setterMethodInfo = new MethodInfo( constPool, GENERATED_SETTER_NAME, desc );

    final Bytecode code = new Bytecode( constPool, 4, 6 );
    StackMapTable stackmap = null;
    /* | this | bean | args | i | raw bean | exception | */
    if ( setters.length > 0 ) {
      // required to exception table
      int start;
      int end;
      // iconst_0 // i
      code.addIconst( 0 );
      // istore_3 // store i
      code.addIstore( 3 );
      // aload_1 // load the bean
      code.addAload( 1 );
      // checkcast // cast the bean into a raw bean
      code.addCheckcast( this.targetBean.getName() );
      // astore 4 // store the raw bean
      code.addAstore( 4 );
      /* current stack len = 0 */
      // start region to handling exception (BulkAccessorException)
      start = code.currentPc();
      int lastIndex = 0;
      for ( int i = 0; i < setters.length; ++i ) {
        if ( setters[i] != null ) {
          final int diff = i - lastIndex;
          if ( diff > 0 ) {
            // iinc 3, 1
            code.addOpcode( Opcode.IINC );
            code.add( 3 );
            code.add( diff );
            lastIndex = i;
          }
        }
        /* current stack len = 0 */
        // aload 4 // load the raw bean
        code.addAload( 4 );
        // aload_2 // load the args
        code.addAload( 2 );
        // iconst_i
        code.addIconst( i );
        // aaload
        code.addOpcode( Opcode.AALOAD );
        // checkcast
        final Class[] setterParamTypes = setters[i].getParameterTypes();
        final Class setterParamType = setterParamTypes[0];
        if ( setterParamType.isPrimitive() ) {
          // checkcast (case of primitive type)
          // invokevirtual (case of primitive type)
          this.addUnwrapper( code, setterParamType );
        }
        else {
          // checkcast (case of reference type)
          code.addCheckcast( setterParamType.getName() );
        }
        /* current stack len = 2 */
        final String rawSetterMethodDesc = RuntimeSupport.makeDescriptor( setters[i] );
        if ( !this.targetBean.isInterface() ) {
          // invokevirtual
          code.addInvokevirtual( targetTypeConstPoolIndex, setters[i].getName(), rawSetterMethodDesc );
        }
        else {
          // invokeinterface
          final Class[] params = setters[i].getParameterTypes();
          int size;
          if ( params[0].equals( Double.TYPE ) || params[0].equals( Long.TYPE ) ) {
            size = 3;
          }
          else {
            size = 2;
          }

          code.addInvokeinterface( targetTypeConstPoolIndex, setters[i].getName(), rawSetterMethodDesc, size );
        }
      }

      // end region to handling exception (BulkAccessorException)
      end = code.currentPc();
      // return
      code.addOpcode( Opcode.RETURN );
      /* current stack len = 0 */
      // register in exception table
      final int throwableTypeIndex = constPool.addClassInfo( THROWABLE_CLASS_NAME );
      final int handlerPc = code.currentPc();
      code.addExceptionHandler( start, end, handlerPc, throwableTypeIndex );
      // astore 5 // store exception
      code.addAstore( 5 );
      // new // BulkAccessorException
      code.addNew( BULKEXCEPTION_CLASS_NAME );
      // dup
      code.addOpcode( Opcode.DUP );
      // aload 5 // load exception
      code.addAload( 5 );
      // iload_3 // i
      code.addIload( 3 );
      // invokespecial // BulkAccessorException.<init>
      final String consDesc = "(Ljava/lang/Throwable;I)V";
      code.addInvokespecial( BULKEXCEPTION_CLASS_NAME, MethodInfo.nameInit, consDesc );
      // athrow
      code.addOpcode( Opcode.ATHROW );
      final StackMapTable.Writer writer = new StackMapTable.Writer(32);
      final int[] localTags = {
          StackMapTable.OBJECT,
          StackMapTable.OBJECT,
          StackMapTable.OBJECT,
          StackMapTable.INTEGER
      };
      final int[] localData = {
          constPool.getThisClassInfo(),
          constPool.addClassInfo( "java/lang/Object" ),
          constPool.addClassInfo( "[Ljava/lang/Object;" ),
          0
      };
      final int[] stackTags = {
          StackMapTable.OBJECT
      };
      final int[] stackData = {
          throwableTypeIndex
      };
      writer.fullFrame( handlerPc, localTags, localData, stackTags, stackData );
      stackmap = writer.toStackMapTable( constPool );
    }
    else {
      // return
      code.addOpcode( Opcode.RETURN );
    }
    final CodeAttribute ca = code.toCodeAttribute();
    if ( stackmap != null ) {
      ca.setAttribute( stackmap );
    }
    setterMethodInfo.setCodeAttribute( ca );
    setterMethodInfo.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( setterMethodInfo );
  }
View Full Code Here

   * @throws CannotCompileException
   */
  private void addDefaultConstructor(ClassFile classfile) throws CannotCompileException {
    ConstPool cp = classfile.getConstPool();
    String cons_desc = "()V";
    MethodInfo mi = new MethodInfo( cp, MethodInfo.nameInit, cons_desc );

    Bytecode code = new Bytecode( cp, 0, 1 );
    // aload_0
    code.addAload( 0 );
    // invokespecial
    code.addInvokespecial( BulkAccessor.class.getName(), MethodInfo.nameInit, cons_desc );
    // return
    code.addOpcode( Opcode.RETURN );

    mi.setCodeAttribute( code.toCodeAttribute() );
    mi.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( mi );
  }
View Full Code Here

  private void addGetter(ClassFile classfile, final Method[] getters) throws CannotCompileException {
    ConstPool cp = classfile.getConstPool();
    int target_type_index = cp.addClassInfo( this.targetBean.getName() );
    String desc = GET_SETTER_DESC;
    MethodInfo mi = new MethodInfo( cp, GENERATED_GETTER_NAME, desc );

    Bytecode code = new Bytecode( cp, 6, 4 );
    /* | this | bean | args | raw bean | */
    if ( getters.length >= 0 ) {
      // aload_1 // load bean
      code.addAload( 1 );
      // checkcast // cast bean
      code.addCheckcast( this.targetBean.getName() );
      // astore_3 // store bean
      code.addAstore( 3 );
      for ( int i = 0; i < getters.length; ++i ) {
        if ( getters[i] != null ) {
          Method getter = getters[i];
          // aload_2 // args
          code.addAload( 2 );
          // iconst_i // continue to aastore
          code.addIconst( i ); // growing stack is 1
          Class returnType = getter.getReturnType();
          int typeIndex = -1;
          if ( returnType.isPrimitive() ) {
            typeIndex = FactoryHelper.typeIndex( returnType );
            // new
            code.addNew( FactoryHelper.wrapperTypes[typeIndex] );
            // dup
            code.addOpcode( Opcode.DUP );
          }

          // aload_3 // load the raw bean
          code.addAload( 3 );
          String getter_desc = RuntimeSupport.makeDescriptor( getter );
          String getterName = getter.getName();
          if ( this.targetBean.isInterface() ) {
            // invokeinterface
            code.addInvokeinterface( target_type_index, getterName, getter_desc, 1 );
          }
          else {
            // invokevirtual
            code.addInvokevirtual( target_type_index, getterName, getter_desc );
          }

          if ( typeIndex >= 0 ) {       // is a primitive type
            // invokespecial
            code.addInvokespecial(
                FactoryHelper.wrapperTypes[typeIndex],
                    MethodInfo.nameInit,
                    FactoryHelper.wrapperDesc[typeIndex]
            );
          }

          // aastore // args
          code.add( Opcode.AASTORE );
          code.growStack( -3 );
        }
      }
    }
    // return
    code.addOpcode( Opcode.RETURN );

    mi.setCodeAttribute( code.toCodeAttribute() );
    mi.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( mi );
  }
View Full Code Here

  private void addSetter(ClassFile classfile, final Method[] setters) throws CannotCompileException {
    ConstPool cp = classfile.getConstPool();
    int target_type_index = cp.addClassInfo( this.targetBean.getName() );
    String desc = GET_SETTER_DESC;
    MethodInfo mi = new MethodInfo( cp, GENERATED_SETTER_NAME, desc );

    Bytecode code = new Bytecode( cp, 4, 6 );
    /* | this | bean | args | i | raw bean | exception | */
    if ( setters.length > 0 ) {
      int start, end; // required to exception table
      // iconst_0 // i
      code.addIconst( 0 );
      // istore_3 // store i
      code.addIstore( 3 );
      // aload_1 // load the bean
      code.addAload( 1 );
      // checkcast // cast the bean into a raw bean
      code.addCheckcast( this.targetBean.getName() );
      // astore 4 // store the raw bean
      code.addAstore( 4 );
      /* current stack len = 0 */
      // start region to handling exception (BulkAccessorException)
      start = code.currentPc();
      int lastIndex = 0;
      for ( int i = 0; i < setters.length; ++i ) {
        if ( setters[i] != null ) {
          int diff = i - lastIndex;
          if ( diff > 0 ) {
            // iinc 3, 1
            code.addOpcode( Opcode.IINC );
            code.add( 3 );
            code.add( diff );
            lastIndex = i;
          }
        }
        /* current stack len = 0 */
        // aload 4 // load the raw bean
        code.addAload( 4 );
        // aload_2 // load the args
        code.addAload( 2 );
        // iconst_i
        code.addIconst( i );
        // aaload
        code.addOpcode( Opcode.AALOAD );
        // checkcast
        Class[] setterParamTypes = setters[i].getParameterTypes();
        Class setterParamType = setterParamTypes[0];
        if ( setterParamType.isPrimitive() ) {
          // checkcast (case of primitive type)
          // invokevirtual (case of primitive type)
          this.addUnwrapper( classfile, code, setterParamType );
        }
        else {
          // checkcast (case of reference type)
          code.addCheckcast( setterParamType.getName() );
        }
        /* current stack len = 2 */
        String rawSetterMethod_desc = RuntimeSupport.makeDescriptor( setters[i] );
        if ( !this.targetBean.isInterface() ) {
          // invokevirtual
          code.addInvokevirtual( target_type_index, setters[i].getName(), rawSetterMethod_desc );
        }
        else {
          // invokeinterface
          Class[] params = setters[i].getParameterTypes();
          int size;
          if ( params[0].equals( Double.TYPE ) || params[0].equals( Long.TYPE ) ) {
            size = 3;
          }
          else {
            size = 2;
          }

          code.addInvokeinterface( target_type_index, setters[i].getName(), rawSetterMethod_desc, size );
        }
      }

      // end region to handling exception (BulkAccessorException)
      end = code.currentPc();
      // return
      code.addOpcode( Opcode.RETURN );
      /* current stack len = 0 */
      // register in exception table
      int throwableType_index = cp.addClassInfo( THROWABLE_CLASS_NAME );
      code.addExceptionHandler( start, end, code.currentPc(), throwableType_index );
      // astore 5 // store exception
      code.addAstore( 5 );
      // new // BulkAccessorException
      code.addNew( BULKEXCEPTION_CLASS_NAME );
      // dup
      code.addOpcode( Opcode.DUP );
      // aload 5 // load exception
      code.addAload( 5 );
      // iload_3 // i
      code.addIload( 3 );
      // invokespecial // BulkAccessorException.<init>
      String cons_desc = "(Ljava/lang/Throwable;I)V";
      code.addInvokespecial( BULKEXCEPTION_CLASS_NAME, MethodInfo.nameInit, cons_desc );
      // athrow
      code.addOpcode( Opcode.ATHROW );
    }
    else {
      // return
      code.addOpcode( Opcode.RETURN );
    }

    mi.setCodeAttribute( code.toCodeAttribute() );
    mi.setAccessFlags( AccessFlag.PUBLIC );
    classfile.addMethod( mi );
  }
View Full Code Here

  private void addGetFieldHandlerMethod(ClassFile classfile)
      throws CannotCompileException {
    ConstPool cp = classfile.getConstPool();
    int this_class_index = cp.getThisClassInfo();
    MethodInfo minfo = new MethodInfo(cp, GETFIELDHANDLER_METHOD_NAME,
                                      GETFIELDHANDLER_METHOD_DESCRIPTOR);
    /* local variable | this | */
    Bytecode code = new Bytecode(cp, 2, 1);
    // aload_0 // load this
    code.addAload(0);
    // getfield // get field "$JAVASSIST_CALLBACK" defined already
    code.addOpcode(Opcode.GETFIELD);
    int field_index = cp.addFieldrefInfo(this_class_index,
                                         HANDLER_FIELD_NAME, HANDLER_FIELD_DESCRIPTOR);
    code.addIndex(field_index);
    // areturn // return the value of the field
    code.addOpcode(Opcode.ARETURN);
    minfo.setCodeAttribute(code.toCodeAttribute());
    minfo.setAccessFlags(AccessFlag.PUBLIC);
    classfile.addMethod(minfo);
  }
View Full Code Here

  private void addSetFieldHandlerMethod(ClassFile classfile)
      throws CannotCompileException {
    ConstPool cp = classfile.getConstPool();
    int this_class_index = cp.getThisClassInfo();
    MethodInfo minfo = new MethodInfo(cp, SETFIELDHANDLER_METHOD_NAME,
                                      SETFIELDHANDLER_METHOD_DESCRIPTOR);
    /* local variables | this | callback | */
    Bytecode code = new Bytecode(cp, 3, 3);
    // aload_0 // load this
    code.addAload(0);
    // aload_1 // load callback
    code.addAload(1);
    // putfield // put field "$JAVASSIST_CALLBACK" defined already
    code.addOpcode(Opcode.PUTFIELD);
    int field_index = cp.addFieldrefInfo(this_class_index,
                                         HANDLER_FIELD_NAME, HANDLER_FIELD_DESCRIPTOR);
    code.addIndex(field_index);
    // return
    code.addOpcode(Opcode.RETURN);
    minfo.setCodeAttribute(code.toCodeAttribute());
    minfo.setAccessFlags(AccessFlag.PUBLIC);
    classfile.addMethod(minfo);
  }
View Full Code Here

TOP

Related Classes of javassist.bytecode.MethodInfo

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.