`

Java 调用 Eclipse的编译器 JDT

    博客分类:
  • java
阅读更多

Java 调用 Eclipse的编译器 JDT

想给项目做一个Nightly build,项目特点如下:

1 使用 Eclipse开发的java和GWT混合项目

2 目前有40多个工程

3 项目处于初期,很多部分尚未稳定,因此是工程是工程间依赖工程,没有引用编译好的jar包

4 工程主要分为前台clt,公共模块common,和服务器模块svr。例如有一个A.common,一定有A.clt和A.svr依赖于A.common,但clt和svr间不相互依赖。

(这是我们项目的编译过程的特殊逻辑)

 

以下是选定的技术路线 

 

  1. 因为编译带有特殊的逻辑,所以使用方便编程的java,而非纯ant脚本。
  2. 不想自己整理工程的编译顺序,太多,麻烦。所以使用了dom4j读取eclipse工程配置信息。
  3. 不用ant脚本,可以使用Java程序调用Ant API。
  4. 由于javac对模板的不友好 ,所以使用jdt

 

例如以下的代码

<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />-->package  demo.server;

import  com.extjs.gxt.ui.client.data.BaseModel;

public   class  TestA  extends  BaseModel {

    @Override
    
public   < X >  X get(String property) {
        
return   super .get(property);
    }
}

 

 

使用javac编译,就会出现

无法确定 <X>X 的类型参数;对于上限为 X,java.lang.Object 的类型变量 X,不存在唯一最大实例

 

虽然搜索了以下,说只要返回值强制转换一下就ok,即return (X)super .get(property);

但这样的代码也比较多,明明在eclipse编译通过的,在javac就不行。所以g了一下,才知道 eclipse有自己的编译器(?不太确认javac和jdt的关系),叫jdt。

 

首先要从Eclipse中,抽取出一个JDT的包。在Eclipse/plugin目录下,找到一个org.eclipse.jdt.core _3.5.1.v_972_R35x.jar,(版本社么的没有关系)。用winrar解压出里面的一个jdtCompilerAdapter.jar包,然后从工程中引用它。

 

顺便把

org.eclipse.jdt.compiler.tool_1.0.100.v_972_R35x.jar

org.eclipse.jdt.core_3.5.2.v_981_R35x.jar

org.eclipse.jdt.debug.ui_3.4.1.v20090811_r351.jar

这几个包也从eclipse/plugin中引用到项目里。——为什么要单独解压jdtCompilerAdapter.jar,我不太清楚啊。

 

然后,由于要调用ant,所以从apache上的ant项目中下载http://ant.apache.org/bindownload.cgi,用到两个包,

ant.jar

ant-launcher.jar

 

使用以下代码,调用ant 

<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />-->package  thss.platform.util.mrobuild;

import  java.io.File;

import  org.apache.tools.ant.Project;
import  org.apache.tools.ant.taskdefs.Javac;
import  org.apache.tools.ant.taskdefs.Javac.ImplementationSpecificArgument;
import  org.apache.tools.ant.types.Path;

public   class  JavaBuilder {

    
public  JavaBuilder() {
    }

    
public   void  execute(Path classPath, File output) {
        Project currentProject 
=   new  Project();
        
//  填写工程的绝对目录,这样后面可以使用相对目录
        currentProject.setBaseDir( new  File( " 这里是工程的绝对目录 " ));

        Javac compileJava 
=   new  Javac();
        compileJava.setProject(currentProject);
        
//  调用jdt编译器
        compileJava.setCompiler( " org.eclipse.jdt.core.JDTCompilerAdapter " );
        compileJava.setClasspath(classPath);
        compileJava.setEncoding(
" UTF-8 " );

        
//  填写相对目录src
        compileJava.setSrcdir( new  Path(currentProject,  " src " ));
        
//  编译后的结果.class输出到哪里
        compileJava.setDestdir(output);
        compileJava.setTarget(
" 1.6 " );
        compileJava.setSource(
" 1.6 " );
        compileJava.setNowarn(
true );
        compileJava.setDebug(
true );
        compileJava.setDebugLevel(
" lines,source " );

        
//  javac需要这段,换成了jdt不知道要不要了
        ImplementationSpecificArgument arg  =  compileJava.createCompilerArg();
        arg.setLine(
"  -Xlint " );

        compileJava.execute();

    }
}

 

 

可能上述文章有很多概念性的问题,例如我没有搞清的javac和jdt关系,但是问题确实是解决了,欢迎高手批评指正。by Anic

 

文章来源:http://www.cnblogs.com/anic/archive/2010/03/24/1692271.html

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics