无法在OS X上启动Eclipse RCP应用程序

时间:2016-02-18 16:30:00

标签: bash eclipse-rcp rcp osx-elcapitan

我正在尝试使用带有Java 1.6的Eclipse Indigo插件在OS X上使用Shell脚本启动Eclipse RCP应用程序。 OS的版本是10.11.3 脚本如下:

#!/bin/bash
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
app_cmd="\"$DIR/../Resources/jre/Contents/Home/bin/java\" 
-XstartOnFirstThread
-Xdock:name=GS\ Risk
-Xdock:icon=\"$DIR/../Resources/AppIcon.ico\"
-Dorg.eclipse.swt.internal.carbon.smallFonts
-Dosgi.console.enable.builtin=true
-jar \"$DIR/../Resources/plugins/org.eclipse.equinox.launcher_1.2.0.v20110502.jar\"
-data @noDefault 
-Dfile.encoding=UTF-8 
-os macosx 
-ws cocoa 
-arch x86_64 
-nl en_US 
-consoleLog 
-console 
-showsplash
AppName"

runCommand() { 
    typeset cmnd="$*" 
    typeset ret_code
    echo cmnd=$cmnd 
    eval $cmnd 
    ret_code=$?
    case $ret_code in 
    0)   
        printf "[%s] exit OK." "$NAME"   
        ;; 
    23)   
        printf "[%s] requested a restart. Restarting..." "$NAME"   r
        unCommand "$cmnd"   
        ;; 
    *)
        printf "Error : [%d] when executing command: '$cmnd'" $ret_code   
        ;; 
    esac 
    printf "\n" 
    exit $ret_code 
}

runCommand "$app_cmd"

我收到以下错误:

!SESSION Thu Feb 18 21:50:11 GMT+05:30 2016 ------------------------------------
!ENTRY org.eclipse.equinox.launcher 4 0 2016-02-18 21:50:11.660
!MESSAGE Exception launching the Eclipse Platform:
!STACK
java.lang.RuntimeException: Could not find framework
    at org.eclipse.equinox.launcher.Main.getBootPath(Main.java:978)
    at org.eclipse.equinox.launcher.Main.basicRun(Main.java:557)
    at org.eclipse.equinox.launcher.Main.run(Main.java:1410)
    at org.eclipse.equinox.launcher.Main.main(Main.java:1386)

可能是什么原因?

1 个答案:

答案 0 :(得分:2)

看起来问题在于运行的Java命令而不是运行它的Bash代码,但是Bash代码存在难以调试的问题。一个问题是字符串用于存储命令,选项和参数。这通常是一个坏主意,因为它很难避免路径名扩展(globbing)和单词拆分的问题。另一个问题是使用eval,这是最好的避免,而且很少需要。这是使用数组存储命令的代码的略微修改版本,不使用'eval':

#!/bin/bash

DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"

app_cmd_parts=(
    "$DIR/../Resources/jre/Contents/Home/bin/java"
    -XstartOnFirstThread
    -Xdock:name='GS Risk'
    -Xdock:icon="$DIR/../Resources/AppIcon.ico"
    -Dorg.eclipse.swt.internal.carbon.smallFonts
    -Dosgi.console.enable.builtin=true
    -jar "$DIR/../Resources/plugins/org.eclipse.equinox.launcher_1.2.0.v20110502.jar"
    -data @noDefault
    -Dfile.encoding=UTF-8
    -os macosx
    -ws cocoa
    -arch x86_64
    -nl en_US
    -consoleLog
    -console
    -showsplash
    AppName
)

runCommand() {
    typeset cmd_parts=( "$@" )
    typeset ret_code
    printf 'cmd_parts=('
    printf ' %q' "${cmd_parts[@]}"
    printf ' )\n'
    "${cmd_parts[@]}"
    ret_code=$?
    case $ret_code in
    0)
        printf "[%s] exit OK." "$NAME"
        ;;
    23)
        printf "[%s] requested a restart. Restarting..." "$NAME" runCommand "${cmd_parts[*]}"
        ;;
    *)
        printf "Error : [%d] when executing command: '${cmd_parts[*]}'" $ret_code
        ;;
    esac
    printf "\n"
    exit $ret_code
}

runCommand "${app_cmd_parts[@]}"

这应该更容易调试。使用bash -x运行它以查看它正在做什么。将文本复制并粘贴到cmd_parts=( ... )输出中的括号之间,以重新运行程序运行的Java命令。希望这将使您能够确定该命令的错误以及如何修复它。