Package org.eclipse.jdt.internal.compiler.problem

Examples of org.eclipse.jdt.internal.compiler.problem.AbortMethod


      Reference.reportOnlyUselesslyReadLocal(currentScope, localBinding, valueRequired);
      if (localBinding.resolvedPosition == -1) {
        if (valueRequired) {
          // restart code gen
          localBinding.useFlag = LocalVariableBinding.USED;
          throw new AbortMethod(CodeStream.RESTART_CODE_GEN_FOR_UNUSED_LOCALS_MODE, null);
        }
        return;
      }

      // using incr bytecode if possible
View Full Code Here


  return buffer.toString();
}
protected void writePosition(BranchLabel label) {
  int offset = label.position - this.position + 1;
  if (Math.abs(offset) > 0x7FFF && !this.wideMode) {
    throw new AbortMethod(CodeStream.RESTART_IN_WIDE_MODE, null);
  }
  this.writeSignedShort(offset);
  int[] forwardRefs = label.forwardReferences();
  for (int i = 0, max = label.forwardReferenceCount(); i < max; i++) {
    this.writePosition(label, forwardRefs[i]);
View Full Code Here

}

protected void writePosition(BranchLabel label, int forwardReference) {
  final int offset = label.position - forwardReference + 1;
  if (Math.abs(offset) > 0x7FFF && !this.wideMode) {
    throw new AbortMethod(CodeStream.RESTART_IN_WIDE_MODE, null);
  }
  if (this.wideMode) {
    if ((label.tagBits & BranchLabel.WIDE) != 0) {
      this.writeSignedWord(forwardReference, offset);
    } else {
View Full Code Here

public void abort(int abortLevel, CategorizedProblem problem) {
  switch (abortLevel) {
    case AbortType :
      throw new AbortType(this.compilationResult, problem);
    case AbortMethod :
      throw new AbortMethod(this.compilationResult, problem);
    default :
      throw new AbortCompilationUnit(this.compilationResult, problem);
  }
}
View Full Code Here

        LocalVariableBinding localBinding = (LocalVariableBinding) this.binding;
        if (localBinding.resolvedPosition == -1) {
          if (valueRequired) {
            // restart code gen
            localBinding.useFlag = LocalVariableBinding.USED;
            throw new AbortMethod(CodeStream.RESTART_CODE_GEN_FOR_UNUSED_LOCALS_MODE, null);
          }
          codeStream.recordPositionsFrom(pc, this.sourceStart);
          return;
        }
        if (!valueRequired && (this.implicitConversion & TypeIds.UNBOXING) == 0) {
View Full Code Here

               * restart code gen because we either:
               * - need the value
               * - the constant can have potential side-effect
               */
              localBinding.useFlag = LocalVariableBinding.USED;
              throw new AbortMethod(CodeStream.RESTART_CODE_GEN_FOR_UNUSED_LOCALS_MODE, null);
            } else if (assignConstant == Constant.NotAConstant) {
              // we only need to generate the value of the expression's constant if it is not a constant expression
              expression.generateCode(currentScope, codeStream, false);
            }
            return;
          }
          if ((assignConstant != Constant.NotAConstant)
              && (assignConstant.typeID() != TypeIds.T_float) // only for integral types
              && (assignConstant.typeID() != TypeIds.T_double)) { // TODO (philippe) is this test needed ?
            switch (operator) {
              case PLUS :
                int increment  = assignConstant.intValue();
                if (increment != (short) increment) break; // not representable as a 16-bits value
                codeStream.iinc(localBinding.resolvedPosition, increment);
                if (valueRequired) {
                  codeStream.load(localBinding);
                }
                return;
              case MINUS :
                increment  = -assignConstant.intValue();
                if (increment != (short) increment) break; // not representable as a 16-bits value
                codeStream.iinc(localBinding.resolvedPosition, increment);
                if (valueRequired) {
                  codeStream.load(localBinding);
                }
                return;
            }
          }
          //$FALL-THROUGH$
        default :
          if (localBinding.resolvedPosition == -1) {
            assignConstant = expression.constant;
            if (valueRequired) {
              /*
               * restart code gen because we either:
               * - need the value
               * - the constant can have potential side-effect
               */
              localBinding.useFlag = LocalVariableBinding.USED;
              throw new AbortMethod(CodeStream.RESTART_CODE_GEN_FOR_UNUSED_LOCALS_MODE, null);
            } else if (assignConstant == Constant.NotAConstant) {
              // we only need to generate the value of the expression's constant if it is not a constant expression
              expression.generateCode(currentScope, codeStream, false);
            }
            return;
View Full Code Here

      Reference.reportOnlyUselesslyReadLocal(currentScope, localBinding, valueRequired);
      if (localBinding.resolvedPosition == -1) {
        if (valueRequired) {
          // restart code gen
          localBinding.useFlag = LocalVariableBinding.USED;
          throw new AbortMethod(CodeStream.RESTART_CODE_GEN_FOR_UNUSED_LOCALS_MODE, null);
        }
        return;
      }

      // using incr bytecode if possible
View Full Code Here

*/
protected void checkEffectiveFinality(LocalVariableBinding localBinding, Scope scope) {
  if ((this.bits & ASTNode.IsCapturedOuterLocal) != 0) {
    if (!localBinding.isFinal() && !localBinding.isEffectivelyFinal()) {
      scope.problemReporter().cannotReferToNonEffectivelyFinalOuterLocal(localBinding, this);
      throw new AbortMethod(scope.referenceCompilationUnit().compilationResult, null);
    }
  }
}
View Full Code Here

public void abort(int abortLevel, CategorizedProblem problem) {
  switch (abortLevel) {
    case AbortType :
      throw new AbortType(this.compilationResult, problem);
    case AbortMethod :
      throw new AbortMethod(this.compilationResult, problem);
    default :
      throw new AbortCompilationUnit(this.compilationResult, problem);
  }
}
View Full Code Here

      case AbortCompilationUnit :
        throw new AbortCompilationUnit(this.compilationResult, problem);
      case AbortType :
        throw new AbortType(this.compilationResult, problem);
      default :
        throw new AbortMethod(this.compilationResult, problem);
    }
  }
View Full Code Here

TOP

Related Classes of org.eclipse.jdt.internal.compiler.problem.AbortMethod

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.