Merge branch 'master' of oss:/var/local/git/avian into powerpc

This commit is contained in:
Joel Dice 2008-07-17 17:34:52 -06:00
commit 6e3bbd3c5f
34 changed files with 995 additions and 161 deletions

View File

@ -14,6 +14,7 @@
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#include <stdlib.h> #include <stdlib.h>
#include <dirent.h>
#include "jni.h" #include "jni.h"
#include "jni-util.h" #include "jni-util.h"
@ -202,6 +203,42 @@ Java_java_io_File_exists(JNIEnv* e, jclass, jstring path)
} }
} }
extern "C" JNIEXPORT jlong JNICALL
Java_java_io_File_openDir(JNIEnv* e, jclass, jstring path)
{
const char* chars = e->GetStringUTFChars(path, 0);
if (chars) {
jlong handle = reinterpret_cast<jlong>(opendir(chars));
e->ReleaseStringUTFChars(path, chars);
return handle;
} else {
return 0;
}
}
extern "C" JNIEXPORT jstring JNICALL
Java_java_io_File_readDir(JNIEnv* e, jclass, jlong handle)
{
struct dirent * directoryEntry;
if (handle!=0) {
directoryEntry = readdir(reinterpret_cast<DIR*>(handle));
if (directoryEntry == NULL) {
return NULL;
}
return e->NewStringUTF(directoryEntry->d_name);
}
return NULL;
}
extern "C" JNIEXPORT void JNICALL
Java_java_io_File_closeDir(JNIEnv* , jclass, jlong handle)
{
if (handle!=0) {
closedir(reinterpret_cast<DIR*>(handle));
}
}
extern "C" JNIEXPORT jint JNICALL extern "C" JNIEXPORT jint JNICALL
Java_java_io_FileInputStream_open(JNIEnv* e, jclass, jstring path) Java_java_io_FileInputStream_open(JNIEnv* e, jclass, jstring path)
{ {

View File

@ -38,16 +38,18 @@ public class BufferedReader extends Reader {
} }
if (position >= limit) { if (position >= limit) {
return sb.toString(); return sb.length() == 0 ? null : sb.toString();
} }
for (int i = position; i < limit; ++i) { for (int i = position; i < limit; ++i) {
if (buffer[i] == '\n') { if (buffer[i] == '\n') {
sb.append(buffer, position, i); sb.append(buffer, position, i - position);
position = i + 1; position = i + 1;
return sb.toString(); return sb.toString();
} }
} }
sb.append(buffer, position, limit-position);
position = limit;
} }
} }

View File

@ -14,9 +14,9 @@ public class File {
private static final String FileSeparator private static final String FileSeparator
= System.getProperty("file.separator"); = System.getProperty("file.separator");
// static { // static {
// System.loadLibrary("natives"); // System.loadLibrary("natives");
// } // }
private final String path; private final String path;
@ -126,4 +126,64 @@ public class File {
return false; return false;
} }
} }
public boolean mkdirs() {
File parent = getParentFile();
if (parent != null) {
if (!parent.exists()) {
if (!parent.mkdirs()) {
return false;
}
}
}
return mkdir();
}
public String[] list() {
return list(null);
}
public String[] list(FilenameFilter filter) {
long handle = 0;
try {
handle = openDir(path);
Pair list = null;
int count = 0;
for (String s = readDir(handle); s != null; s = readDir(handle)) {
if (filter == null || filter.accept(this, s)) {
list = new Pair(s, list);
++ count;
}
}
String[] result = new String[count];
for (int i = count; i >= 0; --i) {
result[i] = list.value;
list = list.next;
}
return result;
} finally {
if (handle != 0) {
closeDir(handle);
}
}
}
private static native long openDir(String path);
private static native String readDir(long handle);
private static native long closeDir(long handle);
private static class Pair {
public final String value;
public final Pair next;
public Pair(String value, Pair next) {
this.value = value;
this.next = next;
}
}
} }

View File

