fix rebuild when using GNU Classpath

This commit is contained in:
Joel Dice 2009-06-04 17:54:06 -06:00
parent 0857f53651
commit c14ae4d2f7

View File

@ -57,6 +57,12 @@ src = src
classpath = classpath classpath = classpath
test = test test = test
ifdef gnu
avian-classpath-build = $(build)/avian-classpath
else
avian-classpath-build = $(classpath-build)
endif
input = List input = List
build-cxx = g++ build-cxx = g++
@ -426,17 +432,20 @@ $(classpath-build)/%.class: $(classpath)/%.java
$(classpath-dep): $(classpath-sources) $(classpath-dep): $(classpath-sources)
@echo "compiling classpath classes" @echo "compiling classpath classes"
@mkdir -p $(classpath-build) @mkdir -p $(avian-classpath-build)
$(javac) -d $(classpath-build) -bootclasspath $(classpath-build) \ $(javac) -d $(avian-classpath-build) \
-bootclasspath $(avian-classpath-build) \
$(shell $(MAKE) -s --no-print-directory $(classpath-classes)) $(shell $(MAKE) -s --no-print-directory $(classpath-classes))
ifdef gnu ifdef gnu
(wd=$$(pwd); \ (wd=$$(pwd) && \
cd $(classpath-build); \ cd $(avian-classpath-build) && \
$(jar) c0f "$$($(native-path) "$${wd}/$(build)/overrides.jar")" \ $(jar) c0f "$$($(native-path) "$${wd}/$(build)/overrides.jar")" \
$(gnu-overrides); \ $(gnu-overrides))
rm -r *; \ @mkdir -p $(classpath-build)
$(jar) xf $(gnu)/share/classpath/glibj.zip; \ (wd=$$(pwd) && \
rm $(gnu-blacklist); \ cd $(classpath-build) && \
$(jar) xf $(gnu)/share/classpath/glibj.zip && \
rm $(gnu-blacklist) && \
jar xf "$$($(native-path) "$${wd}/$(build)/overrides.jar")") jar xf "$$($(native-path) "$${wd}/$(build)/overrides.jar")")
endif endif
@touch $(@) @touch $(@)
@ -497,8 +506,8 @@ $(boot-object): $(boot-source)
$(compile-object) $(compile-object)
$(build)/classpath.jar: $(classpath-dep) $(build)/classpath.jar: $(classpath-dep)
(wd=$$(pwd); \ (wd=$$(pwd) && \
cd $(classpath-build); \ cd $(classpath-build) && \
$(jar) c0f "$$($(native-path) "$${wd}/$(@)")" .) $(jar) c0f "$$($(native-path) "$${wd}/$(@)")" .)
$(binaryToMacho): $(src)/binaryToMacho.cpp $(binaryToMacho): $(src)/binaryToMacho.cpp
@ -510,8 +519,8 @@ ifeq ($(platform),darwin)
$(binaryToMacho) $(asm) $(build)/classpath.jar __TEXT __text \ $(binaryToMacho) $(asm) $(build)/classpath.jar __TEXT __text \
__binary_classpath_jar_start __binary_classpath_jar_end > $(@) __binary_classpath_jar_start __binary_classpath_jar_end > $(@)
else else
(wd=$$(pwd); \ (wd=$$(pwd) && \
cd $(build); \ cd $(build) && \
$(objcopy) -I binary classpath.jar \ $(objcopy) -I binary classpath.jar \
-O $(object-format) -B $(object-arch) "$${wd}/$(@)") -O $(object-format) -B $(object-arch) "$${wd}/$(@)")
endif endif
@ -540,10 +549,10 @@ ifeq ($(platform),darwin)
$(binaryToMacho) $(asm) $(<) __BOOT __boot \ $(binaryToMacho) $(asm) $(<) __BOOT __boot \
__binary_bootimage_bin_start __binary_bootimage_bin_end > $(@) __binary_bootimage_bin_start __binary_bootimage_bin_end > $(@)
else else
(wd=$$(pwd); \ (wd=$$(pwd) && \
cd $(native-build); \ cd $(native-build) && \
$(objcopy) --rename-section=.data=.boot -I binary bootimage.bin \ $(objcopy) --rename-section=.data=.boot -I binary bootimage.bin \
-O $(object-format) -B $(object-arch) "$${wd}/$(@).tmp"; \ -O $(object-format) -B $(object-arch) "$${wd}/$(@).tmp" && \
$(objcopy) --set-section-flags .boot=alloc,load,code "$${wd}/$(@).tmp" \ $(objcopy) --set-section-flags .boot=alloc,load,code "$${wd}/$(@).tmp" \
"$${wd}/$(@)") "$${wd}/$(@)")
endif endif