Fixes classpath bugs. Fixes internal analysis bug. Adds some JCL

This commit is contained in:
konsoletyper 2014-03-04 00:06:03 +04:00
parent 9c4f00c18a
commit 92d4078228
6 changed files with 180 additions and 5 deletions

View File

@ -0,0 +1,32 @@
/*
* Copyright 2014 Alexey Andreev.
*
* 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 org.teavm.classlib.java.lang;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class TIncompatibleClassChangeError extends TLinkageError {
private static final long serialVersionUID = 366119408566298082L;
public TIncompatibleClassChangeError() {
super();
}
public TIncompatibleClassChangeError(TString message) {
super(message);
}
}

View File

@ -0,0 +1,32 @@
/*
* Copyright 2014 Alexey Andreev.
*
* 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 org.teavm.classlib.java.lang;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class TNoSuchFieldError extends TIncompatibleClassChangeError {
private static final long serialVersionUID = 7907885242472547035L;
public TNoSuchFieldError() {
super();
}
public TNoSuchFieldError(TString message) {
super(message);
}
}

View File

@ -0,0 +1,33 @@
/*
* Copyright 2014 Alexey Andreev.
*
* 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 org.teavm.classlib.java.util;
import java.io.IOException;
import org.teavm.codegen.SourceWriter;
import org.teavm.javascript.ni.Generator;
import org.teavm.javascript.ni.GeneratorContext;
import org.teavm.model.MethodReference;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class RandomNativeGenerator implements Generator {
@Override
public void generate(GeneratorContext context, SourceWriter writer, MethodReference methodRef) throws IOException {
writer.append("return Math.random();").softNewLine();
}
}

View File

@ -0,0 +1,73 @@
/*
* Copyright 2014 Alexey Andreev.
*
* 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 org.teavm.classlib.java.util;
import org.teavm.classlib.java.io.TSerializable;
import org.teavm.classlib.java.lang.TMath;
import org.teavm.classlib.java.lang.TObject;
import org.teavm.javascript.ni.GeneratedBy;
/**
*
* @author Alexey Andreev <konsoletyper@gmail.com>
*/
public class TRandom extends TObject implements TSerializable {
public TRandom() {
}
public TRandom(@SuppressWarnings("unused") long seed) {
}
public void setSeed(@SuppressWarnings("unused") long seed) {
}
protected int next(int bits) {
return (int)(random() * (1 << TMath.min(32, bits)));
}
public void nextBytes(byte[] bytes) {
for (int i = 0; i < bytes.length; ) {
bytes[i] = (byte)next(8);
}
}
public int nextInt() {
return next(32);
}
public int nextInt(int n) {
return (int)(random() * n);
}
public long nextLong() {
return ((long)nextInt() << 32) | nextInt();
}
public boolean nextBoolean() {
return nextInt() % 2 == 0;
}
public float nextFloat() {
return (float)random();
}
public double nextDouble() {
return random();
}
@GeneratedBy(RandomNativeGenerator.class)
private static native double random();
}

View File

@ -86,7 +86,6 @@ public class LoopGraph implements Graph {
LoopFrame rootFrame = new LoopFrame(); LoopFrame rootFrame = new LoopFrame();
stack[stackSize++] = rootFrame; stack[stackSize++] = rootFrame;
int walkIndex = 0; int walkIndex = 0;
int[] targetEdges = new int[sz];
int lastSortIndex = sz - 1; int lastSortIndex = sz - 1;
int loopSetSize = 0; int loopSetSize = 0;
while (stackSize > 0) { while (stackSize > 0) {
@ -95,8 +94,8 @@ public class LoopGraph implements Graph {
frames[frame.index] = frame; frames[frame.index] = frame;
frame.walkIndex = walkIndex++; frame.walkIndex = walkIndex++;
stack[stackSize++] = frame; stack[stackSize++] = frame;
int targetEdgesCount = graph.copyOutgoingEdges(frame.index, targetEdges); int[] targetEdges = graph.outgoingEdges(frame.index);
for (int i = 0; i < targetEdgesCount; ++i) { for (int i = 0; i < targetEdges.length; ++i) {
int next = targetEdges[i]; int next = targetEdges[i];
LoopFrame nextFrame = frames[next]; LoopFrame nextFrame = frames[next];
if (nextFrame == null) { if (nextFrame == null) {
@ -109,8 +108,8 @@ public class LoopGraph implements Graph {
frame.sortIndex = lastSortIndex--; frame.sortIndex = lastSortIndex--;
frame.done = true; frame.done = true;
LoopImpl bestLoop = null; LoopImpl bestLoop = null;
int targetEdgesCount = graph.copyOutgoingEdges(frame.index, targetEdges); int[] targetEdges = graph.outgoingEdges(frame.index);
for (int i = 0; i < targetEdgesCount; ++i) { for (int i = 0; i < targetEdges.length; ++i) {
int next = targetEdges[i]; int next = targetEdges[i];
LoopFrame nextFrame = frames[next]; LoopFrame nextFrame = frames[next];
LoopImpl loop = nextFrame.loop; LoopImpl loop = nextFrame.loop;

View File

@ -38,6 +38,12 @@
<groupId>org.netbeans.html</groupId> <groupId>org.netbeans.html</groupId>
<artifactId>net.java.html.boot</artifactId> <artifactId>net.java.html.boot</artifactId>
<version>0.8-SNAPSHOT</version> <version>0.8-SNAPSHOT</version>
<exclusions>
<exclusion>
<groupId>org.ow2.asm</groupId>
<artifactId>asm</artifactId>
</exclusion>
</exclusions>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.netbeans.html</groupId> <groupId>org.netbeans.html</groupId>