@ -11,9 +11,9 @@
package java.io; package java.io;
public class FileInputStream extends InputStream { public class FileInputStream extends InputStream {
// static { // static {
// System.loadLibrary("natives"); // System.loadLibrary("natives");
// } // }
private int fd; private int fd;

View File

@ -11,9 +11,9 @@
package java.io; package java.io;
public class FileOutputStream extends OutputStream { public class FileOutputStream extends OutputStream {
// static { // static {
// System.loadLibrary("natives"); // System.loadLibrary("natives");
// } // }
private int fd; private int fd;

View File

@ -0,0 +1,17 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.io;
public interface FilenameFilter {
boolean accept(File dir, String name);
}

View File

@ -41,8 +41,7 @@ public abstract class InputStream {
int c; int c;
while ((c = read(buffer, 0, (int) (size < remaining ? size : remaining))) while ((c = read(buffer, 0, (int) (size < remaining ? size : remaining)))
>= 0 >= 0
&& remaining > 0) && remaining > 0) {
{
remaining -= c; remaining -= c;
} }
return count - remaining; return count - remaining;

View File

@ -38,11 +38,11 @@ public class PushbackReader extends Reader {
if (length > 0) { if (length > 0) {
int c = in.read(b, offset, length); int c = in.read(b, offset, length);
if (c == -1) { if (c == -1) {
if (count == 0) { if (count == 0) {
count = -1; count = -1;
} }
} else { } else {
count += c; count += c;
} }
} }

View File

@ -58,6 +58,14 @@ public final class Character implements Comparable<Character> {
} }
} }
public static int toLowerCase(int codePoint) {
if (isSupplementaryCodePoint(codePoint)) {
return codePoint;
} else {
return toLowerCase((char) codePoint);
}
}
public static char toUpperCase(char c) { public static char toUpperCase(char c) {
if (c >= 'a' && c <= 'z') { if (c >= 'a' && c <= 'z') {
return (char) ((c - 'a') + 'A'); return (char) ((c - 'a') + 'A');
@ -66,10 +74,22 @@ public final class Character implements Comparable<Character> {
} }
} }
public static int toUpperCase(int codePoint) {
if (isSupplementaryCodePoint(codePoint)) {
return codePoint;
} else {
return toUpperCase((char) codePoint);
}
}
public static boolean isDigit(char c) { public static boolean isDigit(char c) {
return c >= '0' && c <= '9'; return c >= '0' && c <= '9';
} }
public static boolean isDigit(int c) {
return c >= '0' && c <= '9';
}
public static int digit(char c, int radix) { public static int digit(char c, int radix) {
int digit = 0; int digit = 0;
if ((c >= '0') && (c <= '9')) { if ((c >= '0') && (c <= '9')) {
@ -87,6 +107,10 @@ public final class Character implements Comparable<Character> {
} }
} }
public static boolean isLetter(int c) {
return canCastToChar(c) && isLetter((char) c);
}
public static boolean isLetter(char c) { public static boolean isLetter(char c) {
return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'); return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z');
} }
@ -95,6 +119,14 @@ public final class Character implements Comparable<Character> {
return isDigit(c) || isLetter(c); return isDigit(c) || isLetter(c);
} }
public static boolean isLetterOrDigit(int c) {
return canCastToChar(c) && (isDigit((char) c) || isLetter((char) c));
}
public static boolean isLowerCase(int c) {
return canCastToChar(c) && isLowerCase((char) c);
}
public static boolean isLowerCase(char c) { public static boolean isLowerCase(char c) {
return (c >= 'a' && c <= 'z'); return (c >= 'a' && c <= 'z');
} }
@ -103,6 +135,14 @@ public final class Character implements Comparable<Character> {
return (c >= 'A' && c <= 'Z'); return (c >= 'A' && c <= 'Z');
} }
public static boolean isUpperCase(int c) {
return canCastToChar(c) && isUpperCase((char) c);
}
public static boolean isWhitespace(int c) {
return canCastToChar(c) && isWhitespace((char) c);
}
public static boolean isWhitespace(char c) { public static boolean isWhitespace(char c) {
return c == ' ' || c == '\t' || c == '\n' || c == '\r'; return c == ' ' || c == '\t' || c == '\n' || c == '\r';
} }
@ -110,4 +150,39 @@ public final class Character implements Comparable<Character> {
public static boolean isSpaceChar(char c) { public static boolean isSpaceChar(char c) {
return isWhitespace(c); return isWhitespace(c);
} }
public static boolean isHighSurrogate(char ch) {
return ch >= '\uD800' && ch <= '\uDBFF';
}
public static boolean isLowSurrogate(char ch) {
return ch >= '\uDC00' && ch <= '\uDFFF';
}
public static int toCodePoint(char high, char low) {
return (((high & 0x3FF) << 10) | (low & 0x3FF)) + 0x10000;
}
public static boolean isSupplementaryCodePoint(int codePoint) {
return codePoint >= 0x10000 && codePoint <= 0x10FFFF;
}
private static boolean canCastToChar(int codePoint) {
return (codePoint >= 0 && codePoint <= 0xFFFF);
}
public static char[] toChars(int codePoint) {
if (isSupplementaryCodePoint(codePoint)) {
int cpPrime = codePoint - 0x10000;
int high = 0xD800 | ((cpPrime >> 10) & 0x3FF);
int low = 0xDC00 | (cpPrime & 0x3FF);
return new char[] { (char) high, (char) low };
}
return new char[] { (char) codePoint };
}
public static boolean isSurrogatePair(char high, char low) {
return isHighSurrogate(high) && isLowSurrogate(low);
}
} }

View File

@ -60,16 +60,17 @@ public final class Long extends Number implements Comparable<Long> {
} }
boolean negative = v < 0; boolean negative = v < 0;
if (negative) v = -v;
int size = (negative ? 1 : 0); int size = (negative ? 1 : 0);
for (long n = v; n > 0; n /= radix) ++size; for (long n = v; n != 0; n /= radix) ++size;
char[] array = new char[size]; char[] array = new char[size];
int i = array.length - 1; int i = array.length - 1;
for (long n = v; n > 0; n /= radix) { for (long n = v; n != 0; n /= radix) {
long digit = n % radix; long digit = n % radix;
if (negative) digit = -digit;
if (digit >= 0 && digit <= 9) { if (digit >= 0 && digit <= 9) {
array[i] = (char) ('0' + digit); array[i] = (char) ('0' + digit);
} else { } else {

View File

@ -11,6 +11,7 @@
package java.lang; package java.lang;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.util.regex.Pattern;
public final class String implements Comparable<String>, CharSequence { public final class String implements Comparable<String>, CharSequence {
private Object data; private Object data;
@ -199,14 +200,8 @@ public final class String implements Comparable<String>, CharSequence {
return -1; return -1;
} }
public int lastIndexOf(int c) { public int lastIndexOf(int ch) {
for (int i = length - 1; i >= 0; --i) { return lastIndexOf(ch, length-1);
if (charAt(i) == c) {
return i;
}
}
return -1;
} }
public int indexOf(String s) { public int indexOf(String s) {
@ -303,6 +298,14 @@ public final class String implements Comparable<String>, CharSequence {
} }
} }
public boolean startsWith(String s, int start) {
if (length >= s.length + start) {
return substring(start, s.length).compareTo(s) == 0;
} else {
return false;
}
}
public boolean endsWith(String s) { public boolean endsWith(String s) {
if (length >= s.length) { if (length >= s.length) {
return substring(length - s.length).compareTo(s) == 0; return substring(length - s.length).compareTo(s) == 0;
@ -429,6 +432,10 @@ public final class String implements Comparable<String>, CharSequence {
return substring(start, end); return substring(start, end);
} }
public boolean matches(String regex) {
return Pattern.matches(regex, this);
}
public native String intern(); public native String intern();
public static String valueOf(Object s) { public static String valueOf(Object s) {
@ -466,4 +473,14 @@ public final class String implements Comparable<String>, CharSequence {
public static String valueOf(double v) { public static String valueOf(double v) {
return Double.toString(v); return Double.toString(v);
} }
public int lastIndexOf(int ch, int lastIndex) {
for (int i = lastIndex ; i >= 0; --i) {
if (charAt(i) == ch) {
return i;
}
}
return -1;
}
} }

View File

@ -70,6 +70,11 @@ public class StringBuffer implements CharSequence {
return this; return this;
} }
public synchronized StringBuffer append(char[] b) {
sb.append(b, 0, b.length);
return this;
}
public synchronized StringBuffer insert(int i, String s) { public synchronized StringBuffer insert(int i, String s) {
sb.insert(i, s); sb.insert(i, s);
return this; return this;

View File

@ -209,6 +209,29 @@ public class StringBuilder implements CharSequence {
insert(start, str); insert(start, str);
return this; return this;
} }
public int indexOf(String s) {
return indexOf(s, 0);
}
public int indexOf(String s, int start) {
int slength = s.length();
if (slength == 0) return start;
for (int i = start; i < length - slength + 1; ++i) {
int j = 0;
for (; j < slength; ++j) {
if (charAt(i + j) != s.charAt(j)) {
break;
}
}
if (j == slength) {
return i;
}
}
return -1;
}
public int length() { public int length() {
return length; return length;

View File

@ -0,0 +1,6 @@
package java.lang;
public @interface SuppressWarnings {
String[] value();
}

View File

@ -17,6 +17,7 @@ import java.io.BufferedOutputStream;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.FileDescriptor; import java.io.FileDescriptor;
import java.util.Properties;
public abstract class System { public abstract class System {
private static Property properties; private static Property properties;
@ -76,6 +77,14 @@ public abstract class System {
return null; return null;
} }
public static Properties getProperties () {
Properties prop = new Properties();
for (Property p = properties; p != null; p = p.next) {
prop.put(p.name, p.value);
}
return prop;
}
private static native String getProperty(String name, boolean[] found); private static native String getProperty(String name, boolean[] found);
private static native String getVMProperty(String name, boolean[] found); private static native String getVMProperty(String name, boolean[] found);

View File

@ -20,9 +20,11 @@ public class Thread implements Runnable {
private boolean interrupted; private boolean interrupted;
private Object sleepLock; private Object sleepLock;
private ClassLoader classLoader; private ClassLoader classLoader;
private String name;
public Thread(Runnable task) { public Thread(Runnable task, String name) {
this.task = task; this.task = task;
this.name = name;
Thread current = currentThread(); Thread current = currentThread();
@ -39,8 +41,8 @@ public class Thread implements Runnable {
classLoader = current.classLoader; classLoader = current.classLoader;
} }
public Thread(Runnable task, String name) { public Thread(Runnable task) {
this(task); this(task, "Thread["+task+"]");
} }
public synchronized void start() { public synchronized void start() {
@ -118,4 +120,9 @@ public class Thread implements Runnable {
public static native int activeCount(); public static native int activeCount();
public static native int enumerate(Thread[] array); public static native int enumerate(Thread[] array);
public String getName() {
return name;
}
} }

View File

@ -100,6 +100,10 @@ public final class URL {
super(url); super(url);
} }
public int getContentLength() {
return ResourceInputStream.getContentLength(url.getFile());
}
public InputStream getInputStream() throws IOException { public InputStream getInputStream() throws IOException {
return new ResourceInputStream(url.getFile()); return new ResourceInputStream(url.getFile());
} }
@ -116,6 +120,8 @@ public final class URL {
} }
} }
private static native int getContentLength(String path);
private static native long open(String path) throws IOException; private static native long open(String path) throws IOException;
private static native int read(long peer, int position) throws IOException; private static native int read(long peer, int position) throws IOException;

View File

@ -25,6 +25,10 @@ public abstract class URLConnection {
return getInputStream(); return getInputStream();
} }
public int getContentLength() {
return -1;
}
public InputStream getInputStream() throws IOException { public InputStream getInputStream() throws IOException {
throw new UnknownServiceException(); throw new UnknownServiceException();
} }

View File

@ -0,0 +1,25 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.security;
/**
* No real access control is implemented here.
*
* @author zsombor
*
*/
public class AccessController {
public static Object doPrivileged (PrivilegedAction action) {
return action.run();
}
}

View File

@ -0,0 +1,17 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.security;
public interface PrivilegedAction<T> {
T run();
}

View File

@ -106,4 +106,17 @@ public class Arrays {
} }
}; };
} }
public static void fill(int[] array, int value) {
for (int i=0;i<array.length;i++) {
array[i] = value;
}
}
public static void fill(char[] array, char value) {
for (int i=0;i<array.length;i++) {
array[i] = value;
}
}
} }

View File

@ -0,0 +1,179 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.util;
import java.io.Serializable;
/**
* @author zsombor
*
*/
public class BitSet implements Serializable, Cloneable {
final static int BITS_PER_LONG = 64;
final static int BITS_PER_LONG_SHIFT = 6;
final static long MASK = 0xFFFFFFFFFFFFFFFFL;
private long[] bits;
private static int longPosition(int index) {
return index >> BITS_PER_LONG_SHIFT;
}
private static long bitPosition(int index) {
return 1L << (index % BITS_PER_LONG);
}
public BitSet(int bitLength) {
if (bitLength % BITS_PER_LONG == 0) {
enlarge(longPosition(bitLength));
} else {
enlarge(longPosition(bitLength) + 1);
}
}
public BitSet() {
enlarge(1);
}
public void and(BitSet otherBits) {
int max = Math.max(bits.length, otherBits.bits.length);
for (int i = 0; i < max; i++) {
bits[i] &= otherBits.bits[i];
}
}
public void andNot(BitSet otherBits) {
int max = Math.max(bits.length, otherBits.bits.length);
enlarge(max);
for (int i = 0; i < max; i++) {
bits[i] &= ~otherBits.bits[i];
}
}
public void or(BitSet otherBits) {
int max = Math.max(bits.length, otherBits.bits.length);
enlarge(max);
for (int i = 0; i < max; i++) {
bits[i] |= otherBits.bits[i];
}
}
public void xor(BitSet otherBits) {
int max = Math.max(bits.length, otherBits.bits.length);
enlarge(max);
for (int i = 0; i < max; i++) {
bits[i] ^= otherBits.bits[i];
}
}
private void enlarge(int newSize) {
if (bits == null || bits.length <= newSize) {
long[] newBits = new long[newSize + 1];
if (bits != null) {
System.arraycopy(bits, 0, newBits, 0, bits.length);
}
bits = newBits;
}
}
public void clear(int index) {
int pos = longPosition(index);
if (pos < bits.length) {
bits[pos] &= (MASK ^ bitPosition(index));
}
}
public boolean get(int index) {
int pos = longPosition(index);
if (pos < bits.length) {
return (bits[pos] & bitPosition(index)) != 0;
}
return false;
}
public void set(int index) {
int pos = longPosition(index);
enlarge(pos);
bits[pos] |= bitPosition(index);
}
public void set(int start, int end) {
for (int i = start; i < end; i++) {
set(i);
}
}
public void clear(int start, int end) {
for (int i = start; i < end; i++) {
clear(i);
}
}
public boolean isEmpty() {
for (int i = 0; i < bits.length; i++) {
if (bits[i] != 0) {
return false;
}
}
return true;
}
public boolean intersects(BitSet otherBits) {
int max = Math.max(bits.length, otherBits.bits.length);
for (int i = 0; i < max; i++) {
if ((bits[i] & otherBits.bits[i]) != 0) {
return true;
}
}
return false;
}
public int length() {
return bits.length << BITS_PER_LONG_SHIFT;
}
public int nextSetBit(int fromIndex) {
return nextBit(fromIndex, false);
}
private int nextBit(int fromIndex, boolean bitClear) {
int pos = longPosition(fromIndex);
if (pos >= bits.length) {
return -1;
}
int current = fromIndex;
do {
long currValue = bits[pos];
if (currValue == 0) {
pos++;
current = pos << BITS_PER_LONG_SHIFT;
} else {
do {
long bitPos = bitPosition(current);
if (((currValue & bitPos) != 0) ^ bitClear) {
return current;
} else {
current++;
}
} while (current % BITS_PER_LONG != 0);
}
pos++;
} while (pos < bits.length);
return -1;
}
public int nextClearBit(int fromIndex) {
return nextBit(fromIndex, true);
}
}

View File

@ -37,6 +37,14 @@ public class Properties extends Hashtable {
return (String)get(key); return (String)get(key);
} }
public String getProperty(String key, String defaultValue) {
String value = (String) get(key);
if (value == null) {
return defaultValue;
}
return value;
}
public void setProperty(String key, String value) { public void setProperty(String key, String value) {
put(key, value); put(key, value);
} }

View File

@ -23,6 +23,14 @@ public class TreeSet<T> extends AbstractSet<T> implements Collection<T> {
size = 0; size = 0;
} }
public TreeSet() {
this(new Comparator<T>() {
public int compare(T a, T b) {
return ((Comparable) a).compareTo(b);
}
});
}
public Iterator<T> iterator() { public Iterator<T> iterator() {
return new MyIterator<T>(set.first()); return new MyIterator<T>(set.first());
} }

