加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – buildFinished和buildStarted将无法正常工作

发布时间:2020-12-15 02:12:26 所属栏目:Java 来源:网络整理
导读:我从org.apache.tools.ant.DefaultLogger的DefaultLogger创建了一个子类: public class ExtendedLogger extends DefaultLogger { // My stuff} 我拿了信息here. 所以我从DefaultLogger重载了一些方法: @Overridepublic void targetStarted(BuildEvent even
我从org.apache.tools.ant.DefaultLogger的DefaultLogger创建了一个子类:

public class ExtendedLogger extends DefaultLogger {
    // My stuff
}

我拿了信息here.

所以我从DefaultLogger重载了一些方法:

@Override
public void targetStarted(BuildEvent event){
    System.out.println("Logger : "+"[TARGET STARTED]n");
}

@Override
public void targetFinished(BuildEvent event){
    System.out.println("Logger : "+"[TARGET FINISHED]n");
}

哪个效果很好(我可以看到输出).

这些方法也有效:

public void taskStarted(BuildEvent event);
public void taskFinished(BuildEvent event);

但是我遇到了麻烦:

@Override
public void buildFinished(BuildEvent event) {
    System.out.println("Logger : "+"[BUILD FINISHED]n");
}

@Override
public void buildStarted(BuildEvent event) {
    System.out.println("Logger : "+"[BUILD STARTED]n");
}

不可能进入这些方法!

我哪里错了?

谢谢.

编辑12/01/2016:

我刚尝试了一个像@Vaspar这样简单的testBuild.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project name="MyProject" default="Init" basedir=".">



<target name="Init">
    <!-- Create the time stamp -->
    <tstamp/>
    <!-- Create the build directory structure used by compile -->
    <echo message="INIT-ING"/>
</target>


<!-- targets used in my project -->
<target name="Clean" description="Clean output directory.">
    <echo>Clean</echo>
</target>

<target name="CleanAutogenerated" description="Clean auto-generated folder.">
    <echo>CleanAutogenerated</echo>
</target>

<target name="AutoGenerateTopics" description="Manual specific targets.">
    <echo>AutoGenerateTopics</echo>
</target>

<target name="BuildDocument" description="Build full documentation">
    <echo>BuildDocument</echo>
</target>



</project>

输出是:

Logger : [TARGET STARTED] org.apache.tools.ant.BuildEvent[source=Clean]
Logger : [TASK STARTED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@12f33e1]
     [echo] Clean
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@12f33e1]
Logger : [TARGET FINISHED] org.apache.tools.ant.BuildEvent[source=Clean]
CleanDocumentTask DONE

Logger : [TARGET STARTED] org.apache.tools.ant.BuildEvent[source=CleanAutogenerated]
Logger : [TASK STARTED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@1e2862f]
     [echo] CleanAutogenerated
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@1e2862f]
Logger : [TARGET FINISHED] org.apache.tools.ant.BuildEvent[source=CleanAutogenerated]
CleanAutoGenerateTask DONE

Logger : [TARGET STARTED] org.apache.tools.ant.BuildEvent[source=AutoGenerateTopics]
Logger : [TASK STARTED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@19bf1ed]
     [echo] AutoGenerateTopics
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@19bf1ed]
Logger : [TARGET FINISHED] org.apache.tools.ant.BuildEvent[source=AutoGenerateTopics]
AutoGenerateTask DONE

Logger : [TARGET STARTED] org.apache.tools.ant.BuildEvent[source=BuildDocument]
Logger : [TASK STARTED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@10b85cb]
     [echo] BuildDocument
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@10b85cb]
Logger : [TARGET FINISHED] org.apache.tools.ant.BuildEvent[source=BuildDocument]
DocumentTask DONE

请注意,CleanDocumentTask DONE,DocumentTask DONE等等是我项目中的纯Java输出(不是ant).

如您所见,targetStarted或targetFinished仍然没有输出:/

编辑12/01/2016(2):

我的ExtendedLogger.java的内容:

import javax.swing.SwingUtilities;

import org.apache.tools.ant.BuildEvent;
import org.apache.tools.ant.DefaultLogger;  


/*
 * This class has been wrote to deals with ant build outputs.
 * 
 * However,buildFinished and buildStarted seems not to work.
 * See details at :
 * 
 * http://api.dpml.net/ant/1.7.0/org/apache/tools/ant/DefaultLogger.html
 * 
 */
public class ExtendedLogger extends DefaultLogger {

    /*
     * public class ColorPane extends JTextPane
     * 
     * (personal class : JTextPane + Ansi coloring)
     */
    ColorPane colorPane = null;

    public ExtendedLogger(ColorPane c){
        super();
        if (c != null){
            colorPane = c;
        } else {
            System.out.println("ColorPane given to constructor is null. Exiting program.");
            System.exit(0);
        }
    }

    @Override
    public void buildFinished(BuildEvent event) {
        ColorPane.appendInEDT("[BUILD FINISHED]n",ColorPane.B_Yellow,colorPane);
        System.out.println("Logger : "+"[BUILD FINISHED]n");
    }

    @Override
    public void buildStarted(BuildEvent event) {
        ColorPane.appendInEDT("[BUILD STARTED]n",colorPane);
        System.out.println("Logger : "+"[BUILD STARTED]n");
    }


    @Override
    public void log(String message){
        appendInEDT(message);
    }

    private void appendInEDT(String s){
        /*
         * Detach the graphical modifications in the Event Dispatch Thread (EDT)
         */
        final String newLine = s;
        Thread t = new Thread(new Runnable(){
            public void run(){
                colorPane.append(ColorPane.B_White,newLine+"n");
            }
        });
        if (SwingUtilities.isEventDispatchThread()) {
            t.start();
        } else {
            SwingUtilities.invokeLater(t);
        }
    }
}

解决方法

奇怪.我使用了你的代码示例,我也可以获得buildStarted / buildFinished日志.

CustomLogger

import org.apache.tools.ant.BuildEvent;
import org.apache.tools.ant.DefaultLogger;

public class CustomLogger extends DefaultLogger{
    @Override
    public void targetStarted(BuildEvent event){
        System.out.println("Logger : "+"[TARGET STARTED] " + event);
    }

    @Override
    public void targetFinished(BuildEvent event){
        System.out.println("Logger : "+"[TARGET FINISHED] " + event);
    }

    @Override
    public void taskStarted(BuildEvent event) {
        System.out.println("Logger : "+"[TASK FINISHED] " + event);
    }
    @Override
    public void taskFinished(BuildEvent event) {
        System.out.println("Logger : "+"[TASK FINISHED] " + event);
    }

    @Override
    public void buildFinished(BuildEvent event) {
        System.out.println("Logger : "+"[BUILD FINISHED] " + event);
    }

    @Override
    public void buildStarted(BuildEvent event) {
        System.out.println("Logger : "+"[BUILD STARTED] " + event);
    }
}

build.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<project name="MyProject" default="init" basedir=".">

  <target name="init">
    <!-- Create the time stamp -->
    <tstamp/>
    <!-- Create the build directory structure used by compile -->
    <echo message="INIT-ING"/>
  </target>
</project>

以下是输出.

产量

/DummyTest> ant -logger CustomLogger
Buildfile: /DummyTest/build.xml
Logger : [BUILD STARTED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.Project@1318bd3c]
Logger : [TARGET STARTED] org.apache.tools.ant.BuildEvent[source=init]
   [tstamp] Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@31623389]
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@31623389]
     [echo] Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@636c7a8f]
     [echo] INIT-ING
Logger : [TASK FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.UnknownElement@636c7a8f]
Logger : [TARGET FINISHED] org.apache.tools.ant.BuildEvent[source=init]
Logger : [BUILD FINISHED] org.apache.tools.ant.BuildEvent[source=org.apache.tools.ant.Project@1318bd3c]

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读