Mercurial > hg > Members > kono > jpf-core
view src/main/gov/nasa/jpf/vm/choice/TypedObjectChoice.java @ 34:49be04cc6389 default tip java9-try
cyclic dependency ...
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 19 Dec 2017 11:21:23 +0900 |
parents | cd7880ab73c7 |
children |
line wrap: on
line source
/* * Copyright (C) 2014, United States Government, as represented by the * Administrator of the National Aeronautics and Space Administration. * All rights reserved. * * The Java Pathfinder core (jpf-core) platform is licensed under the * Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0. * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package gov.nasa.jpf.vm.choice; import gov.nasa.jpf.Config; import gov.nasa.jpf.vm.*; import java.util.ArrayList; /** * a choice generator that enumerates the set of all objects of a certain type. This * is a replacement for the old 'Verify.randomObject' */ public class TypedObjectChoice extends ChoiceGeneratorBase<Integer> implements ReferenceChoiceGenerator { // the requested object type protected String type; // the object references protected int[] values; // our enumeration state protected int count; public TypedObjectChoice (Config conf, String id) { super(id); Heap heap = VM.getVM().getHeap(); type = conf.getString(id + ".type"); if (type == null) { throw conf.exception("missing 'type' property for TypedObjectChoice " + id); } ArrayList<ElementInfo> list = new ArrayList<ElementInfo>(); for ( ElementInfo ei : heap.liveObjects()) { ClassInfo ci = ei.getClassInfo(); if (ci.isInstanceOf(type)) { list.add(ei); } } if (conf.getBoolean(id + ".include_null", true)){ list.add(null); } values = new int[list.size()]; int i = 0; for ( ElementInfo ei : list) { if (ei != null) { values[i++] = ei.getObjectRef(); } else { values[i++] = MJIEnv.NULL; } } count = -1; } @Override public Integer getChoice (int idx){ if (idx >= 0 && idx < values.length){ return values[idx]; } else { throw new IllegalArgumentException("choice index out of range: " + idx); } } @Override public void advance () { count++; } @Override public int getProcessedNumberOfChoices () { return count+1; } @Override public int getTotalNumberOfChoices () { return values.length; } @Override public boolean hasMoreChoices () { return !isDone && (count < values.length-1); } @Override public void reset () { count = -1; isDone = false; } @Override public Integer getNextChoice () { if ((count >= 0) && (count < values.length)) { return new Integer(values[count]); } else { return new Integer(-1); } } @Override public String toString() { StringBuilder sb = new StringBuilder("TypedObjectChoice [id="); sb.append(id); sb.append(",type="); sb.append(type); sb.append(",values="); for (int i=0; i< values.length; i++) { if (i>0) { sb.append(','); } if (i == count) { sb.append("=>"); } sb.append(values[i]); } sb.append(']'); return sb.toString(); } @Override public TypedObjectChoice randomize() { for (int i = values.length - 1; i > 0; i--) { int j = random.nextInt(i + 1); int tmp = values[i]; values[i] = values[j]; values[j] = tmp; } return this; } @Override public Class<Integer> getChoiceType() { return Integer.class; } }