From 3ce1eb4b1960610d962109a3fea8646807863342 Mon Sep 17 00:00:00 2001 From: Alexey Andreev Date: Sun, 11 May 2014 15:27:23 +0400 Subject: [PATCH] Fixes VectorTest passing --- .../classlib/java/util/TAbstractList.java | 48 +++++++++++++++---- .../teavm/classlib/java/util/TTreeMap.java | 4 +- .../teavm/classlib/java/util/VectorTest.java | 20 +++++--- 3 files changed, 55 insertions(+), 17 deletions(-) diff --git a/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TAbstractList.java b/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TAbstractList.java index ce667c68a..d012d7c51 100644 --- a/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TAbstractList.java +++ b/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TAbstractList.java @@ -15,10 +15,8 @@ */ package org.teavm.classlib.java.util; -import org.teavm.classlib.java.lang.TIllegalArgumentException; -import org.teavm.classlib.java.lang.TIllegalStateException; -import org.teavm.classlib.java.lang.TIndexOutOfBoundsException; -import org.teavm.classlib.java.lang.TUnsupportedOperationException; +import org.teavm.classlib.java.lang.*; +import org.teavm.javascript.ni.Rename; /** * @@ -56,9 +54,11 @@ public abstract class TAbstractList extends TAbstractCollection implements throw new TIllegalStateException(); } checkConcurrentModification(); - TAbstractList.this.remove(index - 1); + TAbstractList.this.remove(removeIndex); modCount = TAbstractList.this.modCount; - --index; + if (removeIndex < index) { + --index; + } --size; removeIndex = -1; } @@ -159,6 +159,36 @@ public abstract class TAbstractList extends TAbstractCollection implements } } + + @Override + public int hashCode() { + int hashCode = 1; + for (TIterator iter = iterator(); iter.hasNext();) { + E elem = iter.next(); + hashCode = 31 * hashCode + (elem != null ? elem.hashCode() : 0); + } + return hashCode; + } + + @Override + @Rename("equals") + public boolean equals0(TObject other) { + if (!(other instanceof TList)) { + return false; + } + @SuppressWarnings("unchecked") + TList list = (TList)other; + if (size() != list.size()) { + return false; + } + for (int i = 0; i < list.size(); ++i) { + if (!TObjects.equals(get(i), list.get(i))) { + return false; + } + } + return true; + } + private class TListIteratorImpl implements TListIterator { private int i; private int j; @@ -187,6 +217,9 @@ public abstract class TAbstractList extends TAbstractCollection implements } checkConcurrentModification(); TAbstractList.this.remove(j); + if (j < i) { + --i; + } --sz; lastModCount = modCount; } @@ -215,9 +248,6 @@ public abstract class TAbstractList extends TAbstractCollection implements TAbstractList.this.set(j, e); } @Override public void add(E e) { - if (j == -1) { - throw new TIllegalStateException(); - } TAbstractList.this.add(i++, e); lastModCount = modCount; j = -1; diff --git a/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TTreeMap.java b/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TTreeMap.java index b38c5a7bd..692f81295 100644 --- a/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TTreeMap.java +++ b/teavm-classlib/src/main/java/org/teavm/classlib/java/util/TTreeMap.java @@ -1103,12 +1103,12 @@ public class TTreeMap extends TAbstractMap implements TCloneable, TS @Override public TSortedSet headSet(K toElement) { - return map.headMap(toElement, true).navigableKeySet(); + return map.headMap(toElement, false).navigableKeySet(); } @Override public TSortedSet tailSet(K fromElement) { - return map.headMap(fromElement, false).navigableKeySet(); + return map.headMap(fromElement, true).navigableKeySet(); } @Override diff --git a/teavm-classlib/src/test/java/org/teavm/classlib/java/util/VectorTest.java b/teavm-classlib/src/test/java/org/teavm/classlib/java/util/VectorTest.java index 2eecb9430..9be59abb9 100644 --- a/teavm-classlib/src/test/java/org/teavm/classlib/java/util/VectorTest.java +++ b/teavm-classlib/src/test/java/org/teavm/classlib/java/util/VectorTest.java @@ -43,12 +43,20 @@ import org.junit.Test; import org.teavm.classlib.support.Support_ListTest; public class VectorTest { - private Vector tVector = new Vector<>(); Object[] objArray; - private String vString = "[Test 0, Test 1, Test 2, Test 3, Test 4, Test 5, Test 6, Test 7, Test 8, Test 9, Test 10, Test 11, Test 12, Test 13, Test 14, Test 15, Test 16, Test 17, Test 18, Test 19, Test 20, Test 21, Test 22, Test 23, Test 24, Test 25, Test 26, Test 27, Test 28, Test 29, Test 30, Test 31, Test 32, Test 33, Test 34, Test 35, Test 36, Test 37, Test 38, Test 39, Test 40, Test 41, Test 42, Test 43, Test 44, Test 45, Test 46, Test 47, Test 48, Test 49, Test 50, Test 51, Test 52, Test 53, Test 54, Test 55, Test 56, Test 57, Test 58, Test 59, Test 60, Test 61, Test 62, Test 63, Test 64, Test 65, Test 66, Test 67, Test 68, Test 69, Test 70, Test 71, Test 72, Test 73, Test 74, Test 75, Test 76, Test 77, Test 78, Test 79, Test 80, Test 81, Test 82, Test 83, Test 84, Test 85, Test 86, Test 87, Test 88, Test 89, Test 90, Test 91, Test 92, Test 93, Test 94, Test 95, Test 96, Test 97, Test 98, Test 99]"; + private String vString = "[Test 0, Test 1, Test 2, Test 3, Test 4, Test 5, Test 6, Test 7, Test 8, Test 9, " + + "Test 10, Test 11, Test 12, Test 13, Test 14, Test 15, Test 16, Test 17, Test 18, Test 19, Test 20, " + + "Test 21, Test 22, Test 23, Test 24, Test 25, Test 26, Test 27, Test 28, Test 29, Test 30, Test 31, " + + "Test 32, Test 33, Test 34, Test 35, Test 36, Test 37, Test 38, Test 39, Test 40, Test 41, Test 42, " + + "Test 43, Test 44, Test 45, Test 46, Test 47, Test 48, Test 49, Test 50, Test 51, Test 52, Test 53, " + + "Test 54, Test 55, Test 56, Test 57, Test 58, Test 59, Test 60, Test 61, Test 62, Test 63, Test 64, " + + "Test 65, Test 66, Test 67, Test 68, Test 69, Test 70, Test 71, Test 72, Test 73, Test 74, Test 75, " + + "Test 76, Test 77, Test 78, Test 79, Test 80, Test 81, Test 82, Test 83, Test 84, Test 85, Test 86, " + + "Test 87, Test 88, Test 89, Test 90, Test 91, Test 92, Test 93, Test 94, Test 95, Test 96, Test 97, " + + "Test 98, Test 99]"; public VectorTest() { for (int i = 0; i < 100; i++) { @@ -62,16 +70,16 @@ public class VectorTest { @Test public void test_Constructor() { - // Test for method java.util.Vector() - Vector tv = new Vector<>(100); - for (int i = 0; i < 100; i++) + for (int i = 0; i < 100; i++) { tv.addElement(i); + } new Support_ListTest(tv).runTest(); tv = new Vector<>(200); - for (int i = -50; i < 150; i++) + for (int i = -50; i < 150; i++) { tv.addElement(i); + } new Support_ListTest(tv.subList(50, 150)).runTest(); Vector v = new Vector<>();