修复 UiCollection在JDK 8以下报错的问题

This commit is contained in:
hyb1996 2018-10-28 09:08:50 +08:00
parent e4a92531c3
commit 2acf9123c9
3 changed files with 0 additions and 277 deletions

View File

@ -5,22 +5,18 @@ import android.view.View;
import com.stardust.autojs.BuildConfig;
import com.stardust.autojs.core.ui.ViewExtras;
import com.stardust.autojs.rhino.NativeArrayLikeJavaObject;
import com.stardust.autojs.rhino.RhinoAndroidHelper;
import com.stardust.autojs.rhino.TopLevelScope;
import com.stardust.autojs.runtime.ScriptRuntime;
import com.stardust.autojs.script.JavaScriptSource;
import com.stardust.autojs.script.StringScriptSource;
import com.stardust.automator.UiObject;
import com.stardust.automator.UiObjectCollection;
import com.stardust.pio.PFiles;
import com.stardust.pio.UncheckedIOException;
import org.mozilla.javascript.Context;
import org.mozilla.javascript.NativeArray;
import org.mozilla.javascript.Scriptable;
import org.mozilla.javascript.ScriptableObject;
import org.mozilla.javascript.TopLevel;
import org.mozilla.javascript.commonjs.module.RequireBuilder;
import org.mozilla.javascript.commonjs.module.provider.SoftCachingModuleScriptProvider;

View File

@ -1,230 +0,0 @@
package com.stardust.autojs.rhino;
import android.os.Build;
import android.support.annotation.RequiresApi;
import org.mozilla.javascript.NativeArray;
import org.mozilla.javascript.NativeJavaObject;
import org.mozilla.javascript.Scriptable;
import java.util.Collection;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import java.util.Spliterator;
import java.util.function.Consumer;
import java.util.function.Predicate;
import java.util.function.UnaryOperator;
import java.util.stream.Stream;
public class NativeArrayLikeJavaObject extends NativeJavaObject implements List {
private final NativeArray mArray;
public NativeArrayLikeJavaObject(Scriptable scope, Object javaObject, Class<?> staticType, NativeArray array) {
super(scope, javaObject, staticType);
mArray = array;
setPrototype(mArray);
}
public NativeArrayLikeJavaObject(Scriptable scope, Object javaObject, Class<?> staticType, boolean isAdapter, NativeArray array) {
super(scope, javaObject, staticType, isAdapter);
mArray = array;
setPrototype(mArray);
}
public NativeArrayLikeJavaObject(NativeArray array) {
mArray = array;
setPrototype(mArray);
}
@Override
public boolean has(int index, Scriptable start) {
return mArray.has(index, start);
}
@Override
public Object get(int index, Scriptable start) {
return mArray.get(index, start);
}
@Override
public void put(int index, Scriptable start, Object value) {
mArray.put(index, start, value);
}
@Override
public boolean contains(Object o) {
return mArray.contains(o);
}
@Override
public Object[] toArray() {
return mArray.toArray();
}
@Override
public boolean add(Object o) {
return mArray.add(o);
}
@Override
public Object[] toArray(Object[] a) {
return mArray.toArray(a);
}
@Override
public boolean containsAll(Collection c) {
return mArray.containsAll(c);
}
@Override
public int size() {
return mArray.size();
}
@Override
public boolean isEmpty() {
return mArray.isEmpty();
}
@Override
public Object get(int index) {
return mArray.get(index);
}
@Override
public int indexOf(Object o) {
return mArray.indexOf(o);
}
@Override
public int lastIndexOf(Object o) {
return mArray.lastIndexOf(o);
}
@Override
public Iterator iterator() {
return mArray.iterator();
}
@Override
public ListIterator listIterator() {
return mArray.listIterator();
}
@Override
public ListIterator listIterator(int start) {
return mArray.listIterator(start);
}
@Override
public boolean remove(Object o) {
return mArray.remove(o);
}
@Override
public boolean addAll(Collection c) {
return mArray.addAll(c);
}
@Override
public boolean addAll(int index, Collection c) {
return mArray.addAll(index, c);
}
@Override
public boolean removeAll(Collection c) {
return mArray.removeAll(c);
}
@Override
public boolean retainAll(Collection c) {
return mArray.retainAll(c);
}
@Override
public Object set(int index, Object element) {
return mArray.set(index, element);
}
@Override
public void add(int index, Object element) {
mArray.add(index, element);
}
@Override
public Object remove(int index) {
return mArray.remove(index);
}
@Override
public List subList(int fromIndex, int toIndex) {
return mArray.subList(fromIndex, toIndex);
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public void replaceAll(UnaryOperator operator) {
mArray.replaceAll(operator);
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public void sort(Comparator c) {
mArray.sort(c);
}
@Override
public void clear() {
mArray.clear();
}
@Override
public boolean equals(Object o) {
return mArray.equals(o);
}
@Override
public int hashCode() {
return mArray.hashCode();
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public Spliterator spliterator() {
return mArray.spliterator();
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public boolean removeIf(Predicate filter) {
return mArray.removeIf(filter);
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public Stream stream() {
return mArray.stream();
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public Stream parallelStream() {
return mArray.parallelStream();
}
@RequiresApi(api = Build.VERSION_CODES.N)
@Override
public void forEach(Consumer action) {
mArray.forEach(action);
}
}

View File

@ -291,48 +291,6 @@ public class UiObjectCollection {
return mNodes.lastIndexOf(o);
}
@RequiresApi(api = Build.VERSION_CODES.N)
public ListIterator<UiObject> listIterator() {
return mNodes.listIterator();
}
@RequiresApi(api = Build.VERSION_CODES.N)
public ListIterator<UiObject> listIterator(int index) {
return mNodes.listIterator(index);
}
@RequiresApi(api = Build.VERSION_CODES.N)
public List<UiObject> subList(int fromIndex, int toIndex) {
return mNodes.subList(fromIndex, toIndex);
}
@RequiresApi(api = Build.VERSION_CODES.N)
public Spliterator<UiObject> spliterator() {
return mNodes.spliterator();
}
@RequiresApi(api = Build.VERSION_CODES.N)
public boolean removeIf(Predicate<? super UiObject> filter) {
return mNodes.removeIf(filter);
}
@RequiresApi(api = Build.VERSION_CODES.N)
public Stream<UiObject> stream() {
return mNodes.stream();
}
@RequiresApi(api = Build.VERSION_CODES.N)
public Stream<UiObject> parallelStream() {
return mNodes.parallelStream();
}
public int size() {
return mNodes.size();
}
@ -347,7 +305,6 @@ public class UiObjectCollection {
return mNodes.contains(o);
}
public Iterator<UiObject> iterator() {
return mNodes.iterator();
}