Cordova Android的`create`脚本无法创建新项目 - 使用java / ant配置时出错

时间:2013-08-06 07:51:25

标签: java android ant cordova

我正在尝试使用Cordova / Phonegap创建一个新的Android项目。

我已经下载了cordova-2.9.0和ADT Bundle for Mac。

我将ADT解压缩到〜/ Developer / Android,并将其添加到我的PATH:

export PATH="$HOME/Development/Android/sdk/tools:$PATH"
export PATH="$HOME/Development/Android/sdk/platform-tools:$PATH"

然后我尝试运行cordova create脚本,但它失败了:

→  bin  sudo ./create ~/Projects/myproject/cordova-android com.mydomain.myproject myproject
Password:

BUILD FAILED
/Users/asgeo1/Development/Android/sdk/tools/ant/build.xml:714: The following error occurred while executing this line:
/Users/asgeo1/Development/Android/sdk/tools/ant/build.xml:728: Compile failed; see the compiler error output for details.

Total time: 1 second
An unexpected error occurred: ant jar > /dev/null exited with 1
Deleting project...

不是很有帮助。所以我编辑了Cordova create脚本,以便输出更多信息。

    # COMMENTED OUT piping to /dev/null:
    #
    # compile cordova.js and cordova.jar
    pushd "$BUILD_PATH"/framework # > /dev/null
    ant jar #> /dev/null
    popd  #> /dev/null

然后我重新运行create脚本:

→  bin  sudo ./create ~/Projects/myproject/cordova-android com.mydomain.myproject myproject
~/Downloads/cordova-2.9.0/cordova-android/framework ~/Downloads/cordova-2.9.0/cordova-android/bin
Buildfile: /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/build.xml

-pre-build:

-check-env:
 [checkenv] Android SDK Tools Revision 22.0.5
 [checkenv] Installed at /Users/asgeo1/Development/Android/sdk

-setup:
     [echo] Project Name: Cordova
  [gettype] Project Type: Android Library

-build-setup:
[getbuildtools] Using latest Build Tools: 18.0.1
     [echo] Resolving Build Target for Cordova...
[gettarget] Project Target:   Android 4.3
[gettarget] API level:        18
     [echo] ----------
     [echo] Creating output directories if needed...
     [echo] ----------
     [echo] Resolving Dependencies for Cordova...
[dependency] Library dependencies:
[dependency] No Libraries
     [echo] ----------
     [echo] Building Libraries with '${build.target}'...
   [subant] No sub-builds to iterate on

-code-gen:
[mergemanifest] No changes in the AndroidManifest files.
     [echo] Handling aidl files...
     [aidl] No AIDL files to compile.
     [echo] ----------
     [echo] Handling RenderScript files...
[renderscript] No RenderScript files to compile.
     [echo] ----------
     [echo] Handling Resources...
     [aapt] No changed resources. R.java and Manifest.java untouched.
     [echo] ----------
     [echo] Handling BuildConfig class...
[buildconfig] Generating BuildConfig class.

-pre-compile:

-compile:
    [javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes
    [javac] /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/src/com/squareup/okhttp/Connection.java:171: method does not override a method from its superclass
    [javac]   @Override public void close() throws IOException {
    [javac]    ^

还有另外40个错误,如上面的错误,关于@override

据我所知,这是因为在jdk 1.6及以上版本中,@ override注释发生了变化。 (或类似的东西): Why is javac failing on @Override annotation

好的,所以我发现ant的Android SDK配置位于名为build.xml的文件中。很低,它有一些Java 1.5的设置:

<property name="java.target" value="1.5" />
<property name="java.source" value="1.5" />

如果我将这些值更改为1.6或1.7,则在重新运行Cordova create脚本时出现java错误:

-compile:
    [javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes
    [javac] javac: invalid source release: 1.7
    [javac] Usage: javac <options> <source files>

我真的在这里摸不着头脑。我不是Java的专家,所以我不知道这里发生了什么。

有没有人知道如何在OSX上运行Cordova Android的create脚本?

更新

按照@ cartland的建议,我可以摆脱@Override错误。仍然得到最后一个错误:

-compile:
[javac] Compiling 104 source files to /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/bin/classes
[javac] /Users/asgeo1/Downloads/cordova-2.9.0/cordova-android/framework/src/org/apache/cordova/InAppBrowser.java:523: error: cannot find symbol
[javac]                 settings.setPluginsEnabled(true);
[javac]                         ^
[javac]   symbol:   method setPluginsEnabled(boolean)
[javac]   location: variable settings of type WebSettings
[javac] Note: Some input files use or override a deprecated API.
[javac] Note: Recompile with -Xlint:deprecation for details.
[javac] 1 error

我会尝试弄清楚那是什么 - 但如果有人知道,请发一个答案:)

更新2

我知道第二个错误是什么。这里提到:https://developer.motorolasolutions.com/thread/3640

Cordova 2.9.0与Android SDK 18不兼容。我需要将Cordova 3.0.0与Android SDK 18一起使用。(或者反过来将Android SDK降级为17)

2 个答案:

答案 0 :(得分:4)

我正在运行Ubuntu 10.4 64bit; Oracle JDK 1.7.0_25-b15; Eclipse Kepler; Android SDK 4.3; PhoneGap 3.0。

与使用CLI时出现的问题完全相同。将项目加载到Eclipse中工作正常(〜/ .cordova / lib / android / cordova / 3.0.0 / framework / .project)。由于Eclipse使用它自己的内部Java编译器,我认为我正在使用的Oracle安装存在问题,并且有一些问题。

事实证明,某些应用程序已将早期JRE中的tools.jar(以及其他版本)版本安装到Java ext文件夹中。对我来说似乎很奇怪,javac会在它自己的lib文件夹中加载来自此处的依赖jar,但这似乎是优先顺序。无论如何,我从ext文件夹中删除了所有文件,一切正常。

  • JDK位置:/ usr / lib / jvm / java-7-oracle /
  • Ext位置:/ usr / java / packages / lib / ext /

我没有让我的Mac检查位置,但尝试/ Library / Java / Extensions或〜/ Library / Java / Extensions

我不需要做任何其他更改。但是在试验时,我确实尝试在项目的ant.properties文件中设置以下属性。所有的工作都是1.5,1.6,1.7。

  • java.target = 1.5
  • java.source = 1.5

答案 1 :(得分:0)

实际上,这里的问题似乎是你的java版本和Cordova编译的jar之间的不兼容性。 要快速修复,最好安装Java 1.5并将其用于开发。不要忘记将build.xml中的更改恢复为1.5。