View File

@ -0,0 +1,106 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.util.regex;
/**
* This implementation is a skeleton, useful only for compilation. At runtime it
* is need to be replaced by a working implementation, for example one from the
* Apache Harmony project.
*
* @author zsombor
*
*/
public class Matcher {
public boolean matches() {
throw new UnsupportedOperationException();
}
public boolean requireEnd() {
throw new UnsupportedOperationException();
}
public boolean hitEnd() {
throw new UnsupportedOperationException();
}
public boolean lookingAt() {
throw new UnsupportedOperationException();
}
public Matcher reset() {
throw new UnsupportedOperationException();
}
public Matcher reset(CharSequence input) {
throw new UnsupportedOperationException();
}
public int start() {
throw new UnsupportedOperationException();
}
public int start(int group) {
throw new UnsupportedOperationException();
}
public Pattern pattern() {
throw new UnsupportedOperationException();
}
public Matcher region(int start, int end) {
throw new UnsupportedOperationException();
}
public int regionEnd() {
throw new UnsupportedOperationException();
}
public int regionStart() {
throw new UnsupportedOperationException();
}
public String replaceAll(String replacement) {
throw new UnsupportedOperationException();
}
public String replaceFirst(String replacement) {
throw new UnsupportedOperationException();
}
public int end() {
throw new UnsupportedOperationException();
}
public int end(int group) {
throw new UnsupportedOperationException();
}
public boolean find() {
throw new UnsupportedOperationException();
}
public boolean find(int start) {
throw new UnsupportedOperationException();
}
public int groupCount() {
throw new UnsupportedOperationException();
}
public String group() {
throw new UnsupportedOperationException();
}
public String group(int group) {
throw new UnsupportedOperationException();
}
}

