buildframework/helium/sf/java/legacy/src/com/nokia/ant/taskdefs/CoverageRecorderTask.java
author wbernard
Fri, 13 Aug 2010 14:59:05 +0300
changeset 628 7c4a911dc066
parent 588 c7c26511138f
permissions -rw-r--r--
helium_11.0.0-e00f171ca185
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     1
/*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     2
 *  Licensed to the Apache Software Foundation (ASF) under one or more
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     3
 *  contributor license agreements.  See the NOTICE file distributed with
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     4
 *  this work for additional information regarding copyright ownership.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     5
 *  The ASF licenses this file to You under the Apache License, Version 2.0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     6
 *  (the "License"); you may not use this file except in compliance with
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     7
 *  the License.  You may obtain a copy of the License at
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     8
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     9
 *      http://www.apache.org/licenses/LICENSE-2.0
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    10
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    11
 *  Unless required by applicable law or agreed to in writing, software
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    12
 *  distributed under the License is distributed on an "AS IS" BASIS,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    13
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    14
 *  See the License for the specific language governing permissions and
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    15
 *  limitations under the License.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    16
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    17
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    19
/* Portion Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    20
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    21
package com.nokia.ant.taskdefs;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    22
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    23
import java.util.Hashtable;
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 588
diff changeset
    24
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
import org.apache.tools.ant.BuildException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
import org.apache.tools.ant.Project;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    27
import org.apache.tools.ant.taskdefs.Recorder;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
588
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
    29
import com.nokia.ant.listener.CoverageRecorderEntry;
c7c26511138f helium-10.0.0-bc45d50958fe
wbernard
parents: 587
diff changeset
    30
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
/**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
 * Adds a listener, which inherits the Ant Record task, to the current build process that records the
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
 * output to a XML file.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
public class CoverageRecorderTask extends Recorder {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
    // ATTRIBUTES
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
    /** The list of recorder entries. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
    private static Hashtable<String, CoverageRecorderEntry> recorderEntries = new Hashtable<String, CoverageRecorderEntry>();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
    /** The name of the file to record to. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
    private String filename;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
     * Whether to start or stop recording. Need Boolean to record an unset
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
     * state (null).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
    private Boolean start;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
    /** The level to log at. A level of -1 means not initialized yet. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
    private int loglevel = -1;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
    // ACCESSOR METHODS
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
     * Sets the name of the file to log to, and the name of the recorder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
     * entry.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
     *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
     * @param fname File name of logfile.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
    public void setName(String fname) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
        filename = fname;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
     * Sets the action for the associated recorder entry.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
     *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
     * @param action The action for the entry to take: start or stop.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
    public void setAction(ActionChoices action) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
        if (action.getValue().equalsIgnoreCase("start")) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
            start = Boolean.TRUE;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
        } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
            start = Boolean.FALSE;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    77
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
     * Sets the level to which this recorder entry should log to.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
     * @param level the level to set.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
     * see VerbosityLevelChoices
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
    public void setLoglevel(VerbosityLevelChoices level) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
        loglevel = level.getLevel();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    89
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    90
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    91
    // CORE / MAIN BODY
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    92
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
     * The main execution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
     * @throws BuildException on error
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
    public void execute() {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
        if (filename == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
            throw new BuildException("No filename specified");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
        getProject().log("setting a recorder for name " + filename,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
            Project.MSG_DEBUG);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
        String recordTaskName = this.getTaskName();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
        // get the recorder entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
        CoverageRecorderEntry recorder = getRecorder(filename, getProject(), recordTaskName);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
        if (start != null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
            if (start.booleanValue()) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
                //recorder.reopenFile();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
                recorder.setRecordState(start);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
            } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
                recorder.setRecordState(start);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
                recorder.cleanup();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   116
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   117
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   118
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   119
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   120
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   121
     * Gets the recorder that's associated with the passed in name. If the
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   122
     * recorder doesn't exist, then a new one is created.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   123
     * @param name the name of the recoder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   124
     * @param proj the current project
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   125
     * @return a recorder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   126
     * @throws BuildException on error
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   127
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   128
    protected CoverageRecorderEntry getRecorder(String name, Project proj, String recordTaskName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   129
    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   130
        CoverageRecorderEntry entry = recorderEntries.get(name);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   131
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   132
        if (entry == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   133
            // create a recorder entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   134
            entry = new CoverageRecorderEntry(name, recordTaskName);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   135
            entry.setProject(proj);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   136
            recorderEntries.put(name, entry);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   137
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   138
        return entry;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   139
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   140
}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   141