diff src/main/gov/nasa/jpf/vm/NamedFields.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/NamedFields.java	Fri Jan 23 10:14:01 2015 -0800
@@ -0,0 +1,274 @@
+/*
+ * 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.util.HashData;
+import gov.nasa.jpf.util.IntVector;
+
+/**
+ * value container for non-array classes
+ */
+public class NamedFields extends Fields {
+
+  /** this is where we store the instance data. Since field types are
+   * heterogenous, we have to map everything into int
+   */
+  protected int[] values;
+
+  public NamedFields (int dataSize) {
+    values = new int[dataSize];
+  }
+
+  @Override
+  public int[] asFieldSlots() {
+    return values;
+  }
+
+  /**
+   * give an approximation of the heap size in bytes - we assume fields are word
+   * aligned, hence the number of values*4 should be good. Note that this is
+   * overridden by ArrayFields (arrays would be packed)
+   */
+  @Override
+  public int getHeapSize () {
+    return values.length*4;
+  }
+
+  // our low level getters and setters
+  @Override
+  public int getIntValue (int index) {
+    return values[index];
+  }
+
+  public boolean isEqual(Fields o, int off, int len, int otherOff) {
+    if (o instanceof NamedFields) {
+      NamedFields other = (NamedFields) o;
+      int iEnd = off + len;
+      int jEnd = otherOff + len;
+      int[] v = other.values;
+
+      if ((iEnd > values.length) || (jEnd > v.length)) {
+        return false;
+      }
+
+      for (int i = off, j = otherOff; i < iEnd; i++, j++) {
+        if (values[i] != v[j]) {
+          return false;
+        }
+      }
+
+      return true;
+    } else {
+      return false;
+    }
+  }
+
+  // same as above, just here to make intentions clear
+  @Override
+  public int getReferenceValue (int index) {
+    return values[index];
+  }
+
+  @Override
+  public long getLongValue (int index) {
+    return Types.intsToLong(values[index + 1], values[index]);
+  }
+
+  @Override
+  public boolean getBooleanValue (int index) {
+    return Types.intToBoolean(values[index]);
+  }
+
+  @Override
+  public byte getByteValue (int index) {
+    return (byte) values[index];
+  }
+
+  @Override
+  public char getCharValue (int index) {
+    return (char) values[index];
+  }
+
+  @Override
+  public short getShortValue (int index) {
+    return (short) values[index];
+  }
+
+  // <2do> get rid of it!! this is only for internal use, to increase efficiency
+  public int[] getValues() {
+    return values;
+  }
+
+  //--- the field modifier methods (both instance and static)
+
+  @Override
+  public void setReferenceValue (int index, int newValue) {
+    values[index] = newValue;
+  }
+
+  @Override
+  public void setBooleanValue (int index, boolean newValue) {
+    values[index] = newValue ? 1 : 0;
+  }
+
+  @Override
+  public void setByteValue (int index, byte newValue) {
+    values[index] = newValue;
+  }
+
+  @Override
+  public void setCharValue (int index, char newValue) {
+    values[index] = newValue;
+  }
+
+  @Override
+  public void setShortValue (int index, short newValue) {
+    values[index] = newValue;
+  }
+
+  @Override
+  public void setFloatValue (int index, float newValue) {
+    values[index] = Types.floatToInt(newValue);
+  }
+
+  @Override
+  public void setIntValue (int index, int newValue) {
+    values[index] = newValue;
+  }
+
+  @Override
+  public void setLongValue (int index, long newValue) {
+		values[index++] = Types.hiLong(newValue);
+    values[index] = Types.loLong(newValue);
+  }
+
+  @Override
+  public void setDoubleValue (int index, double newValue) {
+    values[index++] = Types.hiDouble(newValue);
+    values[index] = Types.loDouble(newValue);
+  }
+
+
+  @Override
+  public float getFloatValue (int index) {
+    return Types.intToFloat(values[index]);
+  }
+
+  @Override
+  public double getDoubleValue (int index) {
+    return Types.intsToDouble( values[index+1], values[index]);
+  }
+
+  /**
+   * Creates a clone.
+   */
+  @Override
+  public NamedFields clone () {
+    NamedFields f = (NamedFields) cloneFields();
+    f.values = values.clone();
+    return f;
+  }
+
+  /**
+   * Checks for equality.
+   */
+  @Override
+  public boolean equals (Object o) {
+    if (o instanceof NamedFields) {
+      NamedFields other = (NamedFields) o;
+
+      //--- check values
+      int[] v1 = values;
+      int[] v2 = other.values;
+      int l = v1.length;
+      if (l != v2.length) {
+        return false;
+      }
+      for (int i = 0; i < l; i++) {
+        if (v1[i] != v2[i]) {
+          return false;
+        }
+      }
+      
+      return super.compareAttrs(other);
+
+    } else {
+      return false;
+    }
+  }
+
+  // serialization interface
+  @Override
+  public void appendTo(IntVector v) {
+    v.append(values);
+  }
+
+
+  /**
+   * Adds some data to the computation of an hashcode.
+   */
+  @Override
+  public void hash (HashData hd) {
+    int[] v = values;
+    for (int i=0, l=v.length; i < l; i++) {
+      hd.add(v[i]);
+    }
+  }
+
+  /**
+   * Size of the fields.
+   */
+  public int size () {
+    return values.length;
+  }
+
+  @Override
+  public String toString () {
+    StringBuilder sb = new StringBuilder("NamedFields[");
+
+    sb.append("values=");
+    sb.append('[');
+
+    for (int i = 0; i < values.length; i++) {
+      if (i != 0) {
+        sb.append(',');
+      }
+
+      sb.append(values[i]);
+    }
+
+    sb.append(']');
+    sb.append(',');
+
+    sb.append(']');
+
+    return sb.toString();
+  }
+
+  // <2do> replace with copyTo() !!
+  public int[] getRawValues() {
+    return values;
+  }
+
+  public void copyFrom(Fields other) {
+    System.arraycopy(((NamedFields)other).values, 0, this.values, 0, values.length);
+    super.copyAttrs(other);
+  }
+
+}