View File

@ -0,0 +1,75 @@
/* Copyright (c) 2008, Avian Contributors
Permission to use, copy, modify, and/or distribute this software
for any purpose with or without fee is hereby granted, provided
that the above copyright notice and this permission notice appear
in all copies.
There is NO WARRANTY for this software. See license.txt for
details. */
package java.util.regex;
/**
* This implementation is a skeleton, useful only for compilation. At runtime it
* is need to be replaced by a working implementation, for example one from the
* Apache Harmony project.
*
* @author zsombor
*
*/
public class Pattern {
public static final int UNIX_LINES = 1;
public static final int CASE_INSENSITIVE = 2;
public static final int COMMENTS = 4;
public static final int MULTILINE = 8;
public static final int LITERAL = 16;
public static final int DOTALL = 32;
public static final int UNICODE_CASE = 64;
public static final int CANON_EQ = 128;
private int patternFlags;
private String pattern;
protected Pattern(String pattern, int flags) {
this.pattern = pattern;
this.patternFlags = flags;
}
public static Pattern compile(String regex) {
return new Pattern(regex, 0);
}
public static Pattern compile(String regex, int flags) {
return new Pattern(regex, flags);
}
public int flags() {
return patternFlags;
}
public Matcher matcher(CharSequence input) {
throw new UnsupportedOperationException();
}
public static boolean matches(String regex, CharSequence input) {
return Pattern.compile(regex).matcher(input).matches();
}
public String pattern() {
return pattern;
}
public static String quote(String s) {
throw new UnsupportedOperationException();
}
public String[] split(CharSequence input) {
throw new UnsupportedOperationException();
}
public String[] split(CharSequence input, int limit) {
throw new UnsupportedOperationException();
}
}

View File

@ -142,7 +142,7 @@ for darwin-i386: (objcopy is not currently supported on this platform,
so we use the binaryToMacho utility instead) so we use the binaryToMacho utility instead)
$ ../build/darwin-i386-compile-fast/binaryToMacho boot.jar \ $ ../build/darwin-i386-compile-fast/binaryToMacho boot.jar \
__binary_boot_jar_start __binary_boot_jar_size > boot-jar.o __binary_boot_jar_start __binary_boot_jar_end > boot-jar.o
Step 4: Write a driver which starts the VM and runs the desired main Step 4: Write a driver which starts the VM and runs the desired main
@ -176,40 +176,18 @@ extern "C" {
} // extern "C" } // extern "C"
#ifdef JNI_VERSION_1_6
typedef struct JDK1_1InitArgs {
jint version;
char **properties;
jint checkSource;
jint nativeStackSize;
jint javaStackSize;
jint minHeapSize;
jint maxHeapSize;
jint verifyMode;
char *classpath;
jint (JNICALL *vfprintf)(FILE *fp, const char *format, va_list args);
void (JNICALL *exit)(jint code);
void (JNICALL *abort)(void);
jint enableClassGC;
jint enableVerboseGC;
jint disableAsyncGC;
jint verbose;
jboolean debugging;
jint debugPort;
} JDK1_1InitArgs;
#endif
int int
main(int ac, const char** av) main(int ac, const char** av)
{ {
JDK1_1InitArgs vmArgs; JavaVMInitArgs vmArgs;
vmArgs.version = 0x00010001; vmArgs.version = JNI_VERSION_1_2;
JNI_GetDefaultJavaVMInitArgs(&vmArgs); vmArgs.nOptions = 1;
vmArgs.ignoreUnrecognized = JNI_TRUE;
vmArgs.classpath = const_cast<char*>("[bootJar]"); JavaVMOption options[vmArgs.nOptions];
vmArgs.options = options;
options[0].optionString = const_cast<char*>("-Djava.class.path=[bootJar]");
JavaVM* vm; JavaVM* vm;
void* env; void* env;

View File

@ -741,6 +741,26 @@ Java_java_lang_Thread_enumerate(Thread* t, jclass, jobjectArray array)
return count; return count;
} }
extern "C" JNIEXPORT jint JNICALL
Java_java_net_URL_00024ResourceInputStream_getContentLength
(Thread* t, jclass, jstring path)
{
ENTER(t, Thread::ActiveState);
if (LIKELY(path)) {
char p[stringLength(t, *path) + 1];
stringChars(t, *path, p);
System::Region* r = t->m->finder->find(p);
if (r) {
jint rSize = r->length();
r->dispose();
return rSize;
}
}
return -1;
}
extern "C" JNIEXPORT jlong JNICALL extern "C" JNIEXPORT jlong JNICALL
Java_java_net_URL_00024ResourceInputStream_open Java_java_net_URL_00024ResourceInputStream_open
(Thread* t, jclass, jstring path) (Thread* t, jclass, jstring path)

View File

