Package org.apache.bcel.verifier.exc

Examples of org.apache.bcel.verifier.exc.StructuralCodeConstraintException


      }
      InstructionHandle ret = null;
      for (InstructionHandle actual : instructions) {
        if (actual.getInstruction() instanceof RET){
          if (ret != null){
            throw new StructuralCodeConstraintException("Subroutine with more then one RET detected: '"+ret+"' and '"+actual+"'.");
          }
          else{
            ret = actual;
          }
        }
      }
      if (ret == null){
        throw new StructuralCodeConstraintException("Subroutine without a RET detected.");
      }
      if (((RET) ret.getInstruction()).getIndex() != localVariable){
        throw new StructuralCodeConstraintException("Subroutine uses '"+ret+"' which does not match the correct local variable '"+localVariable+"'.");
      }
      theRET = ret;
    }
View Full Code Here


   * StructuralCodeConstraintException.
   * @throws org.apache.bcel.verifier.exc.StructuralCodeConstraintException always.
   */
  private void constraintViolated(Instruction violator, String description){
    String fq_classname = violator.getClass().getName();
    throw new StructuralCodeConstraintException("Instruction "+ fq_classname.substring(fq_classname.lastIndexOf('.')+1) +" constraint violated: " + description);
  }
View Full Code Here

                    {
                        try
                        {
                            if( !((ObjectType)returnedType).isAssignmentCompatibleWith(m.getReturnType()) )
                            {
                                throw new StructuralCodeConstraintException("Returned type "+returnedType+" does not match Method's return type "+m.getReturnType());
                            }
                        }
                        catch (ClassNotFoundException e)
                        {
                            //dont know what do do now, so raise RuntimeException
                            throw new RuntimeException(e);
                        }
                    }
                    else if( !returnedType.equals(m.getReturnType()) )
                    {
                        throw new StructuralCodeConstraintException("Returned type "+returnedType+" does not match Method's return type "+m.getReturnType());
                    }
                }
      }
    }while ((ih = ih.getNext()) != null);
   
View Full Code Here

      // BFS ended above.
      for (int i=0; i<all.length; i++){
        if (colors.get(all[i]) == BLACK){
          ((SubroutineImpl) (actual==all[0]?getTopLevel():getSubroutine(actual))).addInstruction(all[i]);
          if (instructions_assigned.contains(all[i])){
            throw new StructuralCodeConstraintException("Instruction '"+all[i]+"' is part of more than one subroutine (or of the top level and a subroutine).");
          }
          else{
            instructions_assigned.add(all[i]);
          }
        }
      }
      if (actual != all[0]){// If we don't deal with the top-level 'subroutine'
        ((SubroutineImpl) getSubroutine(actual)).setLeavingRET();
      }
    }
   
    // Now make sure no instruction of a Subroutine is protected by exception handling code
    // as is mandated by JustIces notion of subroutines.
    for (int i=0; i<handlers.length; i++){
      InstructionHandle _protected = handlers[i].getStartPC();
      while (_protected != handlers[i].getEndPC().getNext()){// Note the inclusive/inclusive notation of "generic API" exception handlers!
        for (Subroutine sub : subroutines.values()) {
          if (sub != subroutines.get(all[0])){  // We don't want to forbid top-level exception handlers.
            if (sub.contains(_protected)){
              throw new StructuralCodeConstraintException("Subroutine instruction '"+_protected+"' is protected by an exception handler, '"+handlers[i]+"'. This is forbidden by the JustIce verifier due to its clear definition of subroutines.");
            }
          }
        }
        _protected = _protected.getNext();
      }
View Full Code Here

      int index = ((RET) (subs[i].getLeavingRET().getInstruction())).getIndex();
     
      if (!set.add(Integer.valueOf(index))){
        // Don't use toString() here because of possibly infinite recursive subSubs() calls then.
        SubroutineImpl si = (SubroutineImpl) subs[i];
        throw new StructuralCodeConstraintException("Subroutine with local variable '"+si.localVariable+"', JSRs '"+si.theJSRs+"', RET '"+si.theRET+"' is called by a subroutine which uses the same local variable index as itself; maybe even a recursive call? JustIce's clean definition of a subroutine forbids both.");
      }

      noRecursiveCalls(subs[i], set);
     
      set.remove(Integer.valueOf(index));
View Full Code Here

TOP

Related Classes of org.apache.bcel.verifier.exc.StructuralCodeConstraintException

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.