Mercurial > hg > Members > kono > jpf-core
diff src/main/gov/nasa/jpf/vm/ReferenceFieldInfo.java @ 0:61d41facf527
initial v8 import (history reset)
author | Peter Mehlitz <Peter.C.Mehlitz@nasa.gov> |
---|---|
date | Fri, 23 Jan 2015 10:14:01 -0800 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/main/gov/nasa/jpf/vm/ReferenceFieldInfo.java Fri Jan 23 10:14:01 2015 -0800 @@ -0,0 +1,103 @@ +/* + * 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; + +import gov.nasa.jpf.JPFException; + + +/** + * field info for object fields + */ +public class ReferenceFieldInfo extends SingleSlotFieldInfo { + int init; // = MJIEnv.NULL; // not required for MJIEnv.NULL = 0 + + String sInit; // <2do> pcm - just a temporary quirk to init from string literals + // check if there are other non-object reference inits + + public ReferenceFieldInfo (String name, String type, int modifiers) { + super(name, type, modifiers); + } + + @Override + public String valueToString (Fields f) { + int i = f.getIntValue(storageOffset); + if (i == MJIEnv.NULL) { + return "null"; + } else { + return (VM.getVM().getHeap().get(i)).toString(); + } + } + + @Override + public boolean isReference () { + return true; + } + + @Override + public Class<? extends ChoiceGenerator<?>> getChoiceGeneratorType() { + return ReferenceChoiceGenerator.class; + } + + @Override + public boolean isArrayField () { + return ci.isArray; + } + + @Override + public void setConstantValue (Object constValue){ + // <2do> pcm - check what other constants we might encounter, this is most + // probably not just used for Strings. + // Besides the type issue, there is an even bigger problem with identities. + // For instance, all String refs initialized via the same string literal + // inside a single classfile are in fact refering to the same object. This + // means we have to keep a registry (hashtab) with string-literal created + // String objects per ClassInfo, and use this when we assign or init + // String references. + // For the sake of progress, we ignore this for now, but have to come back + // to it because it violates the VM spec + + if (constValue instanceof String){ + cv = constValue; + sInit = (String)constValue; + } else { + throw new JPFException ("unsupported reference initialization: " + constValue); + } + } + + @Override + public void initialize (ElementInfo ei, ThreadInfo ti) { + int ref = init; + if (sInit != null) { + VM vm = ti.getVM(); + Heap heap = vm.getHeap(); + ref = heap.newString(sInit, ti).getObjectRef(); + } + ei.getFields().setReferenceValue( storageOffset, ref); + } + + @Override + public Object getValueObject (Fields f){ + int i = f.getIntValue(storageOffset); + if (i == MJIEnv.NULL) { + return null; + } else { + Heap heap = VM.getVM().getHeap(); + return heap.get(i); + } + } +}