Switch to Java 8

This commit is contained in:
Alexey Andreev 2015-07-22 22:29:19 +03:00
parent c4bb803965
commit 06372c2f9f
26 changed files with 111 additions and 265 deletions

View File

@ -175,8 +175,8 @@
<artifactId>maven-compiler-plugin</artifactId> <artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version> <version>2.5.1</version>
<configuration> <configuration>
<source>1.7</source> <source>1.8</source>
<target>1.7</target> <target>1.8</target>
</configuration> </configuration>
</plugin> </plugin>
<plugin> <plugin>

View File

@ -156,7 +156,7 @@ public class TTreeMap<K, V> extends TAbstractMap<K, V> implements TCloneable, TS
} }
int mid = (l + u) / 2; int mid = (l + u) / 2;
Entry<? extends K, ? extends V> entry = entries[mid]; Entry<? extends K, ? extends V> entry = entries[mid];
TreeNode<K, V> node = new TreeNode<K, V>(entry.getKey()); TreeNode<K, V> node = new TreeNode<>(entry.getKey());
node.setValue(entry.getValue()); node.setValue(entry.getValue());
node.left = createNode(entries, l, mid - 1); node.left = createNode(entries, l, mid - 1);
node.right = createNode(entries, mid + 1, u); node.right = createNode(entries, mid + 1, u);

View File

