From 94cf093f6318ccd0ef8b6e5a198f55e9165d0316 Mon Sep 17 00:00:00 2001 From: megacz Date: Fri, 30 Jan 2004 07:04:33 +0000 Subject: [PATCH] 2003/09/03 01:03:57 darcs-hash:20040130070433-2ba56-4cdaf3d6af5434390c90cc0b937c81f2c90ea98e.gz --- Makefile | 442 +++++++++++++++++++++++++++++--------------------------------- 1 file changed, 206 insertions(+), 236 deletions(-) diff --git a/Makefile b/Makefile index cd59b13..fb09e67 100644 --- a/Makefile +++ b/Makefile @@ -1,169 +1,153 @@ -# +############################################################################# +# # The XWT Makefile # -## Configurables ########################################################################### - -jpeg_headers := jpeglib.h jconfig.h jmorecfg.h jerror.h jinclude.h jpegint.h jchuff.h jdhuff.h jdct.h jmemsys.h jversion.h -jpeg_c_sources := jdapimin.c jdapistd.c jcomapi.c jcparam.c jdmaster.c jdinput.c jdmainct.c jdcoefct.c jdpostct.c jdmarker.c -jpeg_c_sources += jdhuff.c jdphuff.c jddctmgr.c jidctint.c jidctfst.c jidctflt.c jidctred.c jdsample.c jdcolor.c jdmerge.c -jpeg_c_sources += jquant1.c jquant2.c jerror.c jutils.c jmemnobs.c jmemmgr.c - -# inputs -java_pp_sources := $(shell find src -name \*.java.pp) -java_pp_postproc := $(java_pp_sources:src/%.java.pp=build/java/%.java) -java_generated_sources := $(java_pp_postproc) build/java/org/xwt/imp/Freetype.java -java_sources := $(shell find src -name \*.java) -java_headers := $(java_sources:src/%.java=build/h/%.h) $(java_generated_sources:build/java/%.java=build/h/%.h) -xwar_sources := $(shell ls src/org/xwt/builtin/*.png src/org/xwt/builtin/*.xwt src/org/xwt/builtin/*.xwf) -cc_sources := src/org/xwt/plat/$(platform).cc -c_sources := $(jpeg_c_sources:%.c=src/org/ijg/%.c) - -# freetype inputs -freetype_base_sources := ftsystem.c ftmm.c ftbbox.c ftinit.c ftdebug.c ftbase.c ftglyph.c -freetype_other_sources := smooth/smooth.c autohint/autohint.c sfnt/sfnt.c truetype/truetype.c -freetype_sources := $(freetype_base_sources:%=gcc/src/freetype-2.1.4/src/base/%) -freetype_sources += $(freetype_other_sources:%=gcc/src/freetype-2.1.4/src/%) - -# outputs -java_objects := $(filter-out build/$(platform)/org/xwt/plat/%, $(java_sources:src/%.java=build/$(platform)/%.java.o)) -java_objects += $(java_generated_sources:build/java/%.java=build/$(platform)/%.java.o) -java_objects += build/$(platform)/org/xwt/plat/GCJ.java.o -java_objects += $(platform_java_sources:%=build/$(platform)/org/xwt/plat/%.java.o) -cc_objects := $(cc_sources:src/%.cc=build/$(platform)/%.cc.o) -c_objects := $(c_sources:src/%.c=build/$(platform)/%.c.o) - -# tools -gcc_path := $(shell pwd)/gcc/install -#gcc_optimizations := -O9 -ffast-math -fomit-frame-pointer -foptimize-sibling-calls -finline-functions -#gcc_optimzations += -funroll-loops -ffunction-sections -fdata-sections +all: Linux Win32 Java2 #Solaris +.SILENT: $(cc_objects) $(java_objects) $(java_headers) all build/xwar/builtin.xwar $(target_bin) compile + + +############################################################################# +# Configurables: +# +target_bin := xwt.$(shell echo $(target) | tr A-Z a-z) +jikes_flags := -verbose -nowarn -sourcepath src/ +gcc_path := upstream/prefix gcc_optimizations := -O2 -debug := -gcc_flags := $(gcc_optimizations) $(debug) -Isrc/org/ijg +#gcc_optimizations := -O9 -ffast-math -fomit-frame-pointer -foptimize-sibling-calls -finline-functions -funroll-loops -ffunction-sections -fdata-sections +gcc_flags := $(gcc_optimizations) gcj_flags := -fCLASSPATH=src -gcj := $(gcc_path)/bin/$(target)-gcj $(gcj_flags) $(gcc_flags) +gcj := $(gcc_path)/bin/$(target)-gcj $(gcc_flags) $(gcj_flags) g++ := $(gcc_path)/bin/$(target)-g++ $(gcc_flags) gcc := $(gcc_path)/bin/$(target)-gcc $(gcc_flags) gcjh := $(gcc_path)/bin/$(target)-gcjh - as := $(gcc_path)/$(target)/bin/as ar := $(gcc_path)/$(target)/bin/ar ranlib := $(gcc_path)/$(target)/bin/ranlib strip := $(gcc_path)/$(target)/bin/strip jar := $(shell ((type fastjar &>/dev/null) && echo fastjar) || echo jar) -# path -PATH := jikes-1.18/bin:$(PATH) -## Platform-Neutral ########################################################################### +############################################################################# +# Overview: +# +# The Makefile has been divided into phases; each phase depends on the +# previous one. Subphases of the same phase (ie 1a, 1b) are not +# interdependent. You can think of the build process as proceeding +# through the phases in order, but processing subphases within a given +# phase in any order. +# -ifneq ($(verbose),true) -.SILENT: $(cc_objects) $(java_objects) $(java_headers) all build/xwar/builtin.xwar $(target_bin) compile -silent := --silent -endif -compile: .javac $(java_generated_sources) build/xwar/builtin.xwar - echo "compiling .java -> .class: [all]" - mkdir -p build - $(shell cat .javac) -classpath lib/libgcj-minimal.jar $(java_sources) $(java_generated_sources) -d build/ 2>&1 | \ +# PHASE 1a: human-written inputs +handwritten_java_sources := $(find src -name \*.java) +handwritten_java_pp_sources := $(find src -name \*.java.pp) +handwritten_mips_sources := $(find src -name \*.mips.c) +handwritten_cc_sources := src/org/xwt/plat/$(platform).cc +handwritten_c_sources := $(jpeg_c_sources:%.c=src/org/ijg/%.c) +handwritten_xwar_sources := $(shell ls src/org/xwt/builtin/*.png src/org/xwt/builtin/*.xwt src/org/xwt/builtin/*.xwf) + + +# PHASE 1b: upstream code +jpeg_c_sources := jdapimin.c jdapistd.c jcomapi.c jcparam.c jdmaster.c jdinput.c jdmainct.c jdcoefct.c jdpostct.c jdmarker.c +jpeg_c_sources += jdhuff.c jdphuff.c jddctmgr.c jidctint.c jidctfst.c jidctflt.c jidctred.c jdsample.c jdcolor.c jdmerge.c +jpeg_c_sources += jquant1.c jquant2.c jerror.c jutils.c jmemnobs.c jmemmgr.c +jpeg_sources := $(jpeg_c_sources:%.c=upstream/jpeg-6b/%.c) +$(jpeg_sources): + make -C upstream .jpeg-6b + +freetype_sources := $(patsubst %,upstream/freetype-2.1.4/base/%,ftsystem.c ftmm.c ftbbox.c ftinit.c ftdebug.c ftbase.c ftglyph.c) +freetype_sources += $(patsubst %,upstream/freetype-2.1.4/%,smooth/smooth.c autohint/autohint.c sfnt/sfnt.c truetype/truetype.c) +$(freetype_sources): upstream/.freetype-2.1.4a + make -C upstream .freetype-2.1.4 + +upstream/.jikes: + make -C upstream .jikes + +$(gcc_path)/bin/$(target)-gcj: + make -C upstream .gcc-$(target) + + +# PHASE 2: ready-to-compile java files (either symlinked to phase 1a sources or else generated from them) +java_sources := $(handwritten_java_sources:src/%.java=build/java/%.java) +java_sources += $(handwritten_java_pp_sources:src/%.java.pp=build/java/%.java) +java_sources += $(handwritten_mips_sources:src/%.mips.c=build/java/%.java) +java_sources += build/java/org/xwt/Builtin.java +build/java/%.java: src/%.java + cd `dirname $@`; \ + A=`echo $@ | sed 's_[^/]*/_../_g'`; \ + B=`dirname $$A`; \ + C=$$B/$<; \ + ln -s $$C + + +# PHASE 3: class files +class_files := $(java_sources:build/java/%.java=build/class/%.class) +class_files += build/class/org/xwt/imp/Freetype.class +build/%.class: build/java/%.java src/%.java upstream/.jikes mkdir_build + @$(shell cat upstream/.jikes) -classpath lib/libgcj-minimal.jar $< -d build/ 2>&1 | \ grep -v ^\\[read | sed s_^\\[write\ build/__ | sed s_.class\\]_.java_ | sed "s_^_compiling .java -> .class: src/_" -build/%.class: src/%.java .javac - @echo "compiling .java -> .class: $<" - @mkdir -p build - @$(shell cat .javac) -classpath lib/libgcj-minimal.jar $< -d build/ 2>&1 | \ - grep -v ^\\[read | sed s_^\\[write\ build/__ | sed s_.class\\]_.java_ | sed "s_^_compiling .java -> .class: src/_" -$(java_pp_postproc): build/java/%.java: src/%.java.pp build/org/xwt/util/Preprocessor.class - @echo "preprocessing .java.pp -> .java: $<" +# PHASE 4: gcj-generated headers +java_headers := $(build_java_sources:build/java/%.java=build/h/%.h) +$(java_headers): build/h/%.h: build/%.class + @echo "extracting .class -> .h: $<" + cd build; find `echo $< | sed s/.class$$// | sed s_^build/__ `*.class |\ + sed s_/_._g | sed s/.class$$// | sed s/.java$$// |\ + xargs $(gcjh) --classpath . + +# PHASE 4: object files +java_object_files := $(filter-out build/$(platform)/org/xwt/plat/%, $(java_sources:src/%.java=build/$(platform)/%.java.o)) +java_object_files += $(pathsubst %,build/$(platform)/org/xwt/plat/%.java.o,GCJ $(platform_java_sources)) +java_object_files += build/$(platform)/org/xwt/imp/Freetype.java.o +cc_object_files := $(handwritten_cc_sources:src/%.cc=build/$(platform)/%.cc.o) +c_object_files := $(handwritten_c_sources:src/%.c=build/$(platform)/%.c.o) +$(java_objects): build/$(platform)/%.java.o: src/%.java + @echo "compiling .java -> .o: $<" + mkdir -p `dirname $@` + $(gcj) -c $< -o $@ +$(cc_object_files): build/$(platform)/%.cc.o: src/%.cc $(java_headers) src/org/ijg/jmorecfg.h + @echo "compiling .cc -> .o: $<" @mkdir -p `dirname $@` - @java -cp build org.xwt.util.Preprocessor < $< > $@ + $(g++) -I/usr/X11R6/include/ -I$(gcc_path)/include -Ibuild/h -Iupstream/$(platform)/include -Wno-multichar -c $< -o $@ +$(c_object_files): build/$(platform)/%.c.o: src/%.c src/org/ijg/jmorecfg.h + @echo "compiling .c -> .o: $<" + @mkdir -p `dirname $@` + $(gcc) -Ibuild/h -c $< -o $@ -# platforms -all: Win32 Linux Java2 #Solaris - -.javac: - @if \ - type jikes && (jikes --version | grep "Version 1.18"); \ - then \ - echo "public class GetBootClassPath { public static void main(String[] s) { " > GetBootClassPath.java; \ - echo "System.out.println(System.getProperty(\"sun.boot.class.path\")); } }" >> GetBootClassPath.java; \ - javac GetBootClassPath.java; \ - java -cp . GetBootClassPath > .bootclasspath; \ - rm GetBootClassPath.*; \ - echo -n "jikes -verbose -nowarn -sourcepath src/ -bootclasspath " > .javac; \ - cat .bootclasspath >> .javac; \ - else \ - echo "WARNING: You do not have jikes; falling back to javac. Compiles will be very slow."; \ - echo javac > .javac; \ - fi - -jikes: - curl ftp://www-126.ibm.com/pub/jikes/1.18/jikes-1.18.tar.bz2 | tar xjvf - - cd jikes-1.18; ./configure --prefix=`pwd` && make && make install - ln -sf jikes-1.18/bin/jikes .jikes - -build/xwar/builtin.xwar: $(xwar_sources) - mkdir -p build/xwar - cd src; $(jar) cf ../build/xwar/builtin.xwar $(xwar_sources:src/%=%) +# PHASE 5: linking +$(target_bin): $(objects) + @echo "linking .o -> $(target_bin)" + $(gcj) --main=org.xwt.Main -o build/$(platform)/$(target_bin) $^ $(platform_link) -clean: - rm -rf build - find . -name \*~ | xargs rm -f - find . -name \#\*\# | xargs rm -f -update-build: - cvs tag -F xwt-$(current_build) - (echo -n 0000; (echo "10k16o16i"; cat next.build | tr a-z A-Z; echo "1+f") | dc) | tail --bytes=5 > next.build- - mv next.build- next.build - echo -n "Next build will be " - cat next.build - cvs update CHANGES - echo "" >> CHANGES - echo `date +%d-%b`" =========== build $(current_build) ================================================" >> CHANGES - echo committing... - cvs commit -m 'this comment should not appear in CHANGES' next.build CHANGES - echo committed. - -propose-patch: - @echo -n "Please type a one-line description of this bug: "; \ - read A; \ - echo; \ - echo "Please type any additional comments that explain this patch."; \ - echo "If this patch fixes a bug, include a link to bugs.xwt.org."; \ - echo "When you are done, press control-d on a new line."; \ - echo; \ - ( echo -e "HELO patcher"; \ - echo -e "MAIL FROM:$(USER)@xwt.org"; \ - echo -e "RCPT TO: patches@xwt.org"; \ - echo -e "DATA"; \ - echo -e "From: $(USER)@xwt.org"; \ - echo -e "To: patches@xwt.org"; \ - echo -e "Subject: proposed patch to $(this_branch): $$A"; \ - echo -e ""; \ - cat; \ - echo; \ - cvs diff -Bud; \ - echo .; \ - ) > .message - bash -c "cat .message > /dev/tcp/mail.xwt.org/25" # /dev/tcp is faked by bash; not part of the os +############################################################################## +# Special treatment: +# -## GCJ-Derived Platforms ####################################################################### +build/java/org/xwt/Builtin.java: $(handwritten_xwar_sources) mkdir_build + @echo "wrapping .xwar -> .o: build/java/org/xwt/Builtin.java" + echo "package org.xwt;" > build/java/org/xwt/Builtin.java + echo "class Builtin {" >> build/java/org/xwt/Builtin.java + echo "public static String encoded = " >> build/java/org/xwt/Builtin.java + cd src; $(jar) cf - $(xwar_sources:src/%=%) | uuencode foo | tail -n +2 | grep -v '^end$$' | grep -v '^`$$' | sed 's_(.+)_"\1" +_' >> ../build/java/org/xwt/Builtin.java + echo "\"\"; } >> build/java/org/xwt/Builtin.java -# if the user doesn't change gcc_path, and it's not built, then we'll try to build it -$(shell pwd)/gcc/install/bin/$(target)-gcj: .upstream - make -C gcc +postprocessed_sources := $(handwritten_java_pp_sources:src/%.pp=build/java/%) +$(postprocessed_sources): build/java/%.java: src/%.java.pp build/org/xwt/util/Preprocessor.class + @echo "preprocessing .java.pp -> .java: $<" + @mkdir -p `dirname $@` + @java -cp build org.xwt.util.Preprocessor < $< > $@ -gcc/src/.freetype: - mkdir -p gcc/src - curl http://umn.dl.sourceforge.net/sourceforge/freetype/freetype-2.1.4.tar.gz | tar xvzf - -C gcc/src - cd gcc/src; patch -p0 < freetype.patch - touch gcc/src/.freetype +build/java/org/xwt/imp/Freetype.java: build/mips/freetype.mips build/class/org/xwt/imp/MIPS.class + @echo "translating .mips -> .java: $<" + @mkdir -p build/java/org/xwt/imp/ + @java -cp build org.xwt.imp.MIPS org.xwt.imp.Freetype build/mips/freetype.mips > build/java/org/xwt/imp/Freetype.java -build/mips/freetype.mips: gcc/src/.freetype - mkdir -p build/mips - make -C gcc mips target=mips +build/mips/freetype.mips: upstream/.freetype + make -C upstream .gcc-mips target=mips $(gcc_path)/bin/mips-gcc \ --static \ -mabi=32 \ @@ -174,114 +158,30 @@ build/mips/freetype.mips: gcc/src/.freetype $(freetype_sources) \ -Wl,--warn-once \ src/org/xwt/imp/Freetype.c \ - $(gcc_path)/mips/lib/libm.a \ -Wl,-s,-T,$(gcc_path)/mips/lib/nullmon.ld -build/java/org/xwt/imp/Freetype.java: build/mips/freetype.mips build/org/xwt/imp/MIPS.class - @echo "translating .mips -> .java: $<" - @mkdir -p build/java/org/xwt/imp/ - @java -cp build org.xwt.imp.MIPS org.xwt.imp.Freetype build/mips/freetype.mips > build/java/org/xwt/imp/Freetype.java + + +############################################################################## +# Supported Platforms: +# # compile is here to force compilation of the .class files (they get used via -Ibuild) without # having the individual .o's depend on the .java's (otherwise every .o gets recompiled when one .java changes) gcj: $(gcc_path)/bin/$(target)-gcj compile $(target_bin) - -$(target_bin): $(java_objects) $(cc_objects) $(c_objects) build/$(platform)/org/xwt/builtin.o - @echo "linking .o -> $(target_bin)" - $(gcj) --main=org.xwt.Main -o build/$(platform)/$(target_bin) $^ $(platform_link) - -build/$(platform)/org/xwt/builtin.o: build/xwar/builtin.xwar - @echo "wrapping .xwar -> .o: build/$(platform)/org/xwt/builtin.o" - @(echo "unsigned int builtin_xwar_length = ";\ - (wc -c build/xwar/builtin.xwar | sed "s_build.*__");\ - echo \;;\ - echo "unsigned char builtin_xwar[] = {";\ - hexdump -ve '"0x" 1/1 "%x,\n"' build/xwar/builtin.xwar;\ - echo "};") > .builtin.c - $(gcc) -c .builtin.c -o build/$(platform)/org/xwt/builtin.o - -$(java_headers): build/h/%.h: build/%.class - @echo "extracting .class -> .h: $<" - cd build; find `echo $< | sed s/.class$$// | sed s_^build/__ `*.class |\ - sed s_/_._g | sed s/.class$$// | sed s/.java$$// |\ - xargs $(gcjh) --classpath . - -$(java_objects): build/$(platform)/%.java.o: src/%.java - @echo "compiling .java -> .o: $<" - mkdir -p `dirname $@` - $(gcj) -c $< -o $@ - -# unpack and patch the ijg library -src/org/ijg/jmorecfg.h: src/org/ijg/jpegsrc.v6b.tar.gz src/org/ijg/jmorecfg.h.patch - cd src/org/ijg/; tar xzf jpegsrc.v6b.tar.gz - cd src/org/ijg/jpeg-6b; ./configure --target=$(target) - cd src/org/ijg/jpeg-6b; mv $(jpeg_c_sources) $(jpeg_headers) .. - cd src/org/ijg; patch -l -p0 < jmorecfg.h.patch - rm -rf src/org/ijg/jpeg-6b - -$(cc_objects): build/$(platform)/%.cc.o: src/%.cc $(java_headers) src/org/ijg/jmorecfg.h - @echo "compiling .cc -> .o: $<" - @mkdir -p `dirname $@` - $(g++) -I/usr/X11R6/include/ -I$(gcc_path)/include -Ibuild/h -Iupstream/$(platform)/include -Wno-multichar -c $< -o $@ - -$(c_objects): build/$(platform)/%.c.o: src/%.c src/org/ijg/jmorecfg.h - @echo "compiling .c -> .o: $<" - @mkdir -p `dirname $@` - $(gcc) -Ibuild/h -c $< -o $@ - -.upstream: - mkdir -p gcc/install; curl http://www.megacz.com/upstream.tgz | tar xvzhf - -C gcc/install - touch .upstream - - -## Platforms ############################################################################## + echo -e "\\n=== $(target) =========================================" Linux: - echo -e "\\n=== Linux =========================================" - make gcj \ - platform=Linux \ - target=i686-pc-linux-gnu \ - target_bin=xwt.linux \ - platform_link="-L$(gcc_path)/lib -L/usr/X11R6/lib -lX11 -lXext --static" \ - platform_java_sources="POSIX X11" + make gcj platform=Linux target=i686-pc-linux-gnu platform_link="-L$(gcc_path)/lib -L/usr/X11R6/lib -lX11 -lXext --static" platform_java_sources="POSIX X11" Solaris: - echo -e "\\n=== Solaris =========================================" - make gcj \ - platform=Solaris \ - target=sparc-sun-solaris2.7 \ - target_bin=xwt.solaris \ - platform_link="-L$(gcc_path)/lib -lX11 -lXext" \ - platform_java_sources="POSIX X11" + make gcj platform=Solaris target=sparc-sun-solaris2.7 platform_link="-L$(gcc_path)/lib -lX11 -lXext" platform_java_sources="POSIX X11" Win32: - echo -e "\\n=== Win32 =========================================" - make gcj \ - platform=Win32 \ - target=i686-pc-mingw32 \ - target_bin=xwt.exe \ - platform_link="-Wl,--subsystem,windows -lcomdlg32" \ - platform_java_sources="Win32" - -Darwin: - echo -e "\\n=== Darwin =========================================" - ranlib upstream/Darwin/lib/*.a - ar x /usr/lib/libcc_dynamic.a upstream/Darwin/lib/darwin-fpsave.o - make gcj \ - platform=Darwin \ - target=powerpc-apple-darwin \ - target_bin=xwt.darwin \ - platform_link="upstream/Darwin/lib/*.[oa] $(gcc_path)/lib/libgcj.a" \ - platform_java_sources="POSIX X11" + make gcj platform=Win32 target=i686-pc-mingw32 target_bin=xwt.exe platform_link="-Wl,--subsystem,windows -lcomdlg32" platform_java_sources=Win32 Carbon: - echo -e "\\n=== Carbon =========================================" - make gcj \ - platform=Carbon \ - target=powerpc-apple-darwin \ - target_bin=xwt.carbon \ - platform_link="$(gcc_path)/lib/libgcj.a -Xlinker -framework -Xlinker Carbon" \ - platform_java_sources="POSIX Carbon" + make gcj platform=Carbon arget=powerpc-apple-darwin platform_link="$(gcc_path)/lib/libgcj.a -Xlinker -framework -Xlinker Carbon" platform_java_sources="POSIX Carbon" JVM: compile build/xwar/builtin.xwar echo -e "\\n=== JVM =========================================" @@ -294,12 +194,59 @@ JVM: compile build/xwar/builtin.xwar org/xwt/plat/AWT*.class org/xwt/plat/Java2*.class | tr \\012 \\015 echo -PalmOS: - echo "PalmOS is not yet supported" - false -## master.dist.xwt.org ############################################################################ +############################################################################## +# Misc +# + +mkdirs: + mkdir -p build build/java build/class build/h build +clean: + find . -name \*~ | xargs rm -f + find . -name \#\*\# | xargs rm -f + + + +############################################################################## +# Maintainer stuff: generating numbered builds, proposing patches +# + +update-build: + cvs tag -F xwt-$(current_build) + (echo -n 0000; (echo "10k16o16i"; cat next.build | tr a-z A-Z; echo "1+f") | dc) | tail --bytes=5 > next.build- + mv next.build- next.build + echo -n "Next build will be " + cat next.build + cvs update CHANGES + echo "" >> CHANGES + echo `date +%d-%b`" =========== build $(current_build) ================================================" >> CHANGES + echo committing... + cvs commit -m 'this comment should not appear in CHANGES' next.build CHANGES + echo committed. + +propose-patch: + @echo -n "Please type a one-line description of this bug: "; \ + read A; \ + echo; \ + echo "Please type any additional comments that explain this patch."; \ + echo "If this patch fixes a bug, include a link to bugs.xwt.org."; \ + echo "When you are done, press control-d on a new line."; \ + echo; \ + ( echo -e "HELO patcher"; \ + echo -e "MAIL FROM:$(USER)@xwt.org"; \ + echo -e "RCPT TO: patches@xwt.org"; \ + echo -e "DATA"; \ + echo -e "From: $(USER)@xwt.org"; \ + echo -e "To: patches@xwt.org"; \ + echo -e "Subject: proposed patch to $(this_branch): $$A"; \ + echo -e ""; \ + cat; \ + echo; \ + cvs diff -Bud; \ + echo .; \ + ) > .message + bash -c "cat .message > /dev/tcp/mail.xwt.org/25" # /dev/tcp is faked by bash; not part of the os current_build := $(shell cat next.build) this_branch := $(shell tail -c +2 CVS/Tag 2>/dev/null || echo HEAD) @@ -324,7 +271,6 @@ dist: compile echo -e 'export JAVA_HOME=/usr/lib/j2sdk1.4\n cd /home/xwt\n date=`date +%d-%b-%H%M`\n mkdir xwt-$$date\n cd xwt-$$date\n /usr/bin/cvs -d /cvs co $(this_branch_flag) xwt\n mv xwt/* .\n mv xwt/.* .\n rmdir xwt\n touch .make-dist.out\n nohup make dist &> /dev/null &\n echo\n cat .make-dist.out' | ssh xwt@xwt.org | grep -v "make...:.\(Entering\|Leaving\).directory" endif - dist-private: make $(silent) update-build @@ -357,3 +303,27 @@ dist-private: echo echo "*** DONE ******************************************" + + +compile: .javac $(java_sources) build/xwar/builtin.xwar build/org/xwt/imp/Freetype.class + echo "compiling .java -> .class: src/**/*.java" + mkdir -p build + cp build/org/xwt/imp/MIPS.class build/org/xwt/imp/MIPS.class.old + $(shell cat .javac) -classpath lib/libgcj-minimal.jar $(java_sources) -d build/ 2>&1 | \ + grep -v ^\\[read | sed s_^\\[write\ build/__ | sed s_.class\\]_.java_ | sed "s_^_compiling .java -> .class: src/_" + cmp build/org/xwt/imp/MIPS.class build/org/xwt/imp/MIPS.class.old && mv build/org/xwt/imp/MIPS.class.old build/org/xwt/imp/MIPS.class + + + + + +#mips: $(prefix)/mips/lib/libm.a +#$(prefix)/mips/lib/libm.a: src/.newlib $(prefix)/bin/mips-gcc +# mkdir -p build/$(target)/newlib +# cd build/$(target)/newlib; PATH=$(prefix)/bin:$$PATH \ +# ../../../src/newlib-1.11.0/configure --nfp --enable-multilib --prefix=$(prefix) --target=mips +# cd build/$(target)/newlib; PATH=$(prefix)/bin:$$PATH EXTRA_CFLAGS=-mstrict-align make +# cd build/$(target)/newlib; make install +# FIXME: this is probably going to cause problems... figure out how to get by without it +# touch .empty.c +# $(prefix)/bin/mips-gcc -c .empty.c -o $(prefix)/mips/lib/crt0.o -- 1.7.10.4