服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

编写自定义任务,轻松扩展ant(1)

  ant自带了大量的任务(task),在网上也有大量的任务可用,可是如果你面对的是别人根本不会想到的问题,怎么办呢?其实,只要花一点点功夫就可以编写出自己的任务出来。我开始也没想到会这样简单(做嵌套任务碰到一点问题),由此可见ant的结构设计是相当优秀的。

  假设我们需要显示任务执行各花了多少时间,写一个timertask

  起步:覆盖org.apache.tools.ant.task的execute方法
  import org.apache.tools.ant.task;

  import org.apache.tools.ant.buildexception;

  public class timertask extends task {

  public void execute() throws buildexception {

    system.out.println("i am a timer");

  }

  }

  注意,编译时ant.jar必须在classpath上。

  简单起见,假设java源文件,类文件在同一目录下,在此目录再写一个build.xml文件:

  <?xml version="1.0" ?>

  <project name="testtimer" default="test" basedir=".">

   <taskdef name="timer" classname="timertask" classpath="."/>

  <target name="test">

    <timer />

  </target>

  </project>

  打开dos窗口,到此目录,运行ant

  够简单吧!如果类路径比这复杂或者在jar文件中,设置<taskdef>的classpath属性就行了。

   继续:设置属性

  假设我们想添加一个action属性,在java文件中:

  private string action;

  ….

  public void execute() throws buildexception {

  if (action.equals(“init”)) {

        …
  }

  …

  }

  public string getaction() {

  return action;

  }

  public void setaction(string string) {

  action = string;

  }

  在xml文件中:

  <timer action=”init” />

  使用project保存中间结果

  对于这个任务来讲,必须把时间值保存起来,比较合适的就是org.apache.tools.ant.project了,project对象生命期是整个build,并且可以通过setproperty, getproperty等方法保存/获取值。

   public void execute() throws buildexception {

    if (getowningtarget() == null)

        return;

    project proj = getowningtarget().getproject();

    …

 

    // can do smt with proj now

  }

  晋级:嵌套任务

  如果我们想要在timer下面再嵌套子任务(好像没有这个必要 :-):

  <timer action=”init” >

  <foo />

  </timer>

  那我们首先只需要写一个简单的footask,然后在build.xml加上<foo>的定义:

  <taskdef name="timer" classname="timertask" classpath="."/>

  <taskdef name="foo" classname="footask" classpath="."/> 

  然后给timertask添加一个方法:

  public void addfoo(footask foo) {

  }

  注意:addxxx的xxx由<taskdef>中的name决定,ant会利用java reflection去找;类型必须是具体的类型footask,不能是task。

扫描关注微信公众号