Merge remote branch 'origin/master' into r0.5

This commit is contained in:
Joel Dice 2011-01-25 17:30:21 -07:00
commit e16d5f83af
20 changed files with 191 additions and 18 deletions

View File

@ -37,10 +37,12 @@
# define OPEN_MASK O_BINARY # define OPEN_MASK O_BINARY
# ifdef _MSC_VER # ifdef _MSC_VER
# define S_ISREG(x) ((x) | _S_IFREG) # define S_ISREG(x) ((x) & _S_IFREG)
# define S_ISDIR(x) ((x) | _S_IFDIR) # define S_ISDIR(x) ((x) & _S_IFDIR)
# define S_IRUSR _S_IREAD # define S_IRUSR _S_IREAD
# define S_IWUSR _S_IWRITE # define S_IWUSR _S_IWRITE
# define W_OK 2
# define R_OK 4
# else # else
# define OPEN _wopen # define OPEN _wopen
# define CREAT _wcreat # define CREAT _wcreat
@ -331,7 +333,7 @@ Java_java_io_File_length(JNIEnv* e, jclass, jstring path)
} }
} }
return -1; return 0;
} }
extern "C" JNIEXPORT void JNICALL extern "C" JNIEXPORT void JNICALL

View File

@ -39,10 +39,34 @@ public class PrintStream extends OutputStream {
print(String.valueOf(o)); print(String.valueOf(o));
} }
public void print(boolean v) {
print(String.valueOf(v));
}
public void print(char c) { public void print(char c) {
print(String.valueOf(c)); print(String.valueOf(c));
} }
public void print(int v) {
print(String.valueOf(v));
}
public void print(long v) {
print(String.valueOf(v));
}
public void print(float v) {
print(String.valueOf(v));
}
public void print(double v) {
print(String.valueOf(v));
}
public void print(char[] s) {
print(String.valueOf(s));
}
public synchronized void println(String s) { public synchronized void println(String s) {
try { try {
out.write(s.getBytes()); out.write(s.getBytes());
@ -62,9 +86,33 @@ public class PrintStream extends OutputStream {
println(String.valueOf(o)); println(String.valueOf(o));
} }
public void println(boolean v) {
println(String.valueOf(v));
}
public void println(char c) { public void println(char c) {
println(String.valueOf(c)); println(String.valueOf(c));
} }
public void println(int v) {
println(String.valueOf(v));
}
public void println(long v) {
println(String.valueOf(v));
}
public void println(float v) {
println(String.valueOf(v));
}
public void println(double v) {
println(String.valueOf(v));
}
public void println(char[] s) {
println(String.valueOf(s));
}
public void write(int c) throws IOException { public void write(int c) throws IOException {
out.write(c); out.write(c);

View File

@ -28,5 +28,17 @@ public abstract class Reader {
public abstract int read(char[] buffer, int offset, int length) public abstract int read(char[] buffer, int offset, int length)
throws IOException; throws IOException;
public boolean markSupported() {
return false;
}
public void mark(int readAheadLimit) throws IOException {
throw new IOException("mark not supported");
}
public void reset() throws IOException {
throw new IOException("reset not supported");
}
public abstract void close() throws IOException; public abstract void close() throws IOException;
} }

View File

@ -109,6 +109,15 @@ public final class Character implements Comparable<Character> {
} }
} }
public static char forDigit(int digit, int radix) {
if (MIN_RADIX <= radix && radix <= MAX_RADIX) {
if (0 <= digit && digit < radix) {
return (char) (digit < 10 ? digit + '0' : digit + 'a' - 10);
}
}
return 0;
}
public static boolean isLetter(int c) { public static boolean isLetter(int c) {
return canCastToChar(c) && isLetter((char) c); return canCastToChar(c) && isLetter((char) c);
} }

View File

@ -43,4 +43,8 @@ public class Package {
this.sealed = sealed; this.sealed = sealed;
this.loader = loader; this.loader = loader;
} }
public String getName() {
return name;
}
} }

