diff options
author | Michael DeGuzis | 2017-09-19 20:20:42 -0400 |
---|---|---|
committer | Michael DeGuzis | 2017-09-19 20:20:42 -0400 |
commit | 7e54b9cd6bcbb3eaa57f9b2f0b9d710635fbf509 (patch) | |
tree | 1523f8745c4afa4f1a9b36033ee55f22c87379a8 /PlayOnLinux.sh | |
parent | a974aeb2f1454b2d30d5b81b3f4f84aee044745a (diff) | |
download | aur-7e54b9cd6bcbb3eaa57f9b2f0b9d710635fbf509.tar.gz |
WIP logic for handling javafx detect
Diffstat (limited to 'PlayOnLinux.sh')
-rwxr-xr-x | PlayOnLinux.sh | 82 |
1 files changed, 63 insertions, 19 deletions
diff --git a/PlayOnLinux.sh b/PlayOnLinux.sh index fd713fbf883f..b91952c90f01 100755 --- a/PlayOnLinux.sh +++ b/PlayOnLinux.sh @@ -1,8 +1,21 @@ #!/bin/bash +cat<<-EOF + +----------------------------------------- +Unofficial PlayOnLinux5 Launcher +----------------------------------------- + +EOF + POL_HOME=/opt/playonlinux5 CLASSPATH=${CLASSPATH}:$POL_HOME/lib/* +# Test for active java +_openjdk=$(ls -d /usr/lib/jvm/java-{8,9}-openjdk* 2>/dev/null | head -1) +_oraclejdk=$(ls -d /usr/lib/jvm/java-{8,9}-jdk* 2>/dev/null | head -1) +_opendjdk_jetbrains=$(ls -d /usr/lib/jvm/java-{8,9}-openjdk-jetbrains* 2>/dev/null | head -1) + # Allow either openjdk java or Oracle java to be used if (( $(archlinux-java get | cut -d "-" -f2) < 8 )); then @@ -10,33 +23,64 @@ if (( $(archlinux-java get | cut -d "-" -f2) < 8 )); then echo "WARNING: A JVM of version 8 or higher was not found" java_default=$(archlinux-java get) echo -e "\t==> Picked up default Java of: $java_default" - echo -e "\t==> Assessing if we have JetBrains or OpenJDK with version 8 or higher..." - - # Order is Oracle/Jetbrains/OpenJDK - # If you have both Oracle/Jetbrains, choose one. - # It is too diffcult to appease everyone... - javaver_oracle=$(ls -d /usr/lib/jvm/java-{8,9}-jdk* 2>/dev/null | head -1) - javaver_openjdk=$(ls -d /usr/lib/jvm/java-{8,9}-openjdk* 2>/dev/null | head -1) - javaver_jetbrains=$(ls -d /usr/lib/jvm/java-{8,9}-openjdk-jetbrains* 2>/dev/null | head -1) - - if [[ "$javaver_oracle" ]]; then - echo -e "\t==> Picked up compatible JVM: $javaver_oracle" - javaver=$javaver_oracle - elif [[ "$javaver_jetbrains" ]]; then - echo -e "\t==> Picked up compatible JVM: $javaver_jetbrains" - javaver=$javaver_jetbrains - elif [[ "$javaver_openjdk" ]]; then - echo -e "\t==> Picked up compatible JVM: $javaver_openjdk" - javaver=$javaver_opendjdk + echo -e "\t==> Assessing if we have java version 8 or higher..." + + if [[ "$_oraclejdk" ]]; then + echo -e "\t==> Picked up compatible JVM: $_oraclejdk" + JAVA_HOME=$_oraclejdk + + elif [[ "$_openjdk_jetbrains" ]]; then + echo -e "\t==> Picked up compatible JVM: $opendjdk_jetbrains" + JAVA_HOME=$_openjdk_jetbrains + + elif [[ "$_openjdk" ]]; then + echo -e "\t==> Picked up compatible JVM: $_openjdk" + JAVA_HOME=$_opendjdk + else echo -e "\t==> Failed to find a compatible runtime JVM!" + fi else echo "Running compatible JVM already (default set): $(archlinux-java get)" + echo "Using: $(archlinux-java get)" + export JAVA_HOME="/usr/lib/jvm/default" + +fi +# JavaFX +# Test for JavaFX (required) + +JAVA_FX=$(find $JAVA_HOME/ -name "javafx.properties") +if [[ -n "$JAVA_FX" ]]; then + JAVA_FX_BOOLEAN="True" +else + JAVA_FX_BOOLEAN="False" fi +echo "JavaFX Capabale? $JAVA_FX_BOOLEAN" + +if [[ "$JAVA_FX_BOOLEAN" = "False" ]]; then + echo "Forcing proper Java (if available)" + + if [[ "${_openjdk}" ]]; then + export JAVA_HOME="${_openjdk[0]}" + echo "Switching to OpenJDK" + + elif [[ "${_oraclejdk}" ]]; then + export JAVA_HOME=$(ls /usr/lib/jvm/java-{8,9}-jdk*/bin/javac 2>/dev/null | cut -d "/" -f-5 | head -1) + msg2 "Switching to Oracle JDK" + else + msg2 "ERROR: Could not find a proper java build environment. Exiting" + exit 1 + fi + +fi + +echo "JAVA_HOME: $JAVA_HOME" + # Start PlayOnLinux -$javaver/bin/java -classpath "$CLASSPATH" org.phoenicis.javafx.JavaFXApplication "$@" +echo "Launching PlayOnLinux5" +$JAVA_HOME/bin/java -classpath "$CLASSPATH" org.phoenicis.javafx.JavaFXApplication "$@" |