@ -348,7 +348,7 @@ public class AstIO {
output.writeInt(statement.getExceptionType() != null ? output.writeInt(statement.getExceptionType() != null ?
symbolTable.lookup(statement.getExceptionType()) : -1); symbolTable.lookup(statement.getExceptionType()) : -1);
output.writeShort(statement.getExceptionVariable() != null ? output.writeShort(statement.getExceptionVariable() != null ?
statement.getExceptionVariable().intValue() : -1); statement.getExceptionVariable() : -1);
writeSequence(statement.getHandler()); writeSequence(statement.getHandler());
} catch (IOException e) { } catch (IOException e) {
throw new IOExceptionWrapper(e); throw new IOExceptionWrapper(e);

View File

@ -33,11 +33,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getFullNameFor(method);
@Override public void perform(NamingStrategy naming) {
naming.getFullNameFor(method);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -50,11 +46,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getNameForInit(method);
@Override public void perform(NamingStrategy naming) {
naming.getNameForInit(method);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -66,11 +58,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getNameFor(method);
@Override public void perform(NamingStrategy naming) {
naming.getNameFor(method);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -82,11 +70,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getNameFor(className);
@Override public void perform(NamingStrategy naming) {
naming.getNameFor(className);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -98,11 +82,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getNameFor(field);
@Override public void perform(NamingStrategy naming) {
naming.getNameFor(field);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -114,11 +94,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
Entry entry = entries.get(key); Entry entry = entries.get(key);
if (entry == null) { if (entry == null) {
entry = new Entry(); entry = new Entry();
entry.operation = new NamingOperation() { entry.operation = naming -> naming.getNameForFunction(name);
@Override public void perform(NamingStrategy naming) {
naming.getNameForFunction(name);
}
};
entries.put(key, entry); entries.put(key, entry);
} }
entry.frequency++; entry.frequency++;
@ -126,11 +102,7 @@ public class NamingOrderer implements NameFrequencyConsumer {
public void apply(NamingStrategy naming) { public void apply(NamingStrategy naming) {
List<Entry> entryList = new ArrayList<>(entries.values()); List<Entry> entryList = new ArrayList<>(entries.values());
Collections.sort(entryList, new Comparator<Entry>() { Collections.sort(entryList, (o1, o2) -> Integer.compare(o2.frequency, o1.frequency));
@Override public int compare(Entry o1, Entry o2) {
return Integer.compare(o2.frequency, o1.frequency);
}
});
for (Entry entry : entryList) { for (Entry entry : entryList) {
entry.operation.perform(naming); entry.operation.perform(naming);
} }

View File

@ -80,11 +80,7 @@ public final class GraphUtils {
} }
public static int[][] findStronglyConnectedComponents(Graph graph, int[] start) { public static int[][] findStronglyConnectedComponents(Graph graph, int[] start) {
return findStronglyConnectedComponents(graph, start, new GraphNodeFilter() { return findStronglyConnectedComponents(graph, start, node -> true);
@Override public boolean match(int node) {
return true;
}
});
} }
/* /*

View File

@ -92,14 +92,11 @@ public class RangeTree {
for (Range range : ranges) { for (Range range : ranges) {
rangeList.add(range); rangeList.add(range);
} }
Collections.sort(rangeList, new Comparator<Range>() { Collections.sort(rangeList, (o1, o2) -> {
@Override if (o1.right != o2.right) {
public int compare(Range o1, Range o2) { return o2.right - o1.right;
if (o1.right != o2.right) {
return o2.right - o1.right;
}
return o1.left - o2.left;
} }
return o1.left - o2.left;
}); });
Deque<NodeImpl> stack = new ArrayDeque<>(); Deque<NodeImpl> stack = new ArrayDeque<>();
stack.push(root); stack.push(root);

View File

@ -38,11 +38,7 @@ public class ThreadPoolFiniteExecutor implements FiniteExecutor {
public ThreadPoolFiniteExecutor(int numThreads) { public ThreadPoolFiniteExecutor(int numThreads) {
for (int i = 0; i < numThreads; ++i) { for (int i = 0; i < numThreads; ++i) {
Thread thread = new Thread() { Thread thread = new Thread(() -> takeTask());
@Override public void run() {
takeTask();
}
};
threads.add(thread); threads.add(thread);
thread.start(); thread.start();
} }

View File

@ -107,8 +107,7 @@ public class Debugger {
DebugInformation debugInfo = debugInformationMap.get(script); DebugInformation debugInfo = debugInformationMap.get(script);
if (frame.getLocation() != null && frame.getLocation().getFileName() != null && if (frame.getLocation() != null && frame.getLocation().getFileName() != null &&
frame.getLocation().getLine() >= 0 && debugInfo != null) { frame.getLocation().getLine() >= 0 && debugInfo != null) {
exits = addFollowing(debugInfo, frame.getLocation(), script, new HashSet<SourceLocation>(), exits = addFollowing(debugInfo, frame.getLocation(), script, new HashSet<>(), successors);
successors);
if (enterMethod) { if (enterMethod) {
CallSiteSuccessorFinder successorFinder = new CallSiteSuccessorFinder(debugInfo, script, CallSiteSuccessorFinder successorFinder = new CallSiteSuccessorFinder(debugInfo, script,
successors); successors);

View File

@ -271,7 +271,7 @@ class DebugInformationWriter {
} }
if (count > 1) { if (count > 1) {
if (current > last) { if (current > last) {
writeUnsignedNumber(((current - last) << 1) | 0); writeUnsignedNumber((current - last) << 1);
while (last < current) { while (last < current) {
writeUnsignedNumber(array[last++]); writeUnsignedNumber(array[last++]);
} }
@ -282,7 +282,7 @@ class DebugInformationWriter {
} }
} }
if (array.length > last) { if (array.length > last) {
writeUnsignedNumber(((array.length - last) << 1) | 0); writeUnsignedNumber((array.length - last) << 1);
while (last < array.length) { while (last < array.length) {
writeUnsignedNumber(array[last++]); writeUnsignedNumber(array[last++]);
} }

View File

@ -71,40 +71,24 @@ public class DependencyChecker implements DependencyInfo {
this.classSource = new DependencyClassSource(classSource, diagnostics); this.classSource = new DependencyClassSource(classSource, diagnostics);
this.classLoader = classLoader; this.classLoader = classLoader;
this.services = services; this.services = services;
methodReaderCache = new CachedMapper<>(new Mapper<MethodReference, MethodReader>() { methodReaderCache = new CachedMapper<>(preimage -> findMethodReader(preimage));
@Override public MethodReader map(MethodReference preimage) { fieldReaderCache = new CachedMapper<>(preimage -> findFieldReader(preimage));
return findMethodReader(preimage); methodCache = new CachedMapper<>(preimage -> {
MethodReader method = methodReaderCache.map(preimage);
if (method != null && !method.getReference().equals(preimage)) {
return methodCache.map(method.getReference());
} }
return createMethodDep(preimage, method);
}); });
fieldReaderCache = new CachedMapper<>(new Mapper<FieldReference, FieldReader>() { fieldCache = new CachedMapper<>(preimage -> {
@Override public FieldReader map(FieldReference preimage) { FieldReader field = fieldReaderCache.map(preimage);
return findFieldReader(preimage); if (field != null && !field.getReference().equals(preimage)) {
} return fieldCache.map(field.getReference());
});
methodCache = new CachedMapper<>(new Mapper<MethodReference, MethodDependency>() {
@Override public MethodDependency map(MethodReference preimage) {
MethodReader method = methodReaderCache.map(preimage);
if (method != null && !method.getReference().equals(preimage)) {
return methodCache.map(method.getReference());
}
return createMethodDep(preimage, method);
}
});
fieldCache = new CachedMapper<>(new Mapper<FieldReference, FieldDependency>() {
@Override public FieldDependency map(FieldReference preimage) {
FieldReader field = fieldReaderCache.map(preimage);
if (field != null && !field.getReference().equals(preimage)) {
return fieldCache.map(field.getReference());
}
return createFieldNode(preimage, field);
} }
return createFieldNode(preimage, field);
}); });
classCache = new CachedMapper<>(new Mapper<String, ClassDependency>() { classCache = new CachedMapper<>(preimage -> createClassDependency(preimage));
@Override public ClassDependency map(String preimage) {
return createClassDependency(preimage);
}
});
agent = new DependencyAgent(this); agent = new DependencyAgent(this);
} }
@ -183,20 +167,14 @@ public class DependencyChecker implements DependencyInfo {
} }
} }
void schedulePropagation(final DependencyConsumer consumer, final DependencyType type) { void schedulePropagation(DependencyConsumer consumer, DependencyType type) {
tasks.add(new Runnable() { tasks.add(() -> consumer.consume(type));
@Override public void run() {
consumer.consume(type);
}
});
} }
void schedulePropagation(final DependencyConsumer consumer, final DependencyType[] types) { void schedulePropagation(DependencyConsumer consumer, DependencyType[] types) {
tasks.add(new Runnable() { tasks.add(() -> {
@Override public void run() { for (DependencyType type : types) {
for (DependencyType type : types) { consumer.consume(type);
consumer.consume(type);
}
} }
}); });
} }
@ -215,12 +193,9 @@ public class DependencyChecker implements DependencyInfo {
added = classesAddedByRoot.add(className); added = classesAddedByRoot.add(className);
} }
if (!dep.isMissing() && added) { if (!dep.isMissing() && added) {
tasks.add(new Runnable() { tasks.add(() -> {
@Override for (DependencyListener listener : listeners) {
public void run() { listener.classReached(agent, className, callLocation);
for (DependencyListener listener : listeners) {
listener.classReached(agent, className, callLocation);
}
} }
}); });
} }
@ -289,11 +264,7 @@ public class DependencyChecker implements DependencyInfo {
ClassReader reader = cls.getClassReader(); ClassReader reader = cls.getClassReader();
final MethodReader method = reader.getMethod(new MethodDescriptor("<clinit>", void.class)); final MethodReader method = reader.getMethod(new MethodDescriptor("<clinit>", void.class));
if (method != null) { if (method != null) {
tasks.add(new Runnable() { tasks.add(() -> linkMethod(method.getReference(), callLocation).use());
@Override public void run() {
linkMethod(method.getReference(), callLocation).use();
}
});
} }
} }
@ -369,22 +340,18 @@ public class DependencyChecker implements DependencyInfo {
final MethodDependency dep = new MethodDependency(this, parameterNodes, paramCount, resultNode, thrown, final MethodDependency dep = new MethodDependency(this, parameterNodes, paramCount, resultNode, thrown,
method, methodRef); method, methodRef);
if (method != null) { if (method != null) {
tasks.add(new Runnable() { tasks.add(() -> {
@Override public void run() { CallLocation caller = new CallLocation(dep.getMethod().getReference());
CallLocation caller = new CallLocation(dep.getMethod().getReference()); linkClass(dep.getMethod().getOwnerName(), caller).initClass(caller);
linkClass(dep.getMethod().getOwnerName(), caller).initClass(caller);
}
}); });
} }
return dep; return dep;
} }
void scheduleMethodAnalysis(final MethodDependency dep) { void scheduleMethodAnalysis(final MethodDependency dep) {
tasks.add(new Runnable() { tasks.add(() -> {
@Override public void run() { DependencyGraphBuilder graphBuilder = new DependencyGraphBuilder(DependencyChecker.this);
DependencyGraphBuilder graphBuilder = new DependencyGraphBuilder(DependencyChecker.this); graphBuilder.buildGraph(dep);
graphBuilder.buildGraph(dep);
}
}); });
} }
@ -414,11 +381,7 @@ public class DependencyChecker implements DependencyInfo {
} }
FieldDependency dep = fieldCache.map(fieldRef); FieldDependency dep = fieldCache.map(fieldRef);
if (!dep.isMissing()) { if (!dep.isMissing()) {
tasks.add(new Runnable() { tasks.add(() -> linkClass(fieldRef.getClassName(), location).initClass(location));
@Override public void run() {
linkClass(fieldRef.getClassName(), location).initClass(location);
}
});
} }
if (!dep.isMissing() && added) { if (!dep.isMissing() && added) {
for (DependencyListener listener : listeners) { for (DependencyListener listener : listeners) {
@ -438,18 +401,14 @@ public class DependencyChecker implements DependencyInfo {
return classCache.getKnown(className); return classCache.getKnown(className);
} }
private FieldDependency createFieldNode(final FieldReference fieldRef, FieldReader field) { private FieldDependency createFieldNode(FieldReference fieldRef, FieldReader field) {
DependencyNode node = createNode(); DependencyNode node = createNode();
if (shouldLog) { if (shouldLog) {
node.setTag(fieldRef.getClassName() + "#" + fieldRef.getFieldName()); node.setTag(fieldRef.getClassName() + "#" + fieldRef.getFieldName());
} }
FieldDependency dep = new FieldDependency(node, field, fieldRef); FieldDependency dep = new FieldDependency(node, field, fieldRef);
if (!dep.isMissing()) { if (!dep.isMissing()) {
tasks.add(new Runnable() { tasks.add(() -> linkClass(fieldRef.getClassName(), null).initClass(null));
@Override public void run() {
linkClass(fieldRef.getClassName(), null).initClass(null);
}
});
} }
return dep; return dep;
} }

View File

@ -21,7 +21,6 @@ import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import org.teavm.common.CachedMapper; import org.teavm.common.CachedMapper;
import org.teavm.common.Mapper;
import org.teavm.diagnostics.Diagnostics; import org.teavm.diagnostics.Diagnostics;
import org.teavm.model.ClassHolder; import org.teavm.model.ClassHolder;
import org.teavm.model.ClassHolderTransformer; import org.teavm.model.ClassHolderTransformer;
@ -38,11 +37,7 @@ class DependencyClassSource implements ClassReaderSource {
private Diagnostics diagnostics; private Diagnostics diagnostics;
private Map<String, ClassHolder> generatedClasses = new HashMap<>(); private Map<String, ClassHolder> generatedClasses = new HashMap<>();
private List<ClassHolderTransformer> transformers = new ArrayList<>(); private List<ClassHolderTransformer> transformers = new ArrayList<>();
private CachedMapper<String, ClassReader> cache = new CachedMapper<>(new Mapper<String, ClassReader>() { private CachedMapper<String, ClassReader> cache = new CachedMapper<>(preimage -> findAndTransformClass(preimage));
@Override public ClassReader map(String preimage) {
return findAndTransformClass(preimage);
}
});
public DependencyClassSource(ClassReaderSource innerSource, Diagnostics diagnostics) { public DependencyClassSource(ClassReaderSource innerSource, Diagnostics diagnostics) {
this.innerSource = innerSource; this.innerSource = innerSource;

View File

@ -236,12 +236,8 @@ class DependencyGraphBuilder {
methodDep.use(); methodDep.use();
DependencyNode[] targetParams = methodDep.getVariables(); DependencyNode[] targetParams = methodDep.getVariables();
if (parameters[0] != null && targetParams[0] != null) { if (parameters[0] != null && targetParams[0] != null) {
parameters[0].connect(targetParams[0], new DependencyTypeFilter() { parameters[0].connect(targetParams[0], thisType -> isAssignableFrom(checker.getClassSource(),
@Override public boolean match(DependencyType thisType) { methodDep.getMethod().getOwnerName(), thisType.getName()));
return isAssignableFrom(checker.getClassSource(), methodDep.getMethod().getOwnerName(),
thisType.getName());
}
});
} }
for (int i = 1; i < parameters.length; ++i) { for (int i = 1; i < parameters.length; ++i) {
if (parameters[i] != null && targetParams[i] != null) { if (parameters[i] != null && targetParams[i] != null) {
@ -267,10 +263,8 @@ class DependencyGraphBuilder {
if (subtype.getParent() != null && isAssignableFrom(classSource, supertype, subtype.getParent())) { if (subtype.getParent() != null && isAssignableFrom(classSource, supertype, subtype.getParent())) {
return true; return true;
} }
for (String iface : subtype.getInterfaces()) { if (subtype.getInterfaces().stream().anyMatch(iface -> isAssignableFrom(classSource, supertype, iface))) {
if (isAssignableFrom(classSource, supertype, iface)) { return true;
return true;
}
} }
return false; return false;
} }
@ -358,14 +352,12 @@ class DependencyGraphBuilder {
final ClassReader targetClass = dependencyChecker.getClassSource().get(targetClsName); final ClassReader targetClass = dependencyChecker.getClassSource().get(targetClsName);
if (targetClass != null) { if (targetClass != null) {
if (valueNode != null && receiverNode != null) { if (valueNode != null && receiverNode != null) {
valueNode.connect(receiverNode, new DependencyTypeFilter() { valueNode.connect(receiverNode, type -> {
@Override public boolean match(DependencyType type) { if (targetClass.getName().equals("java.lang.Object")) {
if (targetClass.getName().equals("java.lang.Object")) { return true;
return true;
}
return isAssignableFrom(dependencyChecker.getClassSource(), targetClass.getName(),
type.getName());
} }
return isAssignableFrom(dependencyChecker.getClassSource(), targetClass.getName(),
type.getName());
}); });
} }
return; return;
@ -514,11 +506,7 @@ class DependencyGraphBuilder {
DependencyNode arrayNode = nodes[array.getIndex()]; DependencyNode arrayNode = nodes[array.getIndex()];
final DependencyNode receiverNode = nodes[receiver.getIndex()]; final DependencyNode receiverNode = nodes[receiver.getIndex()];
if (arrayNode != null && receiverNode != null) { if (arrayNode != null && receiverNode != null) {
arrayNode.addConsumer(new DependencyConsumer() { arrayNode.addConsumer(type -> receiverNode.propagate(type));
@Override public void consume(DependencyType type) {
receiverNode.propagate(type);
}
});
arrayNode.getArrayItem().connect(receiverNode.getArrayItem()); arrayNode.getArrayItem().connect(receiverNode.getArrayItem());
} }
} }

View File

@ -182,11 +182,7 @@ public class DependencyNode implements ValueDependencyInfo {
if (DependencyChecker.shouldLog) { if (DependencyChecker.shouldLog) {
arrayItemNode.tag = tag + "["; arrayItemNode.tag = tag + "[";
} }
arrayItemNode.addConsumer(new DependencyConsumer() { arrayItemNode.addConsumer(type -> propagate(type));
@Override public void consume(DependencyType type) {
DependencyNode.this.propagate(type);
}
});
} }
return arrayItemNode; return arrayItemNode;
} }

View File

@ -378,7 +378,6 @@ class OptimizingVisitor implements StatementVisitor, ExprVisitor {
statements.remove(i + 1); statements.remove(i + 1);
wieldTryCatch(first.getProtectedBody()); wieldTryCatch(first.getProtectedBody());
--i; --i;
continue;
} }
} }
} }

View File

@ -359,7 +359,6 @@ public class Renderer implements ExprVisitor, StatementVisitor, RenderingContext
debugEmitter.emitClass(cls.getName()); debugEmitter.emitClass(cls.getName());
try { try {
List<MethodNode> nonInitMethods = new ArrayList<>(); List<MethodNode> nonInitMethods = new ArrayList<>();
List<MethodNode> virtualMethods = new ArrayList<>();
MethodHolder clinit = classSource.get(cls.getName()).getMethod( MethodHolder clinit = classSource.get(cls.getName()).getMethod(
new MethodDescriptor("<clinit>", ValueType.VOID)); new MethodDescriptor("<clinit>", ValueType.VOID));
List<MethodNode> clinitMethods = new ArrayList<>(); List<MethodNode> clinitMethods = new ArrayList<>();
@ -393,8 +392,6 @@ public class Renderer implements ExprVisitor, StatementVisitor, RenderingContext
if (!method.getModifiers().contains(NodeModifier.STATIC)) { if (!method.getModifiers().contains(NodeModifier.STATIC)) {
if (method.getReference().getName().equals("<init>")) { if (method.getReference().getName().equals("<init>")) {
renderInitializer(method); renderInitializer(method);
} else {
virtualMethods.add(method);
} }
} }
} }
@ -686,7 +683,7 @@ public class Renderer implements ExprVisitor, StatementVisitor, RenderingContext
variableNames.add(variableName(i)); variableNames.add(variableName(i));
} }
TryCatchFinder tryCatchFinder = new TryCatchFinder(); TryCatchFinder tryCatchFinder = new TryCatchFinder();
for (AsyncMethodPart part : methodNode.getBody()) { for (AsyncMethodPart part : methodNode.getBody()) {
if (!tryCatchFinder.tryCatchFound) { if (!tryCatchFinder.tryCatchFound) {
part.getStatement().acceptVisitor(tryCatchFinder); part.getStatement().acceptVisitor(tryCatchFinder);
} }

View File

@ -31,7 +31,7 @@ public abstract class Expr implements Cloneable {
@Override @Override
public Expr clone() { public Expr clone() {
return clone(new HashMap<Expr, Expr>()); return clone(new HashMap<>());
} }
protected abstract Expr clone(Map<Expr, Expr> cache); protected abstract Expr clone(Map<Expr, Expr> cache);

View File

@ -15,7 +15,6 @@
*/ */
package org.teavm.model; package org.teavm.model;
import org.teavm.common.Mapper;
import org.teavm.model.util.ModelUtils; import org.teavm.model.util.ModelUtils;
import org.teavm.resource.MapperClassHolderSource; import org.teavm.resource.MapperClassHolderSource;
@ -25,11 +24,7 @@ import org.teavm.resource.MapperClassHolderSource;
*/ */
public class CopyClassHolderSource implements ClassHolderSource { public class CopyClassHolderSource implements ClassHolderSource {
private ClassReaderSource innerSource; private ClassReaderSource innerSource;
private MapperClassHolderSource mapperSource = new MapperClassHolderSource(new Mapper<String, ClassHolder>() { private MapperClassHolderSource mapperSource = new MapperClassHolderSource(preimage -> copyClass(preimage));
@Override public ClassHolder map(String preimage) {
return copyClass(preimage);
}
});
public CopyClassHolderSource(ClassReaderSource innerSource) { public CopyClassHolderSource(ClassReaderSource innerSource) {
this.innerSource = innerSource; this.innerSource = innerSource;

View File

@ -44,7 +44,7 @@ class LocationGraphBuilder {
Deque<Step> stack = new ArrayDeque<>(); Deque<Step> stack = new ArrayDeque<>();
for (int i = 0; i < graph.size(); ++i) { for (int i = 0; i < graph.size(); ++i) {
if (graph.incomingEdgesCount(i) == 0) { if (graph.incomingEdgesCount(i) == 0) {
stack.push(new Step(null, new HashSet<InstructionLocation>(), i)); stack.push(new Step(null, new HashSet<>(), i));
} }
} }
boolean[] visited = new boolean[graph.size()]; boolean[] visited = new boolean[graph.size()];
@ -84,8 +84,7 @@ class LocationGraphBuilder {
} }
} else { } else {
for (int next : graph.outgoingEdges(step.block)) { for (int next : graph.outgoingEdges(step.block)) {
stack.push(new Step(location, started ? new HashSet<InstructionLocation>() : step.startLocations, stack.push(new Step(location, started ? new HashSet<>() : step.startLocations, next));
next));
} }
} }
} }

View File

@ -126,7 +126,7 @@ public class GlobalValueNumbering implements MethodOptimization {
private List<List<Incoming>> findOutgoings(Program program) { private List<List<Incoming>> findOutgoings(Program program) {
List<List<Incoming>> outgoings = new ArrayList<>(); List<List<Incoming>> outgoings = new ArrayList<>();
for (int i = 0; i < program.basicBlockCount(); ++i) { for (int i = 0; i < program.basicBlockCount(); ++i) {
outgoings.add(new ArrayList<Incoming>()); outgoings.add(new ArrayList<>());
} }
for (int i = 0; i < program.basicBlockCount(); ++i) { for (int i = 0; i < program.basicBlockCount(); ++i) {
for (Phi phi : program.basicBlockAt(i).getPhis()) { for (Phi phi : program.basicBlockAt(i).getPhis()) {

View File

@ -125,12 +125,7 @@ public class ClasspathResourceMapper implements Mapper<String, ClassHolder>, Cla
return name; return name;
} }
private Mapper<String, String> classNameMapper = new Mapper<String, String>() { private Mapper<String, String> classNameMapper = preimage -> renameClass(preimage);
@Override
public String map(String preimage) {
return renameClass(preimage);
}
};
@Override @Override
public Date getModificationDate(String className) { public Date getModificationDate(String className) {

View File

@ -122,8 +122,8 @@ public class SSATransformer {
List<List<TryCatchBlock>> caughtBlocks = new ArrayList<>(); List<List<TryCatchBlock>> caughtBlocks = new ArrayList<>();
List<List<Phi>> specialPhis = new ArrayList<>(); List<List<Phi>> specialPhis = new ArrayList<>();
for (int i = 0; i < program.basicBlockCount(); ++i) { for (int i = 0; i < program.basicBlockCount(); ++i) {
caughtBlocks.add(new ArrayList<TryCatchBlock>()); caughtBlocks.add(new ArrayList<>());
specialPhis.add(new ArrayList<Phi>()); specialPhis.add(new ArrayList<>());
} }
for (int i = 0; i < program.basicBlockCount(); ++i) { for (int i = 0; i < program.basicBlockCount(); ++i) {
for (TryCatchBlock tryCatch : program.basicBlockAt(i).getTryCatchBlocks()) { for (TryCatchBlock tryCatch : program.basicBlockAt(i).getTryCatchBlocks()) {

View File

@ -254,24 +254,18 @@ public class TeaVMTestTool {
if (numThreads != 1) { if (numThreads != 1) {
int threads = numThreads != 0 ? numThreads : Runtime.getRuntime().availableProcessors(); int threads = numThreads != 0 ? numThreads : Runtime.getRuntime().availableProcessors();
final ThreadPoolFiniteExecutor threadedExecutor = new ThreadPoolFiniteExecutor(threads); final ThreadPoolFiniteExecutor threadedExecutor = new ThreadPoolFiniteExecutor(threads);
finalizer = new Runnable() { finalizer = () -> threadedExecutor.stop();
@Override public void run() {
threadedExecutor.stop();
}
};
executor = threadedExecutor; executor = threadedExecutor;
} }
for (final MethodReference method : testMethods) { for (final MethodReference method : testMethods) {
final ClassHolderSource builderClassSource = classSource; final ClassHolderSource builderClassSource = classSource;
executor.execute(new Runnable() { executor.execute(() -> {
@Override public void run() { log.debug("Building test for " + method);
log.debug("Building test for " + method); try {
try { decompileClassesForTest(classLoader, new CopyClassHolderSource(builderClassSource), method,
decompileClassesForTest(classLoader, new CopyClassHolderSource(builderClassSource), method, fileNames.get(method));
fileNames.get(method)); } catch (IOException e) {
} catch (IOException e) { log.error("Error generating JavaScript", e);
log.error("Error generating JavaScript", e);
}
} }
}); });
++methodsGenerated; ++methodsGenerated;

View File

@ -350,11 +350,7 @@ public class TeaVM implements TeaVMHost, ServiceRepository {
return; return;
} }
AliasProvider aliasProvider = minifying ? new MinifyingAliasProvider() : new DefaultAliasProvider(); AliasProvider aliasProvider = minifying ? new MinifyingAliasProvider() : new DefaultAliasProvider();
dependencyChecker.setInterruptor(new DependencyCheckerInterruptor() { dependencyChecker.setInterruptor(() -> progressListener.progressReached(0) == TeaVMProgressFeedback.CONTINUE);
@Override public boolean shouldContinue() {
return progressListener.progressReached(0) == TeaVMProgressFeedback.CONTINUE;
}
});
dependencyChecker.linkMethod(new MethodReference(Class.class.getName(), "getClass", dependencyChecker.linkMethod(new MethodReference(Class.class.getName(), "getClass",
ValueType.object("org.teavm.platform.PlatformClass"), ValueType.parse(Class.class)), null).use(); ValueType.object("org.teavm.platform.PlatformClass"), ValueType.parse(Class.class)), null).use();
dependencyChecker.linkMethod(new MethodReference(String.class, "<init>", char[].class, void.class), dependencyChecker.linkMethod(new MethodReference(String.class, "<init>", char[].class, void.class),

View File

@ -16,11 +16,12 @@
package org.teavm.common; package org.teavm.common;
import static org.hamcrest.CoreMatchers.is; import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.*; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
import com.carrotsearch.hppc.IntOpenHashSet; import com.carrotsearch.hppc.IntOpenHashSet;
import com.carrotsearch.hppc.IntSet; import com.carrotsearch.hppc.IntSet;
import java.util.Arrays; import java.util.Arrays;
import java.util.Comparator;
import org.junit.Test; import org.junit.Test;
/** /**
@ -77,11 +78,7 @@ public class GraphTest {
builder.addEdge(5, 3); builder.addEdge(5, 3);
Graph graph = builder.build(); Graph graph = builder.build();
int[][] sccs = GraphUtils.findStronglyConnectedComponents(graph, new int[] { 1, 2, 3 }, new GraphNodeFilter() { int[][] sccs = GraphUtils.findStronglyConnectedComponents(graph, new int[] { 1, 2, 3 }, node -> node != 0);
@Override public boolean match(int node) {
return node != 0;
}
});
sortSccs(sccs); sortSccs(sccs);
assertThat(sccs.length, is(1)); assertThat(sccs.length, is(1));
@ -129,12 +126,7 @@ public class GraphTest {
builder.addEdge(8, 7); builder.addEdge(8, 7);
Graph graph = builder.build(); Graph graph = builder.build();
int[][] sccs = GraphUtils.findStronglyConnectedComponents(graph, new int[] { 1, 2, 3, 4 }, int[][] sccs = GraphUtils.findStronglyConnectedComponents(graph, new int[] { 1, 2, 3, 4 }, node -> node != 0);
new GraphNodeFilter() {
@Override public boolean match(int node) {
return node != 0;
}
});
sortSccs(sccs); sortSccs(sccs);
assertThat(sccs.length, is(2)); assertThat(sccs.length, is(2));
@ -240,20 +232,12 @@ public class GraphTest {
return true; return true;
} }
private GraphNodeFilter filter = new GraphNodeFilter() { private GraphNodeFilter filter = (int node) -> true;
@Override public boolean match(int node) {
return true;
}
};
private void sortSccs(int[][] sccs) { private void sortSccs(int[][] sccs) {
for (int i = 0; i < sccs.length; ++i) { for (int i = 0; i < sccs.length; ++i) {
Arrays.sort(sccs[i]); Arrays.sort(sccs[i]);
} }
Arrays.sort(sccs, new Comparator<int[]>() { Arrays.sort(sccs, (o1, o2) -> Integer.compare(o1[0], o2[0]));
@Override public int compare(int[] o1, int[] o2) {
return Integer.compare(o1[0], o2[0]);
}
});
} }
} }

View File

@ -99,18 +99,18 @@ public final class AsyncProgram {
boolean[] prime = new boolean[1000]; boolean[] prime = new boolean[1000];
prime[2] = true; prime[2] = true;
prime[3] = true; prime[3] = true;
nextPrime: for (int i = 5; i < prime.length; i += 2) { nextPrime: for (int i = 5; i &lt; prime.length; i += 2) {
int maxPrime = (int)Math.sqrt(i); int maxPrime = (int)Math.sqrt(i);
for (int j = 3; j <= maxPrime; j += 2) { for (int j = 3; j &lt;= maxPrime; j += 2) {
Thread.yield(); Thread.yield();
if (prime[j] && i % j == 0) { if (prime[j] &amp;&amp; i % j == 0) {
continue nextPrime; continue nextPrime;
} }
} }
prime[i] = true; prime[i] = true;
} }
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
for (int i = 0; i < 1000; ++i) { for (int i = 0; i &lt; 1000; ++i) {
if (prime[i]) { if (prime[i]) {
sb.append(i).append(' '); sb.append(i).append(' ');
} }
@ -144,9 +144,9 @@ public final class AsyncProgram {
private static void withoutAsync() { private static void withoutAsync() {
report("Start sync"); report("Start sync");
for (int i = 0; i < 20; ++i) { for (int i = 0; i &lt; 20; ++i) {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
for (int j = 0; j <= i; ++j) { for (int j = 0; j &lt;= i; ++j) {
sb.append(j); sb.append(j);
sb.append(' '); sb.append(' ');
} }
@ -157,9 +157,9 @@ public final class AsyncProgram {
private static void withAsync() throws InterruptedException { private static void withAsync() throws InterruptedException {
report("Start async"); report("Start async");
for (int i = 0; i < 20; ++i) { for (int i = 0; i &lt; 20; ++i) {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();
for (int j = 0; j <= i; ++j) { for (int j = 0; j &lt;= i; ++j) {
sb.append(j); sb.append(j);
sb.append(' '); sb.append(' ');
} }

View File

@ -17,8 +17,6 @@ package org.teavm.samples.storage;
import org.teavm.dom.browser.Storage; import org.teavm.dom.browser.Storage;
import org.teavm.dom.browser.Window; import org.teavm.dom.browser.Window;
import org.teavm.dom.events.Event;
import org.teavm.dom.events.EventListener;
import org.teavm.dom.html.HTMLButtonElement; import org.teavm.dom.html.HTMLButtonElement;
import org.teavm.dom.html.HTMLDocument; import org.teavm.dom.html.HTMLDocument;
import org.teavm.dom.html.HTMLElement; import org.teavm.dom.html.HTMLElement;
@ -44,37 +42,28 @@ public final class Application {
} }
HTMLButtonElement saveButton = (HTMLButtonElement)document.getElementById("save-button"); HTMLButtonElement saveButton = (HTMLButtonElement)document.getElementById("save-button");
saveButton.addEventListener("click", new EventListener() { saveButton.addEventListener("click", e -> {
@Override String key = ((HTMLInputElement)document.getElementById("key")).getValue();
public void handleEvent(Event evt) { String value = ((HTMLInputElement)document.getElementById("value")).getValue();
String key = ((HTMLInputElement)document.getElementById("key")).getValue();
String value = ((HTMLInputElement)document.getElementById("value")).getValue();
if (key != null && key.length() > 0 && value != null && value.length() > 0) { if (key != null && key.length() > 0 && value != null && value.length() > 0) {
storage.setItem(key, value); storage.setItem(key, value);
draw(); draw();
}
} }
}); });
HTMLButtonElement deleteButton = (HTMLButtonElement)document.getElementById("delete-button"); HTMLButtonElement deleteButton = (HTMLButtonElement)document.getElementById("delete-button");
deleteButton.addEventListener("click", new EventListener() { deleteButton.addEventListener("click", e -> {
@Override String key = ((HTMLInputElement)document.getElementById("key")).getValue();
public void handleEvent(Event evt) {
String key = ((HTMLInputElement)document.getElementById("key")).getValue();
if (key != null && key.length() > 0) { if (key != null && key.length() > 0) {
storage.removeItem(key); storage.removeItem(key);
draw(); draw();
}
} }
}); });
HTMLButtonElement deleteAllButton = (HTMLButtonElement)document.getElementById("delete-all-button"); HTMLButtonElement deleteAllButton = (HTMLButtonElement)document.getElementById("delete-all-button");
deleteAllButton.addEventListener("click", new EventListener() { deleteAllButton.addEventListener("click", e -> {
@Override storage.clear();
public void handleEvent(Event evt) { draw();
storage.clear();
draw();
}
}); });
draw(); draw();
} }