mirror of
https://github.com/corda/corda.git
synced 2025-01-23 04:48:09 +00:00
Merge branch 'master' of oss:/var/local/git/avian into powerpc
This commit is contained in:
commit
6e3bbd3c5f
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
17
classpath/java/io/FilenameFilter.java
Normal file
17
classpath/java/io/FilenameFilter.java
Normal 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);
|
||||||
|
|
||||||
|
}
|
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
6
classpath/java/lang/SuppressWarnings.java
Normal file
6
classpath/java/lang/SuppressWarnings.java
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
package java.lang;
|
||||||
|
|
||||||
|
|
||||||
|
public @interface SuppressWarnings {
|
||||||
|
String[] value();
|
||||||
|
}
|
@ -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);
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
25
classpath/java/security/AccessController.java
Normal file
25
classpath/java/security/AccessController.java
Normal 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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
17
classpath/java/security/PrivilegedAction.java
Normal file
17
classpath/java/security/PrivilegedAction.java
Normal 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();
|
||||||
|
|
||||||
|
}
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
179
classpath/java/util/BitSet.java
Normal file
179
classpath/java/util/BitSet.java
Normal 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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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());
|
||||||
}
|
}
|
||||||
|
106
classpath/java/util/regex/Matcher.java
Normal file
106
classpath/java/util/regex/Matcher.java
Normal 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();
|
||||||
|
}
|
||||||
|
}
|
75
classpath/java/util/regex/Pattern.java
Normal file
75
classpath/java/util/regex/Pattern.java
Normal 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();
|
||||||
|
}
|
||||||
|
}
|
40
readme.txt
40
readme.txt
@ -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;
|
||||||
|
@ -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)
|
||||||
|
@ -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__)
|
||||||
|
145
src/jnienv.cpp
145
src/jnienv.cpp
@ -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)))
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
117
src/main.cpp
117
src/main.cpp
@ -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
64
test/BitsetTest.java
Normal 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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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 };
|
||||||
|
Loading…
Reference in New Issue
Block a user