215 lines
6.9 KiB
215 lines
6.9 KiB
#!/bin/sh |
|
# --- SDE-COPYRIGHT-NOTE-BEGIN --- |
|
# This copyright note is auto-generated by ./scripts/Create-CopyPatch. |
|
# |
|
# Filename: package/.../java-dirtree/java-conf.in |
|
# Copyright (C) 2008 The OpenSDE Project |
|
# Copyright (C) 2004 - 2006 The T2 SDE Project |
|
# |
|
# More information can be found in the files COPYING and README. |
|
# |
|
# This program is free software; you can redistribute it and/or modify |
|
# it under the terms of the GNU General Public License as published by |
|
# the Free Software Foundation; version 2 of the License. A copy of the |
|
# GNU General Public License can be found in the file COPYING. |
|
# --- SDE-COPYRIGHT-NOTE-END --- |
|
|
|
# Common java configuration is needed as well. |
|
. $base/package/*/*/java-common-conf.in |
|
|
|
# Defaults |
|
auto_detect=on |
|
build_type= |
|
|
|
# Prevent executing normal make and install build steps. |
|
# Java packages have custom make and install. |
|
makeopt= |
|
makeinstopt= |
|
|
|
# Set variables used for building java sources to there default values. |
|
# builddocdir - Location where documentation can be found after building. |
|
# buildjardir - Location where build results (jarfiles) can be found. |
|
# buildtarget - target(Ant)/goal(Maven) to be used for building. |
|
# buildfile - buildfile containing the build rules. |
|
builddocdir=dist/docs |
|
buildjardir=dist |
|
buildtarget=dist |
|
buildfile= |
|
|
|
# ------------------------------------------------------------------------- |
|
# |
|
# ------------------------------------------------------------------------- |
|
maven1_build() { |
|
echo_status "Java buildstyle: Maven (version 1)" |
|
|
|
# Maven 2 needs to be installed to be able to use it. |
|
pkgprefix -t maven1 |
|
|
|
# Invoke maven to start building. However, we strictly |
|
# forbid downloading dependancies from remote repositories. |
|
# All dependancies should be build locally and added to |
|
# the local repository. |
|
$root/$(pkgprefix bindir maven1)/maven \ |
|
-Dmaven.repo.remote.enabled=false \ |
|
$mavengoals --pom $1 |
|
} |
|
|
|
# ------------------------------------------------------------------------- |
|
# |
|
# ------------------------------------------------------------------------- |
|
maven2_build() { |
|
echo_status "Java buildstyle: Maven (version 2)" |
|
|
|
# Maven 2 needs to be installed to be able to use it. |
|
pkgprefix -t maven |
|
|
|
abort "MAVEN2 building NOT yet implemented." |
|
} |
|
|
|
# ------------------------------------------------------------------------- |
|
# ant_build: Starts the apache ant build tool. |
|
# |
|
# Besides starting the apache build tool. The results of building are |
|
# gathered and moved to right place. For this two things are considered. |
|
# dist/docs for documentation. |
|
# dist/*.jar for java jar files/libraries. |
|
# |
|
# IMPORTANT VARIABLES: |
|
# builddocdir - Location where documentation will be. |
|
# buildjardir - Location where build result will be. |
|
# buildtarget - Ant target to be used for building. |
|
# ------------------------------------------------------------------------- |
|
ant_build() { |
|
echo_status "Java buildstyle: Apache Ant" |
|
|
|
# Ant needs to be installed to be able to use it. |
|
pkgprefix -t apache-ant |
|
|
|
# Invoke Ant to start building. |
|
$root/$(pkgprefix bindir apache-ant)/ant -buildfile $1 \ |
|
-lib $(pkgprefix libdir java-dirtree) \ |
|
$antopt $buildtarget |
|
|
|
# Copy all created jar files to the package libdir. |
|
echo "Trying to copy package jar files." |
|
if ls $buildjardir/*.jar 2> /dev/null ; then |
|
cp -v $buildjardir/*.jar $root/$libdir |
|
else |
|
# Strange. No jar files available? |
|
echo "Package $pkg produces no jar files in $buildjardir/." |
|
fi |
|
|
|
# Copy all documentation to the package docdir. |
|
echo "Trying to copy package documentaion." |
|
tempdir=$builddocdir |
|
if [ -d $tempdir ] ; then |
|
( cd $tempdir; tar -c * | tar -x -C $root/$docdir ) |
|
fi |
|
unset tempdir |
|
} |
|
|
|
# ------------------------------------------------------------------------- |
|
# set_build_type: Sets the java build type. |
|
# |
|
# Sets the java build type to be used for building the current package. |
|
# ------------------------------------------------------------------------- |
|
set_build_type() { |
|
local builder_func= |
|
|
|
# Build type can only be set once per package, check if it |
|
# has already been set. |
|
if [ -n "$build_type" ] ; then |
|
echo "Buildtype already set ($build_type), can't set it to '$1'" |
|
Abort "java-conf.in: Buildtype can only be set once." |
|
fi |
|
build_type="$1" |
|
|
|
case "$build_type" in |
|
ANT) builder_func="ant_build ${buildfile:-build.xml}" ;; |
|
MAVEN) todo ;; |
|
SCRIPT) todo ;; |
|
*) abort "java-conf.in: Unknown buildtype $1 specified." ;; |
|
esac |
|
|
|
# Since the built type is set, auto detection is no longer needed. |
|
auto_detect=off |
|
|
|
# Set the inmake hook to use the given builder type. |
|
hook_add inmake 5 "$builder_func" |
|
} |
|
|
|
# Before we continue lets process all command line options. |
|
while [ "$1" ] ; do |
|
case "$1" in |
|
NO_AUTO_DETECT) auto_detect=off ; |
|
echo_status "Java buildstyle: Autodetect disabled." ;; |
|
BUILD_TYPE=*) set_build_type ${1#*=} ;; |
|
BUILD_FILE=*) buildfile=${1#*=} ;; |
|
*) abort "java-conf.in: Unknown arguments" ;; |
|
esac |
|
shift |
|
done |
|
|
|
# Check if at least one of the jdk's is available right now. |
|
if [ -z $JAVA_HOME ]; then |
|
# No jdk available, continueing is pointless. |
|
abort "At least one of the JDK's need to be installed." |
|
fi |
|
|
|
# This function determines the maven version to be used on |
|
# the given input file. |
|
# param: pom/project filename |
|
# return: the pom/project file major version number. |
|
detect_maven_version() { |
|
# Todo: look inside the file to determine the version. |
|
echo "3" |
|
} |
|
|
|
# We know how to build Ant, Maven and Maven 2 style projects. |
|
# build and build.sh scripts are ignored on purpose. By controlling |
|
# the build in here we might make it easier to build packages using |
|
# exotic compilers like gcj or jikes. |
|
determine_build_type() { |
|
local buildtype= |
|
|
|
# Check if the Ant build.xml file is available. |
|
if [ -f build.xml ]; then |
|
# Package can be build using Ant. However this might be |
|
# overruled by any of the others. |
|
buildtype="ANT" |
|
fi |
|
|
|
# Check if the Maven pom.xml or project.xml file is available. |
|
for mavenfile in pom.xml project.xml; do |
|
# Check if the maven file exists |
|
if [ -f $mavenfile ]; then |
|
# A maven file is available, but what maven |
|
# version should be used? The projectfile |
|
# version can tell us. |
|
pomversion=`detect_maven_version $mavenfile` |
|
case "$pomversion" in |
|
4*) builder_func="maven2_build $mavenfile" ;; |
|
# In all other cases we use maven 1. |
|
*) builder_func="maven1_build $mavenfile" ;; |
|
esac |
|
fi |
|
done |
|
|
|
# Check if we have found an appropriate java builder. |
|
if [ -n "$buildtype" ]; then |
|
# Set the selected build type. |
|
set_build_type $buildtype |
|
else |
|
# Auto detection of the build style resulted into |
|
# nothing. So from here on it is up to the package |
|
# to decide how to continue building the package. |
|
echo_status "Java buildstyle: Unknown buildstyle" |
|
fi |
|
} |
|
|
|
# Check if autodetection of the build process is required. |
|
if [ "$auto_detect" == "on" ] ; then |
|
# We use a postpatch hook to determine what kind of build process |
|
# is needed. When we know we set the inmake hook appropriately. |
|
hook_add postpatch 5 determine_build_type |
|
fi
|
|
|