X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=Makefile;h=70ef00dd1e971359e330b2df4fe85db892860618;hb=77091a0ecab02cafc3610508a59347aeadcb922e;hp=84c8b24b12deddf6cd6278456c41b7d500e833e4;hpb=6bc8259d72f08e1f25f42d495bbd993dfc9acb2d;p=org.ibex.core.git diff --git a/Makefile b/Makefile index 84c8b24..70ef00d 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,7 @@ ############################################################################# # # The XWT Makefile + # all: JVM Darwin Linux Win32 Solaris @@ -67,11 +68,13 @@ build/class/%.class: build/java/%.java .jikes mkdir -p build/class ./.jikes $< +# this forces a clean build every time because jikes is so damn buggy compile: .compile -.compile: $(all_java_sources) +.compile: $(all_java_sources) .jikes @echo -e "\n\033[1mcompiling .java -> .class: src/**/*.java\033[0m" + rm -rf build/class mkdir -p build/class - @./.jikes $^ + @./.jikes $(all_java_sources) touch .compile # PHASE 4: gcj-generated headers @@ -115,7 +118,7 @@ jpeg_sources += jquant1.c jquant2.c jerror.c jutils.c jmemnobs.c jmemmgr.c upstream/jpeg-6b/build-$(target)/libjpeg.a: .install_jpeg-6b_$(target) java_objects := $(nonplat_java_sources:build/java/%.java=build/$(platform)/%.java.o) -build/$(platform)/$(platform).ar: $(java_objects) build/$(platform)/org/xwt/plat/$(platform).cc.o build/$(platform)/org/xwt/builtin.res.o build/$(platform)/freetype.res.o $(plat_java_sources:build/java/%.java=build/$(platform)/%.java.o) +build/$(platform)/$(platform).ar: $(java_objects) build/$(platform)/org/xwt/plat/$(platform).cc.o build/$(platform)/builtin.o $(plat_java_sources:build/java/%.java=build/$(platform)/%.java.o) @echo -e "\n\033[1marchiving .o -> .a\033[0m" mkdir -p build/$(platform) upstream/install/bin/$(target)-ar rc $@ $? @@ -131,8 +134,8 @@ $(target_bin): build/$(platform)/$(platform).ar upstream/jpeg-6b/build-$(target) # Special treatment: # -builtin_src := $(find src/org/xwt/builtin) -build/res/resources.jar: $(builtin_src:src/%=build/res/%) build/res/freetype.mips +builtin_src := $(shell find src/org/xwt/builtin -name '*.*') +build/res/builtin.jar: $(builtin_src:src/%=build/res/%) build/res/freetype.mips @echo -e "\n\033[1mzipping res/* -> .jar: builtin.jar\033[0m" cd build/res; $(jar) cf builtin.jar $(^:build/res/%=%) @@ -150,11 +153,12 @@ build/$(platform)/builtin.o: build/res/builtin.jar # having the individual .o's depend on the .java's (otherwise every .o gets recompiled when one .java changes) gcj: .vendor .install_gcc-3.3_$(target) $(target_bin) -build/JVM/xwt.jar: $(java_sources:build/java/%.java=build/class/%.class) +build/JVM/xwt.jar: .compile build/res/builtin.jar @echo -e "\n\033[1marchiving .class -> .jar: build/JVM/xwt.jar\033[0m" mkdir -p build/JVM echo -e "Manifest-Version: 1.0\nMain-Class: org.xwt.Main\n" > build/JVM/.manifest - cd build/class; $(jar) cfm ../JVM/xwt.jar ../JVM/.manifest `find .`; + cd build/class/org/xwt; ln -sf ../../../res/builtin.jar + cd build/class; $(jar) cfm ../JVM/xwt.jar ../JVM/.manifest `find . \! -type d`; @@ -171,7 +175,7 @@ build/mips/%.c.o: src/%.c build/res/freetype.mips: build/mips/org/xwt/translators/Freetype.c.o build/mips/org/xwt/mips/crt0.c.o build/mips/org/xwt/mips/syscalls.c.o make .install_freetype-2.1.4_mips-unknown-elf target=mips-unknown-elf @echo -e "\n\033[1mlinking .o -> .mips: $@\033[0m" - mkdir -p build/mips + mkdir -p build/mips build/res upstream/install/bin/mips-unknown-elf-gcc \ -nostdlib \ --static \