@ -23,8 +23,10 @@
#undef JNIEXPORT #undef JNIEXPORT
#ifdef __MINGW32__ #ifdef __MINGW32__
# define JNIEXPORT __declspec(dllexport) # define JNIEXPORT __declspec(dllexport)
# define PATH_SEPARATOR ';'
#else #else
# define JNIEXPORT __attribute__ ((visibility("default"))) # define JNIEXPORT __attribute__ ((visibility("default")))
# define PATH_SEPARATOR ':'
#endif #endif
#if (defined __i386__) || (defined __POWERPC__) #if (defined __i386__) || (defined __POWERPC__)

View File

@ -1845,30 +1845,49 @@ IsSameObject(Thread* t, jobject a, jobject b)
} }
} }
struct JDK1_1InitArgs { struct JavaVMOption {
char* optionString;
void* extraInfo;
};
struct JavaVMInitArgs {
jint version; jint version;
const char** properties; jint nOptions;
jint checkSource; JavaVMOption* options;
jint nativeStackSize; jboolean ignoreUnrecognized;
jint javaStackSize;
jint minHeapSize;
jint maxHeapSize;
jint verifyMode;
const char* classpath;
jint (JNICALL *vfprintf)(FILE* fp, const char* format, va_list args);
void (JNICALL *exit)(jint code);
void (JNICALL *abort)(void);
jint enableClassGC;
jint enableVerboseGC;
jint disableAsyncGC;
jint verbose;
jboolean debugging;
jint debugPort;
}; };
int
parseSize(const char* s)
{
unsigned length = strlen(s);
char buffer[length + 1];
if (length == 0) {
return 0;
} else if (s[length - 1] == 'k') {
memcpy(buffer, s, length - 1);
buffer[length] = 0;
return atoi(buffer) * 1024;
} else if (s[length - 1] == 'm') {
memcpy(buffer, s, length - 1);
buffer[length] = 0;
return atoi(buffer) * 1024 * 1024;
} else {
return atoi(s);
}
}
void
append(char** p, const char* value, unsigned length, char tail)
{
if (length) {
memcpy(*p, value, length);
*p += length;
*((*p)++) = tail;
}
}
} // namespace } // namespace
namespace vm { namespace vm {
@ -2040,43 +2059,91 @@ populateJNITables(JavaVMVTable* vmTable, JNIEnvVTable* envTable)
} // namespace vm } // namespace vm
extern "C" JNIEXPORT jint JNICALL
JNI_GetDefaultJavaVMInitArgs(void* args)
{
JDK1_1InitArgs* a = static_cast<JDK1_1InitArgs*>(args);
a->maxHeapSize = 128 * 1024 * 1024;
a->classpath = ".";
a->properties = 0;
return 0;
}
#define BUILTINS_PROPERTY "avian.builtins" #define BUILTINS_PROPERTY "avian.builtins"
#define BOOTSTRAP_PROPERTY "avian.bootstrap" #define BOOTSTRAP_PROPERTY "avian.bootstrap"
#define CLASSPATH_PROPERTY "java.class.path"
#define BOOTCLASSPATH_PREPEND_OPTION "bootclasspath/p"
#define BOOTCLASSPATH_OPTION "bootclasspath"
#define BOOTCLASSPATH_APPEND_OPTION "bootclasspath/a"
extern "C" JNIEXPORT jint JNICALL
JNI_GetDefaultJavaVMInitArgs(void*)
{
return 0;
}
extern "C" JNIEXPORT jint JNICALL extern "C" JNIEXPORT jint JNICALL
JNI_CreateJavaVM(Machine** m, Thread** t, void* args) JNI_CreateJavaVM(Machine** m, Thread** t, void* args)
{ {
JDK1_1InitArgs* a = static_cast<JDK1_1InitArgs*>(args); JavaVMInitArgs* a = static_cast<JavaVMInitArgs*>(args);
unsigned heapLimit = 0;
const char* builtins = 0; const char* builtins = 0;
const char* bootLibrary = 0; const char* bootLibrary = 0;
if (a->properties) { const char* classpath = 0;
for (const char** p = a->properties; *p; ++p) { const char* bootClasspathPrepend = "";
if (strncmp(*p, BUILTINS_PROPERTY "=", const char* bootClasspath = "";
const char* bootClasspathAppend = "";
for (int i = 0; i < a->nOptions; ++i) {
if (strncmp(a->options[i].optionString, "-X", 2) == 0) {
const char* p = a->options[i].optionString + 2;
if (strncmp(p, "mx", 2) == 0) {
heapLimit = parseSize(p + 2);
} else if (strncmp(p, BOOTCLASSPATH_PREPEND_OPTION ":",
sizeof(BOOTCLASSPATH_PREPEND_OPTION)) == 0)
{
bootClasspathPrepend = p + sizeof(BOOTCLASSPATH_PREPEND_OPTION);
} else if (strncmp(p, BOOTCLASSPATH_OPTION ":",
sizeof(BOOTCLASSPATH_OPTION)) == 0)
{
bootClasspath = p + sizeof(BOOTCLASSPATH_OPTION);
} else if (strncmp(p, BOOTCLASSPATH_APPEND_OPTION ":",
sizeof(BOOTCLASSPATH_APPEND_OPTION)) == 0)
{
bootClasspathAppend = p + sizeof(BOOTCLASSPATH_APPEND_OPTION);
}
} else if (strncmp(a->options[i].optionString, "-D", 2) == 0) {
const char* p = a->options[i].optionString + 2;
if (strncmp(p, BUILTINS_PROPERTY "=",
sizeof(BUILTINS_PROPERTY)) == 0) sizeof(BUILTINS_PROPERTY)) == 0)
{ {
builtins = (*p) + sizeof(BUILTINS_PROPERTY); builtins = p + sizeof(BUILTINS_PROPERTY);
} else if (strncmp(*p, BOOTSTRAP_PROPERTY "=", } else if (strncmp(p, BOOTSTRAP_PROPERTY "=",
sizeof(BOOTSTRAP_PROPERTY)) == 0) sizeof(BOOTSTRAP_PROPERTY)) == 0)
{ {
bootLibrary = (*p) + sizeof(BOOTSTRAP_PROPERTY); bootLibrary = p + sizeof(BOOTSTRAP_PROPERTY);
} else if (strncmp(p, CLASSPATH_PROPERTY "=",
sizeof(CLASSPATH_PROPERTY)) == 0)
{
classpath = p + sizeof(CLASSPATH_PROPERTY);
} }
// todo: add properties to VM
} }
} }
if (heapLimit == 0) heapLimit = 128 * 1024 * 1024;
if (classpath == 0) classpath = ".";
unsigned bcppl = strlen(bootClasspathPrepend);
unsigned bcpl = strlen(bootClasspath);
unsigned bcpal = strlen(bootClasspathAppend);
unsigned cpl = strlen(classpath);
unsigned classpathBufferSize = bcppl + bcpl + bcpal + cpl + 4;
char classpathBuffer[classpathBufferSize];
char* classpathPointer = classpathBuffer;
append(&classpathPointer, bootClasspathPrepend, bcppl, PATH_SEPARATOR);
append(&classpathPointer, bootClasspath, bcpl, PATH_SEPARATOR);
append(&classpathPointer, bootClasspathAppend, bcpal, PATH_SEPARATOR);
append(&classpathPointer, classpath, cpl, 0);
System* s = makeSystem(); System* s = makeSystem();
Heap* h = makeHeap(s, a->maxHeapSize); Heap* h = makeHeap(s, heapLimit);
Finder* f = makeFinder(s, a->classpath, bootLibrary); Finder* f = makeFinder(s, classpathBuffer, bootLibrary);
Processor* p = makeProcessor(s, h); Processor* p = makeProcessor(s, h);
*m = new (h->allocate(sizeof(Machine))) *m = new (h->allocate(sizeof(Machine)))

View File

@ -1847,7 +1847,7 @@ Thread::init()
threadPeer(this, javaThread) = reinterpret_cast<jlong>(this); threadPeer(this, javaThread) = reinterpret_cast<jlong>(this);
} else { } else {
this->javaThread = makeThread this->javaThread = makeThread
(this, reinterpret_cast<int64_t>(this), 0, 0, 0, 0, m->loader); (this, reinterpret_cast<int64_t>(this), 0, 0, 0, 0, m->loader, 0);
} }
} }

