Ant正在使用错误的Java编译器,但认为它是正确的

时间:2013-04-16 05:50:26

标签: java ant environment-variables javac

为了清楚起见,这不是这个问题:Ant is using wrong java version

我正在尝试使用Mac OS 10.8.2计算机上的Ant编译Java 1.7项目。我已经安装了Java 1.7,并且Eclipse已经在游戏中构建它。但是,在使用Ant构建脚本时,如命令行执行Ant

ant -v

输出最多是神秘的:第一行显示Ant正在我自己设置的$ JAVA_HOME位置按要求使用Java 1.7。

Apache Ant(TM) version 1.8.2 compiled on December 20 2010
Trying the default build file: build.xml
Buildfile: /Users/emish/School/cis555/homework/cis-555-search-engine/build.xml
Detected Java version: 1.7 in: /Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home/jre
Detected OS: Mac OS X

但是,以下编译器错误没有任何意义,因为它们显示的编译器错误只会发生在Java 1.7之前的版本中:

[javac] /Users/emish/School/cis555/homework/cis-555-search-engine/src/pokedex/crawler/CrawlCore.java:186: <identifier> expected
[javac]         } catch (IOException | ClassNotFoundException | InterruptedException e) {
[javac]                             ^

这很奇怪。我尝试了很多东西,包括重新安装我的Java JDK并重新安装Ant。有没有人对可能导致这个令人费解的问题的原因有所了解?

如果有任何帮助:

java -version
java version "1.7.0_17"
Java(TM) SE Runtime Environment (build 1.7.0_17-b02)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01, mixed mode)

javac -version
javac 1.7.0_17

echo $JAVA_HOME
/Library/Java/JavaVirtualMachines/jdk1.7.0_17.jdk/Contents/Home

ll `which javac`
lrwxr-xr-x  1 root  wheel  75 Oct 30 22:27 /usr/bin/javac -> /System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands/javac

ll `which java`
lrwxr-xr-x  1 root  wheel  74 Oct 30 22:27 /usr/bin/java -> /System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands/java

编辑:根据评论者的要求,我在下面添加了我的build.xml和manifest.mf文件。

的build.xml

<?xml version="1.0"?>

<project name="pokedex" default="jar" basedir=".">
    <property name="shared.root" location="${basedir}"/>
    <property name="project.root" location="${basedir}"/>
    <property name="build.dir" location="${project.root}${file.separator}build"/>
    <property name="src" location="${project.root}${file.separator}src"/>
    <property name="build.classes" location="${build.dir}${file.separator}classes"/>
    <property name="test.classes" location="${build.classes}${file.separator}test"/>
    <property name="test.source" location="${src}${file.separator}test"/>
    <property name="lib.dir" location="${project.root}${file.separator}lib"/>


    <target name="jar" depends="clobber, compile" description="Create Jar file">
          <jar destfile="pokedex.jar">
            <fileset dir="${build.classes}" includes="**/*.class"/>
            <fileset dir="${project.root}" includes="conf/*"/>
          </jar>
    </target>

    <target name="compile" depends="clobber" description="compiles Java source code">
        <javac srcdir="${src}${file.separator}" destdir="${build.classes}" debug="on" deprecation="off"
            optimize="on" includeAntRuntime="no">
            <classpath>
                <fileset dir="${lib.dir}">
                    <include name="*.jar"/>
                    <include name="*.zip"/>
                </fileset>
            </classpath>
        </javac>
    </target>

    <target name="pack" depends="jar" description="Create an archive use on EC2">
          <zip destfile="pokedex.zip">
            <zipfileset dir="." excludes="target/**,extra/**,**/*.class,pokedex.zip"/>
          </zip>
    </target>

  <target name="clobber" description="remove jar">
        <delete file="${project.root}${file.separator}pokedex.jar"/>
        <delete dir="${build.classes}${file.separator}"/>
        <mkdir dir="${build.classes}${file.separator}"/>
    </target>

       <!--DOES NOT WORK -->
       <target name="test" description="Run tests">
         <java failonerror="true" fork="true" classname="junit.textui.TestRunner">
           <classpath>
             <pathelement location="${test.classes}"/>
             <pathelement location="${build.classes.dir}"/>
              <fileset dir="${lib.dir}">
                  <include name="*.jar"/>
              </fileset>
           </classpath>
            <arg value="RunAllTests"/>
         </java>
       </target>

    <target name="test2">
      <junit>
        <classpath>
             <pathelement location="${build.classes.dir}"/>
                <fileset dir="${lib.dir}">
                     <include name="*.jar"/>
                </fileset>
              </classpath>   
        <batchtest>
           <fileset dir="${project.root}">
                <include name="**/RunAllTests*" />
           </fileset>
        </batchtest>
        <formatter type="brief" usefile="false"/>
      </junit>
    </target>

</project>

MANIFEST.MF

Manifest-Version: 1.0
Class-Path: 

1 个答案:

答案 0 :(得分:6)

尝试

ant -diagnostics | grep java\\.home

您将看到Ant认为安装Java的位置。除了您在Eclipse中使用的内容之外,它可能会从某个地方获取它,因为当然,Eclipse允许用户在每个项目的基础上指定JDK工具所在的位置。您也可以运行ant -diagnostics来查看完整的诊断输出,这将基本上添加Java版本信息等信息。

在实际的Ant脚本中,为什么不在构建目标中回显以下内容:

<echo message="Ant running on Java version ${ant.java.version}"/>

这将提供信息以区分运行Ant的容器与您希望应用程序编译的容器。

您可以通过将这些说明符添加到构建目标中的javac说明符来强制您的应用程序使用特定Java版本进行编译:

<javac debug="true" 
... 
source="1.7" 
target="1.7" 
...
executable="<MY_JDK7_JAVA_HOME_DIR>/bin/javac" 
... >
... 
</javac>

此外,您可以通过指定'-v'选项ala ant -v ...以详细模式运行Ant。此信息应指导调试问题并希望解决问题。