# inputs
jikes_java_sources := $(shell find src -name *.java)
-gcj_java_sources := $(shell find src -name *.java -not -path src/org/xwt/plat/\*) src/org/xwt/plat/GCJ.java $(platform_java_sources)
+gcj_java_sources := $(shell find src -name *.java \! -path src/org/xwt/plat/\*) src/org/xwt/plat/GCJ.java $(platform_java_sources)
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
gcjh := $(gcc_path)/bin/gcjh
ar := $(gcc_path)/$(target)/bin/ar
strip := $(gcc_path)/$(target)/bin/strip
+jar := $(shell ((type fastjar &>/dev/null) && echo fastjar) || echo jar)
jikes := jikes -extdirs ${JAVA_HOME}/jre/lib -nowarn
# platforms
## Platform-Neutral ###########################################################################
ifneq ($(verbose),true)
-.SILENT: $(jikes_java_objects) .headers $(gcj_java_objects) $(all_platforms) bin/org/xwt/builtin.xwar
+.SILENT: $(jikes_java_objects) .headers $(gcj_java_objects) $(all_platforms) bin/org/xwt/builtin.xwar .bootclasspath
silent := --silent
endif
all: $(all_platforms)
-$(jikes_java_objects): $(jikes_java_sources)
- test "$(JAVA_HOME)"x != x || (echo "you forgot to set your $$JAVA_HOME environment variable"; false)
+.bootclasspath:
+ 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.*
+
+$(jikes_java_objects): $(jikes_java_sources) .bootclasspath
+ test "$(JAVA_HOME)"x != x || (echo "you forgot to set your JAVA_HOME environment variable"; false)
echo "compiling .java -> .class:"
mkdir -p bin
- $(jikes) -sourcepath src/ -classpath lib/libgcj-minimal.jar $(jikes_java_sources) -d bin/
+ $(jikes) -bootclasspath $(shell cat .bootclasspath) -sourcepath src/ -classpath lib/libgcj-minimal.jar $(jikes_java_sources) -d bin/
echo "compiling .java -> .class: done"
bin/org/xwt/builtin.xwar: $(xwar_sources)
mkdir -p bin/org/xwt
- cd src; fastjar cf ../bin/org/xwt/builtin.xwar $(xwar_sources:src/%=%)
+ cd src; $(jar) cf ../bin/org/xwt/builtin.xwar $(xwar_sources:src/%=%)
clean:
rm -rf bin-* bin
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 "
echo "archiving .class -> .jar"
mkdir -p bin-Java2
echo -e "Manifest-Version: 1.0\nMain-Class: org.xwt.Main\n" > bin/.manifest
- cd bin; fastjar cvf ../bin-Java2/xwt.jar -m .manifest \
+ cd bin; $(jar) cvf ../bin-Java2/xwt.jar -m .manifest \
org/xwt/builtin.xwar \
`find . -name \*.class | grep -v org/xwt/plat/` \
org/xwt/plat/AWT*.class org/xwt/plat/Java2*.class | tr \\012 \\015
## master.dist.xwt.org ############################################################################
current_build := $(shell cat next.build)
+this_branch := $(shell tail -c +2 CVS/Tag 2>/dev/null || echo HEAD)
dist:
# this will fail if we haven't checked-in since the comment is null; we want this.
cvs commit -m '' > /dev/null
+ cvs tag -F xwt-$(current_build)
echo "***********************************************************"
echo "* This build is $(current_build)"
tail -n 200 .make-dist.out | \
mail -s "Unsigned binaries of $(current_build) are now available" cvs@xwt.org
else
- ssh xwt@xwt.org verbose=$(verbose) /home/xwt/dist \
+ ssh xwt@xwt.org verbose=$(verbose) /home/xwt/dist $(this_branch) \
| grep -v "make...:.\(Entering\|Leaving\).directory"
endif
echo "copying xwt.linux to distribution area..."
$(strip) bin-Linux/xwt.linux -o /var/www/master.dist.xwt.org/xwt-$(current_build).linux.unsigned
+ echo "creating source tarball in distribution area..."
+ CVSROOT=/cvs cvs export -r xwt-$(current_build) xwt
+ mv xwt xwt-$(current_build)
+ tar cvzf /var/www/master.dist.xwt.org/xwt-$(current_build).tgz xwt-$(current_build)
+
echo
echo "*** DONE ******************************************"