View File

@ -20,40 +20,20 @@
# define PATH_SEPARATOR ':' # define PATH_SEPARATOR ':'
#endif #endif
#ifdef JNI_VERSION_1_6
// todo: use JavaVMInitArgs instead
typedef struct JDK1_1InitArgs {
jint version;
char **properties;
jint checkSource;
jint nativeStackSize;
jint javaStackSize;
jint minHeapSize;
jint maxHeapSize;
jint verifyMode;
char *classpath;
jint (JNICALL *vfprintf)(FILE *fp, const char *format, va_list args);
void (JNICALL *exit)(jint code);
void (JNICALL *abort)(void);
jint enableClassGC;
jint enableVerboseGC;
jint disableAsyncGC;
jint verbose;
jboolean debugging;
jint debugPort;
} JDK1_1InitArgs;
#endif
namespace { namespace {
void void
usageAndExit(const char* name) usageAndExit(const char* name)
{ {
fprintf(stderr, "usage: %s [-cp <classpath>] [-Xmx<maximum heap size>] " fprintf
"<class name> [<argument> ...]\n", name); (stderr, "usage: %s\n"
"\t[{-cp|-classpath} <classpath>]\n"
"\t[-Xmx<maximum heap size>]\n"
"\t[-Xbootclasspath/p:<classpath to prepend to bootstrap classpath>]\n"
"\t[-Xbootclasspath:<bootstrap classpath>]\n"
"\t[-Xbootclasspath/a:<classpath to append to bootstrap classpath>]\n"
"\t[-D<property name>=<property value> ...]\n"
"\t<class name> [<argument> ...]\n", name);
exit(-1); exit(-1);
} }
@ -62,22 +42,25 @@ usageAndExit(const char* name)
int int
main(int ac, const char** av) main(int ac, const char** av)
{ {
JDK1_1InitArgs vmArgs; JavaVMInitArgs vmArgs;
vmArgs.version = 0x00010001; vmArgs.version = JNI_VERSION_1_2;
JNI_GetDefaultJavaVMInitArgs(&vmArgs); vmArgs.nOptions = 1;
vmArgs.ignoreUnrecognized = JNI_TRUE;
const char* class_ = 0; const char* class_ = 0;
int argc = 0; int argc = 0;
const char** argv = 0; const char** argv = 0;
int propertyCount = 0; const char* classpath = ".";
for (int i = 1; i < ac; ++i) { for (int i = 1; i < ac; ++i) {
if (strcmp(av[i], "-cp") == 0) { if (strcmp(av[i], "-cp") == 0
vmArgs.classpath = const_cast<char*>(av[++i]); or strcmp(av[i], "-classpath") == 0)
} else if (strncmp(av[i], "-Xmx", 4) == 0) { {
vmArgs.maxHeapSize = atoi(av[i] + 4); classpath = av[++i];
} else if (strncmp(av[i], "-D", 2) == 0) { } else if (strncmp(av[i], "-X", 2) == 0
++ propertyCount; or strncmp(av[i], "-D", 2) == 0)
{
++ vmArgs.nOptions;
} else { } else {
class_ = av[i++]; class_ = av[i++];
if (i < ac) { if (i < ac) {
@ -88,35 +71,53 @@ main(int ac, const char** av)
} }
} }
#ifdef BOOT_LIBRARY
++ vmArgs.nOptions;
#endif
#ifdef BOOT_CLASSPATH #ifdef BOOT_CLASSPATH
unsigned size = sizeof(BOOT_CLASSPATH) + 1 + strlen(vmArgs.classpath); ++ vmArgs.nOptions;
char classpath[size]; #endif
snprintf(classpath, size, "%s%c%s",
BOOT_CLASSPATH, PATH_SEPARATOR, vmArgs.classpath); JavaVMOption options[vmArgs.nOptions];
vmArgs.classpath = classpath; vmArgs.options = options;
unsigned optionIndex = 0;
#ifdef BOOT_CLASSPATH
options[optionIndex++].optionString
= const_cast<char*>("-Xbootclasspath:" BOOT_CLASSPATH);
#endif #endif
#ifdef BOOT_LIBRARY #ifdef BOOT_LIBRARY
const int BootPropertyCount = 1; options[optionIndex++].optionString
#else = const_cast<char*>("-Davian.bootstrap=" BOOT_LIBRARY);
const int BootPropertyCount = 0;
#endif #endif
const char* properties[propertyCount + BootPropertyCount + 1]; #define CLASSPATH_PROPERTY "-Djava.class.path="
properties[propertyCount + BootPropertyCount] = 0;
unsigned classpathSize = strlen(classpath);
unsigned classpathPropertyBufferSize
= sizeof(CLASSPATH_PROPERTY) + classpathSize;
char classpathPropertyBuffer[classpathPropertyBufferSize];
memcpy(classpathPropertyBuffer,
CLASSPATH_PROPERTY,
sizeof(CLASSPATH_PROPERTY) - 1);
memcpy(classpathPropertyBuffer + sizeof(CLASSPATH_PROPERTY) - 1,
classpath,
classpathSize + 1);
options[optionIndex++].optionString = classpathPropertyBuffer;
for (int i = 1; i < ac; ++i) { for (int i = 1; i < ac; ++i) {
if (strncmp(av[i], "-D", 2) == 0) { if (strncmp(av[i], "-X", 2) == 0
properties[--propertyCount] = av[i] + 2; or strncmp(av[i], "-D", 2) == 0)
{
options[optionIndex++].optionString = const_cast<char*>(av[i]);
} }
} }
#ifdef BOOT_LIBRARY
properties[propertyCount + BootPropertyCount - 1]
= "avian.bootstrap=" BOOT_LIBRARY;
#endif
vmArgs.properties = const_cast<char**>(properties);
if (class_ == 0) { if (class_ == 0) {
usageAndExit(av[0]); usageAndExit(av[0]);
} }

64
test/BitsetTest.java Normal file
View File

@ -0,0 +1,64 @@
import java.util.BitSet;
public class BitsetTest {
public static void main(String[] args) {
BitSet bits = new BitSet(16);
bits.set(5);
bits.set(1);
BitSet other = new BitSet(16);
other.set(5);
assertTrue("bit 1 is set", bits.get(1));
assertTrue("bit 5 is set", bits.get(5));
assertTrue("bit 0 is not set", !bits.get(0));
assertTrue("bit 16 is not set", !bits.get(16));
bits.and(other);
assertTrue("bit 5 is set", bits.get(5));
assertTrue("bit 1 is not set", !bits.get(1));
bits.set(100);
assertTrue("bit 100 is set", bits.get(100));
assertTrue("bit 101 is not set", !bits.get(101));
other.set(101);
bits.or(other);
assertTrue("bit 101 is set", bits.get(101));
assertEquals("first bit is 5", 5, bits.nextSetBit(0));
assertEquals("first bit is 5 from 3", 5, bits.nextSetBit(4));
assertEquals("first bit is 5 from 5", 5, bits.nextSetBit(5));
assertEquals("second bit is 100", 100, bits.nextSetBit(6));
assertEquals("second bit is 100 from 100", 100, bits.nextSetBit(100));
assertEquals("third bit is 101", 101, bits.nextSetBit(101));
assertEquals("there is no 4th bit", -1, bits.nextSetBit(102));
assertEquals("first empty bit is 0", 0, bits.nextClearBit(0));
assertEquals("after 5, 6 is empty", 6, bits.nextClearBit(5));
assertEquals("after 100, 102 is empty", 102, bits.nextClearBit(100));
}
static void assertTrue(String msg, boolean flag) {
if (flag) {
System.out.println(msg + " : OK.");
} else {
throw new RuntimeException("Error:"+msg);
}
}
static void assertEquals(String msg, int expected, int actual) {
if (expected==actual) {
System.out.println(msg + " : OK. ["+actual+']');
} else {
throw new RuntimeException("Error:"+msg+" expected:"+expected+", actual:"+actual);
}
}
}

View File

@ -102,7 +102,10 @@ public class Misc {
expect(foo > 0); expect(foo > 0);
} }
expect(String.valueOf(25214903884l).equals("25214903884")); expect(String.valueOf(25214903884L).equals("25214903884"));
expect(String.valueOf(-9223372036854775808L).equals
("-9223372036854775808"));
{ boolean p = true; { boolean p = true;
int[] array = new int[] { 1, 2 }; int[] array = new int[] { 1, 2 };