View File

@ -33,6 +33,14 @@ public class TreeSet<T> extends AbstractSet<T> implements Collection<T> {
} }
}); });
} }
public TreeSet(Collection<? extends T> collection) {
this();
for (T item: collection) {
add(item);
}
}
public Iterator<T> iterator() { public Iterator<T> iterator() {
return new MyIterator<T>(set.first()); return new MyIterator<T>(set.first());

View File

@ -353,7 +353,8 @@ ifdef msvc
ld = "$(msvc)/BIN/link.exe" ld = "$(msvc)/BIN/link.exe"
mt = "mt.exe" mt = "mt.exe"
cflags = -nologo -DAVIAN_VERSION=\"$(version)\" -D_JNI_IMPLEMENTATION_ \ cflags = -nologo -DAVIAN_VERSION=\"$(version)\" -D_JNI_IMPLEMENTATION_ \
-DUSE_ATOMIC_OPERATIONS \ -DUSE_ATOMIC_OPERATIONS -DAVIAN_JAVA_HOME=\"$(javahome)\" \
-DAVIAN_EMBED_PREFIX=\"$(embed-prefix)\" \
-Fd$(build)/$(name).pdb -I"$(zlib)/include" -I$(src) -I"$(build)" \ -Fd$(build)/$(name).pdb -I"$(zlib)/include" -I$(src) -I"$(build)" \
-I"$(windows-java-home)/include" -I"$(windows-java-home)/include/win32" -I"$(windows-java-home)/include" -I"$(windows-java-home)/include/win32"
shared = -dll shared = -dll

View File

@ -187,7 +187,7 @@ C++ portions of the VM, while the assembly code and helper tools are
built using GCC. built using GCC.
The MSVC build has been tested with Visual Studio Express Edition The MSVC build has been tested with Visual Studio Express Edition
versions 8 and 9. Other versions may also work. versions 8, 9, and 10. Other versions may also work.
To build with MSVC, install Cygwin as described above and set the To build with MSVC, install Cygwin as described above and set the
following environment variables: following environment variables:
@ -442,7 +442,10 @@ For boot image builds:
space in the executable than the equivalent class files. In space in the executable than the equivalent class files. In
practice, this can make the executable 30-50% larger. Also, AOT practice, this can make the executable 30-50% larger. Also, AOT
compilation does not yet yield significantly faster or smaller code compilation does not yet yield significantly faster or smaller code
than JIT compilation. than JIT compilation. Finally, floating point code may be slower
on 32-bit x86 since the compiler cannot assume SSE2 support will be
available at runtime, and the x87 FPU is not supported except via
out-of-line helper functions.
Note you can use ProGuard without using a boot image and vice-versa, Note you can use ProGuard without using a boot image and vice-versa,
as desired. as desired.
@ -462,7 +465,7 @@ Step 2: Create a stage1 directory and extract the contents of the
class library jar into it. class library jar into it.
$ mkdir stage1 $ mkdir stage1
$ (cd stage1 && jar xf ../../build/${platform}-${arch}/classpath.jar) $ (cd stage1 && jar xf ../../build/linux-i386-bootimage/classpath.jar)
Step 3: Build the Java code and add it to stage1. Step 3: Build the Java code and add it to stage1.
@ -498,10 +501,10 @@ Step 6: Build the boot image.
Step 7: Make an object file out of the boot image. Step 7: Make an object file out of the boot image.
$ ../build/${platform}-${arch}/binaryToObject \ $ ../build/linux-i386-bootimage/binaryToObject \
bootimage.bin bootimage-bin.o \ bootimage.bin bootimage-bin.o \
_binary_bootimage_bin_start _binary_bootimage_bin_end \ _binary_bootimage_bin_start _binary_bootimage_bin_end \
${platform} ${arch} 8 writable executable linux i386 8 writable executable
Step 8: Write a driver which starts the VM and runs the desired main Step 8: Write a driver which starts the VM and runs the desired main
method. Note the bootimageBin function, which will be called by the method. Note the bootimageBin function, which will be called by the

View File

@ -405,6 +405,41 @@ writeBootImage2(Thread* t, FILE* out, BootImage* image, uint8_t* code,
set(t, type(t, Machine::JdoubleType), ClassName, name); set(t, type(t, Machine::JdoubleType), ClassName, name);
} }
// resolve primitive array classes in case they are needed at
// runtime:
{ resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[B"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[Z"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[S"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[C"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[I"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[J"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[F"), true);
if (t->exception) return;
resolveSystemClass
(t, root(t, Machine::BootLoader), makeByteArray(t, "[D"), true);
if (t->exception) return;
}
collect(t, Heap::MajorCollection); collect(t, Heap::MajorCollection);
uintptr_t* heap = static_cast<uintptr_t*> uintptr_t* heap = static_cast<uintptr_t*>

View File

@ -458,7 +458,7 @@ class JarIndex {
RUNTIME_ARRAY_BODY(n)[length] = '/'; RUNTIME_ARRAY_BODY(n)[length] = '/';
RUNTIME_ARRAY_BODY(n)[length + 1] = 0; RUNTIME_ARRAY_BODY(n)[length + 1] = 0;
node = findNode(n); node = findNode(RUNTIME_ARRAY_BODY(n));
if (node) { if (node) {
return System::TypeDirectory; return System::TypeDirectory;
} else { } else {

View File

@ -1842,7 +1842,16 @@ resolveArrayClass(Thread* t, object loader, object spec, bool throw_)
return c; return c;
} else { } else {
return makeArrayClass(t, loader, spec, throw_); PROTECT(t, loader);
PROTECT(t, spec);
c = findLoadedClass(t, root(t, Machine::BootLoader), spec);
if (c) {
return c;
} else {
return makeArrayClass(t, loader, spec, throw_);
}
} }
} }

View File

@ -62,7 +62,13 @@ extern "C" void __cxa_pure_virtual(void) { abort(); }
// we link against a System implmentation, which requires this at link // we link against a System implmentation, which requires this at link
// time, but it should not be used at runtime: // time, but it should not be used at runtime:
extern "C" uint64_t extern "C" uint64_t
vmNativeCall(void*, void*, unsigned, unsigned) { abort(); } vmNativeCall(void*, void*, unsigned, unsigned)
{
abort();
// abort is not declared __declspec(noreturn) on MSVC, so we have to
// pretend it might return to make the compiler happy:
return 0;
}
#endif // BOOT_LIBRARY #endif // BOOT_LIBRARY

View File

@ -206,12 +206,12 @@ resolveNativeMethod(Thread* t, object method, const char* prefix,
object object
resolveNativeMethod(Thread* t, object method) resolveNativeMethod(Thread* t, object method)
{ {
void* p = ::resolveNativeMethod(t, method, "Avian_", 6, 3); void* p = resolveNativeMethod(t, method, "Avian_", 6, 3);
if (p) { if (p) {
return makeNative(t, p, true); return makeNative(t, p, true);
} }
p = ::resolveNativeMethod(t, method, "Java_", 5, -1); p = resolveNativeMethod(t, method, "Java_", 5, -1);
if (p) { if (p) {
return makeNative(t, p, false); return makeNative(t, p, false);
} }

View File

@ -4,7 +4,6 @@ import java.io.FileInputStream;
public class DefineClass { public class DefineClass {
private static File findClass(String name, File directory) { private static File findClass(String name, File directory) {
File[] files = directory.listFiles();
for (File file: directory.listFiles()) { for (File file: directory.listFiles()) {
if (file.isFile()) { if (file.isFile()) {
if (file.getName().equals(name + ".class")) { if (file.getName().equals(name + ".class")) {
@ -50,7 +49,7 @@ public class DefineClass {
} }
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
testStatic(); //testStatic();
testDerived(); testDerived();
} }
@ -72,6 +71,7 @@ public class DefineClass {
public abstract static class Base { public abstract static class Base {
public int foo; public int foo;
public int[] array;
public void bar() { } public void bar() { }

View File

@ -4,6 +4,10 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
public class FileOutput { public class FileOutput {
private static void expect(boolean v) {
if (! v) throw new RuntimeException();
}
private static void test(boolean appendFirst) throws IOException { private static void test(boolean appendFirst) throws IOException {
try { try {
FileOutputStream f = new FileOutputStream("test.txt", appendFirst); FileOutputStream f = new FileOutputStream("test.txt", appendFirst);
@ -21,6 +25,7 @@ public class FileOutput {
while ((c = in.read(buffer, offset, buffer.length - offset)) != -1) { while ((c = in.read(buffer, offset, buffer.length - offset)) != -1) {
offset += c; offset += c;
} }
in.close();
if (! "Hello world!\nHello world again!".equals if (! "Hello world!\nHello world again!".equals
(new String(buffer, 0, offset))) (new String(buffer, 0, offset)))
@ -28,11 +33,13 @@ public class FileOutput {
throw new RuntimeException(); throw new RuntimeException();
} }
} finally { } finally {
new File("test.txt").delete(); expect(new File("test.txt").delete());
} }
} }
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
expect(new File("nonexistent-file").length() == 0);
test(false); test(false);
test(true); test(true);
} }

View File

@ -227,5 +227,13 @@ public class Misc {
} }
System.out.println(new java.util.Date().toString()); System.out.println(new java.util.Date().toString());
System.out.println('x');
System.out.println(true);
System.out.println(42);
System.out.println(123456789012345L);
System.out.println(75.62);
System.out.println(75.62d);
System.out.println(new char[] { 'h', 'i' });
} }
} }

View File

@ -71,5 +71,11 @@ public class Strings {
sb.append('$'); sb.append('$');
sb.append('2'); sb.append('2');
expect(sb.substring(1).equals("2")); expect(sb.substring(1).equals("2"));
expect(Character.forDigit(Character.digit('0', 10), 10) == '0');
expect(Character.forDigit(Character.digit('9', 10), 10) == '9');
expect(Character.forDigit(Character.digit('b', 16), 16) == 'b');
expect(Character.forDigit(Character.digit('f', 16), 16) == 'f');
expect(Character.forDigit(Character.digit('z', 36), 36) == 'z');
} }
} }

View File

@ -1,6 +1,8 @@
import java.util.Comparator; import java.util.Comparator;
import java.util.TreeSet; import java.util.TreeSet;
import java.util.TreeMap; import java.util.TreeMap;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Map; import java.util.Map;
import java.util.Iterator; import java.util.Iterator;
@ -87,5 +89,13 @@ public class Tree {
map.put("y", "Y"); map.put("y", "Y");
isEqual(printMap(map), "a=A, b=B, c=C, q=Q, y=Y, z=Z"); isEqual(printMap(map), "a=A, b=B, c=C, q=Q, y=Y, z=Z");
Collection<Integer> list = new ArrayList<Integer>();
list.add(7);
list.add(2);
list.add(9);
list.add(2);
isEqual(printList(new TreeSet<Integer>(list)), "2, 7, 9");
} }
} }

View File

@ -7,7 +7,6 @@ import java.util.zip.ZipEntry;
public class Zip { public class Zip {
private static String findJar(File directory) { private static String findJar(File directory) {
File[] files = directory.listFiles();
for (File file: directory.listFiles()) { for (File file: directory.listFiles()) {
if (file.isFile()) { if (file.isFile()) {
if (file.getName().endsWith(".jar")) { if (file.getName().endsWith(".jar")) {

6
vm.pro
View File

@ -117,3 +117,9 @@
-keepclassmembers class java.lang.Object { -keepclassmembers class java.lang.Object {
protected java.lang.Object clone(); protected java.lang.Object clone();
} }
# called by name in the VM:
-keepclassmembers class java.lang.ClassLoader {
public java.lang.Class loadClass(java.lang.String);
}