add build option for using GNU Classpath

This commit is contained in:
Joel Dice 2009-06-02 18:55:49 -06:00
parent ba5105c374
commit 0f6dbe35a7
2 changed files with 131 additions and 10 deletions

View File

@ -43,6 +43,10 @@ endif
ifeq ($(continuations),true) ifeq ($(continuations),true)
options := $(options)-continuations options := $(options)-continuations
endif endif
ifdef gnu
options := $(options)-gnu
gnu-sources = $(src)/gnu.cpp
endif
root = $(shell (cd .. && pwd)) root = $(shell (cd .. && pwd))
build = build build = build
@ -232,7 +236,8 @@ vm-sources = \
$(src)/$(process).cpp \ $(src)/$(process).cpp \
$(src)/builtin.cpp \ $(src)/builtin.cpp \
$(src)/jnienv.cpp \ $(src)/jnienv.cpp \
$(src)/process.cpp $(src)/process.cpp \
$(gnu-sources)
vm-asm-sources = $(src)/$(asm).S vm-asm-sources = $(src)/$(asm).S
@ -314,16 +319,38 @@ classpath-sources = $(shell find $(classpath) -name '*.java')
classpath-classes = \ classpath-classes = \
$(call java-classes,$(classpath-sources),$(classpath),$(classpath-build)) $(call java-classes,$(classpath-sources),$(classpath),$(classpath-build))
classpath-object = $(native-build)/classpath-jar.o classpath-object = $(native-build)/classpath-jar.o
classpath-dep = $(classpath-build)/dep classpath-dep = $(classpath-build).dep
gnu-blacklist = \
java/lang/AbstractStringBuffer.class \
java/lang/reflect/Proxy.class
gnu-overrides = \
java/lang/Class.class \
java/lang/Enum.class \
java/lang/Object.class \
java/lang/StackTraceElement.class \
java/lang/String.class \
java/lang/StringBuffer.class \
java/lang/StringBuilder.class \
java/lang/Throwable.class \
java/lang/ref/PhantomReference.class \
java/lang/ref/Reference.class \
java/lang/ref/ReferenceQueue.class \
java/lang/ref/WeakReference.class \
java/lang/reflect/AccessibleObject.class \
java/lang/reflect/Constructor.class \
java/lang/reflect/Field.class \
java/lang/reflect/Method.class
test-sources = $(wildcard $(test)/*.java) test-sources = $(wildcard $(test)/*.java)
test-classes = $(call java-classes,$(test-sources),$(test),$(test-build)) test-classes = $(call java-classes,$(test-sources),$(test),$(test-build))
test-dep = $(test-build)/dep test-dep = $(test-build).dep
test-extra-sources = $(wildcard $(test)/extra/*.java) test-extra-sources = $(wildcard $(test)/extra/*.java)
test-extra-classes = \ test-extra-classes = \
$(call java-classes,$(test-extra-sources),$(test),$(test-build)) $(call java-classes,$(test-extra-sources),$(test),$(test-build))
test-extra-dep = $(test-build)/extra/dep test-extra-dep = $(test-build)-extra.dep
class-name = $(patsubst $(1)/%.class,%,$(2)) class-name = $(patsubst $(1)/%.class,%,$(2))
class-names = $(foreach x,$(2),$(call class-name,$(1),$(x))) class-names = $(foreach x,$(2),$(call class-name,$(1),$(x)))
@ -395,8 +422,8 @@ $(classpath-build)/%.class: $(classpath)/%.java
$(classpath-dep): $(classpath-sources) $(classpath-dep): $(classpath-sources)
@echo "compiling classpath classes" @echo "compiling classpath classes"
@mkdir -p $(dir $(@)) @mkdir -p $(classpath-build)
$(javac) -d $(dir $(@)) -bootclasspath $(classpath-build) \ $(javac) -d $(classpath-build) -bootclasspath $(classpath-build) \
$(shell $(MAKE) -s --no-print-directory $(classpath-classes)) $(shell $(MAKE) -s --no-print-directory $(classpath-classes))
@touch $(@) @touch $(@)
@ -405,8 +432,8 @@ $(test-build)/%.class: $(test)/%.java
$(test-dep): $(test-sources) $(test-dep): $(test-sources)
@echo "compiling test classes" @echo "compiling test classes"
@mkdir -p $(dir $(@)) @mkdir -p $(test-build)
$(javac) -d $(dir $(@)) -bootclasspath $(classpath-build) \ $(javac) -d $(test-build) -bootclasspath $(classpath-build) \
$(shell $(MAKE) -s --no-print-directory $(test-classes)) $(shell $(MAKE) -s --no-print-directory $(test-classes))
$(javac) -source 1.2 -target 1.1 -XDjsrlimit=0 -d $(dir $(@)) \ $(javac) -source 1.2 -target 1.1 -XDjsrlimit=0 -d $(dir $(@)) \
test/Subroutine.java test/Subroutine.java
@ -414,7 +441,7 @@ $(test-dep): $(test-sources)
$(test-extra-dep): $(test-extra-sources) $(test-extra-dep): $(test-extra-sources)
@echo "compiling extra test classes" @echo "compiling extra test classes"
@mkdir -p $(dir $(@)) @mkdir -p $(test-build)
$(javac) -d $(test-build) -bootclasspath $(classpath-build) \ $(javac) -d $(test-build) -bootclasspath $(classpath-build) \
$(shell $(MAKE) -s --no-print-directory $(test-extra-classes)) $(shell $(MAKE) -s --no-print-directory $(test-extra-classes))
@touch $(@) @touch $(@)
@ -456,9 +483,21 @@ $(boot-object): $(boot-source)
$(compile-object) $(compile-object)
$(build)/classpath.jar: $(classpath-dep) $(build)/classpath.jar: $(classpath-dep)
ifdef gnu
mkdir $(build)/gnu
(wd=$$(pwd); \
cd $(build)/gnu; \
$(jar) xf $(gnu)/share/classpath/glibj.zip; \
rm $(gnu-blacklist); \
$(jar) c0f "$$($(native-path) "$${wd}/$(@)")" .)
(wd=$$(pwd); \ (wd=$$(pwd); \
cd $(classpath-build); \ cd $(classpath-build); \
$(jar) c0f "$$($(native-path) "$${wd}/$(@)")" $$(find . -name '*.class')) $(jar) u0f "$$($(native-path) "$${wd}/$(@)")" $(gnu-overrides))
else
(wd=$$(pwd); \
cd $(classpath-build); \
$(jar) c0f "$$($(native-path) "$${wd}/$(@)")" .)
endif
$(binaryToMacho): $(src)/binaryToMacho.cpp $(binaryToMacho): $(src)/binaryToMacho.cpp
$(cxx) $(^) -o $(@) $(cxx) $(^) -o $(@)

82
src/gnu.cpp Normal file
View File

@ -0,0 +1,82 @@
/* Copyright (c) 2009, 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. */
#include "machine.h"
#include "constants.h"
#include "processor.h"
using namespace vm;
namespace {
void
setProperty(Thread* t, object method, object properties,
const char* name, const void* value, const char* format = "%s")
{
PROTECT(t, method);
PROTECT(t, properties);
object n = makeString(t, "%s", name);
PROTECT(t, n);
object v = makeString(t, format, value);
t->m->processor->invoke(t, method, properties, n, v);
}
} // namespace
extern "C" JNIEXPORT void JNICALL
Avian_gnu_classpath_VMSystemProperties_preInit
(Thread* t, object, uintptr_t* arguments)
{
object properties = reinterpret_cast<object>(arguments[0]);
PROTECT(t, properties);
object method = resolveMethod
(t, "java/util/Properties", "setProperty",
"(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/Object;");
if (UNLIKELY(t->exception)) {
return;
}
PROTECT(t, method);
setProperty(t, method, properties, "java.vm.name", "Avian");
setProperty(t, method, properties, "java.lang.classpath",
t->m->finder->path());
setProperty(t, method, properties, "file.encoding", "ASCII");
#ifdef WIN32
setProperty(t, method, properties, "line.separator", "\r\n");
setProperty(t, method, properties, "file.separator", "\\");
setProperty(t, method, properties, "os.name", "Windows");
TCHAR buffer[MAX_PATH];
GetTempPath(MAX_PATH, buffer);
setProperty(t, method, properties, "java.io.tmpdir", buffer);
LPWSTR home = _wgetenv(L"USERPROFILE");
setProperty(t, method, properties, "user.home", home, "%ls");
#else
setProperty(t, method, properties, "line.separator", "\n");
setProperty(t, method, properties, "file.separator", "/");
# ifdef __APPLE__
setProperty(t, method, properties, "os.name", "Mac OS X");
# else
setProperty(t, method, properties, "os.name", "Linux");
# endif
setProperty(t, method, properties, "java.io.tmpdir", "/tmp");
setProperty(t, method, properties, "user.home", getenv("HOME"));
#endif
}