mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-08 07:54:11 -08:00
Add tests for lazy evaluation
This commit is contained in:
parent
518e13cf07
commit
5564b47b9f
|
@ -23,6 +23,7 @@ import static org.teavm.metaprogramming.Metaprogramming.arrayClass;
|
||||||
import static org.teavm.metaprogramming.Metaprogramming.emit;
|
import static org.teavm.metaprogramming.Metaprogramming.emit;
|
||||||
import static org.teavm.metaprogramming.Metaprogramming.exit;
|
import static org.teavm.metaprogramming.Metaprogramming.exit;
|
||||||
import static org.teavm.metaprogramming.Metaprogramming.findClass;
|
import static org.teavm.metaprogramming.Metaprogramming.findClass;
|
||||||
|
import static org.teavm.metaprogramming.Metaprogramming.lazy;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.teavm.junit.SkipJVM;
|
import org.teavm.junit.SkipJVM;
|
||||||
|
@ -299,6 +300,56 @@ public class MetaprogrammingTest {
|
||||||
exit(() -> type.getArrayElement(array.get(), index.get()));
|
exit(() -> type.getArrayElement(array.get(), index.get()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void lazyWorks() {
|
||||||
|
WithSideEffect a = new WithSideEffect(10);
|
||||||
|
WithSideEffect b = new WithSideEffect(20);
|
||||||
|
assertEquals(1, withLazy(a, b));
|
||||||
|
assertEquals(1, a.reads);
|
||||||
|
assertEquals(0, b.reads);
|
||||||
|
|
||||||
|
a = new WithSideEffect(-10);
|
||||||
|
b = new WithSideEffect(20);
|
||||||
|
assertEquals(1, withLazy(a, b));
|
||||||
|
assertEquals(1, a.reads);
|
||||||
|
assertEquals(1, b.reads);
|
||||||
|
|
||||||
|
a = new WithSideEffect(-10);
|
||||||
|
b = new WithSideEffect(-20);
|
||||||
|
assertEquals(2, withLazy(a, b));
|
||||||
|
assertEquals(1, a.reads);
|
||||||
|
assertEquals(1, b.reads);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Meta
|
||||||
|
private static native int withLazy(WithSideEffect a, WithSideEffect b);
|
||||||
|
private static void withLazy(Value<WithSideEffect> a, Value<WithSideEffect> b) {
|
||||||
|
Value<Boolean> first = lazy(() -> a.get().getValue() > 0);
|
||||||
|
Value<Boolean> second = lazy(() -> b.get().getValue() > 0);
|
||||||
|
exit(() -> first.get() || second.get() ? 1 : 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void conditionalWorks() {
|
||||||
|
assertEquals("int", fieldType(Context.class, "a"));
|
||||||
|
assertEquals("int", fieldType(Context.class, "b"));
|
||||||
|
assertNull(fieldType(Context.class, "c"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Meta
|
||||||
|
private static native String fieldType(Class<?> cls, String name);
|
||||||
|
private static void fieldType(ReflectClass<Object> cls, Value<String> name) {
|
||||||
|
Value<String> result = lazy(() -> null);
|
||||||
|
for (ReflectField field : cls.getDeclaredFields()) {
|
||||||
|
String type = field.getType().getName();
|
||||||
|
String fieldName = field.getName();
|
||||||
|
Value<String> existing = result;
|
||||||
|
result = lazy(() -> fieldName.equals(name.get()) ? type : existing.get());
|
||||||
|
}
|
||||||
|
Value<String> type = result;
|
||||||
|
exit(() -> type.get());
|
||||||
|
}
|
||||||
|
|
||||||
static class Context {
|
static class Context {
|
||||||
public int a;
|
public int a;
|
||||||
public int b;
|
public int b;
|
||||||
|
@ -346,4 +397,18 @@ public class MetaprogrammingTest {
|
||||||
return emit(() -> "{" + value + "}");
|
return emit(() -> "{" + value + "}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static class WithSideEffect {
|
||||||
|
private int value;
|
||||||
|
public int reads;
|
||||||
|
|
||||||
|
public WithSideEffect(int value) {
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getValue() {
|
||||||
|
++reads;
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user