diff options
author | James Le Cuirot <chewi@gentoo.org> | 2016-07-31 23:16:54 +0100 |
---|---|---|
committer | James Le Cuirot <chewi@gentoo.org> | 2016-08-02 23:34:24 +0100 |
commit | 436dd062c36057b2312c205928fd439b1c5b6e79 (patch) | |
tree | 6cf3987b5e818f8cf8327ad67b7a1688d6a93b58 /eclass/java-vm-2.eclass | |
parent | java-vm-2.eclass: Allow java-vm_revdep-mask to be called repeatedly (diff) | |
download | gentoo-436dd062c36057b2312c205928fd439b1c5b6e79.tar.gz gentoo-436dd062c36057b2312c205928fd439b1c5b6e79.tar.bz2 gentoo-436dd062c36057b2312c205928fd439b1c5b6e79.zip |
java-vm-2.eclass: Add java-vm_install-env to replace set_java_env
set_java_env is now deprecated. The new function is better because any
variable in the environment file can be resolved and it even allows
subshells for more dynamic content.
Diffstat (limited to 'eclass/java-vm-2.eclass')
-rw-r--r-- | eclass/java-vm-2.eclass | 49 |
1 files changed, 45 insertions, 4 deletions
diff --git a/eclass/java-vm-2.eclass b/eclass/java-vm-2.eclass index 8bfb1bb2e2d2..e2d77ad23908 100644 --- a/eclass/java-vm-2.eclass +++ b/eclass/java-vm-2.eclass @@ -161,14 +161,14 @@ get_system_arch() { # @FUNCTION: set_java_env # @DESCRIPTION: # Installs a vm env file. +# DEPRECATED, use java-vm_install-env instead. -# TODO rename to something more evident, like install_env_file set_java_env() { debug-print-function ${FUNCNAME} $* local platform="$(get_system_arch)" local env_file="${ED}${JAVA_VM_CONFIG_DIR}/${VMHANDLE}" - local old_env_file="${ED}/etc/env.d/java/20${P}" + if [[ ${1} ]]; then local source_env_file="${1}" else @@ -206,8 +206,49 @@ set_java_env() { # Make the symlink dodir "${JAVA_VM_DIR}" - dosym ${java_home#${EPREFIX}} ${JAVA_VM_DIR}/${VMHANDLE} \ - || die "Failed to make VM symlink at ${JAVA_VM_DIR}/${VMHANDLE}" + dosym ${java_home#${EPREFIX}} ${JAVA_VM_DIR}/${VMHANDLE} +} + + +# @FUNCTION: java-vm_install-env +# @DESCRIPTION: +# +# Installs a Java VM environment file. The source can be specified but +# defaults to ${FILESDIR}/${VMHANDLE}.env.sh. +# +# Environment variables within this file will be resolved. You should +# escape the $ when referring to variables that should be resolved later +# such as ${JAVA_HOME}. Subshells may be used but avoid using double +# quotes. See icedtea-bin.env.sh for a good example. + +java-vm_install-env() { + debug-print-function ${FUNCNAME} "$*" + + local env_file="${ED}${JAVA_VM_CONFIG_DIR}/${VMHANDLE}" + local source_env_file="${1-${FILESDIR}/${VMHANDLE}.env.sh}" + + if [[ ! -f "${source_env_file}" ]]; then + die "Unable to find the env file: ${source_env_file}" + fi + + dodir "${JAVA_VM_CONFIG_DIR}" + + # Here be dragons! ;) -- Chewi + eval echo "\"$(cat <<< "$(sed 's:":\\":g' "${source_env_file}")")\"" > "${env_file}" || + die "failed to create Java env file" + + ( + echo "VMHANDLE=\"${VMHANDLE}\"" + echo "BUILD_ONLY=\"${JAVA_VM_BUILD_ONLY}\"" + [[ ${JAVA_PROVIDE} ]] && echo "PROVIDES=\"${JAVA_PROVIDE}\"" || true + ) >> "${env_file}" || die "failed to append to Java env file" + + local java_home=$(unset JAVA_HOME; source "${env_file}"; echo ${JAVA_HOME}) + [[ -z ${java_home} ]] && die "No JAVA_HOME defined in ${env_file}" + + # Make the symlink + dodir "${JAVA_VM_DIR}" + dosym "${java_home#${EPREFIX}}" "${JAVA_VM_DIR}/${VMHANDLE}" } |