java - `create` Cordova Android 脚本无法创建新项目 - java/ant 配置错误

标签 java android ant cordova

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

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

我将 ADT 提取到 ~/Developer/Android,并将其添加到我的路径中:

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]    ^

And there's another 40 errors like the one above, regarding @override.

From what I can tell on Google, this is because in jdk 1.6 and above, the @override annotations changed. (or something like that): Why is javac failing on @Override annotation

OK, so I work out that the Android SDK configuration for ant is in a file called build.xml. Low and behold, it has some settings for 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)

最佳答案

我正在运行 Ubuntu 10.4 64 位;甲骨文 JDK 1.7.0_25-b15; eclipse 开普勒;安卓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 文件夹中的 jars 之前从这里加载依赖的 jars,但这似乎是优先顺序。不管怎样,我从 ext 文件夹中删除了所有文件,一切正常。

  • JDK 位置:/usr/lib/jvm/java-7-oracle/
  • 扩展位置:/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

关于java - `create` Cordova Android 脚本无法创建新项目 - java/ant 配置错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18074522/

相关文章:

java - 如何在 spock 或 hamcrest 中创建自定义域特定断言/匹配器

java - 检测 Blackberry 中的切换失败

java - Android中滑动屏幕的动态内容

java - 使用样板生成和生成器(GWT 平台)的 Ant 构建失败

android - 如何为 Android ant 调试版本指定调试 keystore 的位置?

Java - 识别值类型的模式

java - 如何将点击哪一行的变量传递给我的 Intent ?

安卓。为什么时间选择器不对称?

android - Dagger 2 组件链依赖

netbeans - 为什么 NetBeans 无法为我的某些项目找到 CopyLibs?