buildframework/helium/sf/java/legacy/src/com/nokia/ant/taskdefs/CoverageRecorderTask.java
author wbernard
Tue, 27 Apr 2010 08:33:08 +0300
changeset 587 85df38eb4012
child 588 c7c26511138f
permissions -rw-r--r--
helium_9.0-a7879c935424
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;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    24
import org.apache.tools.ant.BuildException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
import org.apache.tools.ant.Project;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
import org.apache.tools.ant.taskdefs.Recorder;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    27
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
/**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    29
 * 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
    30
 * output to a XML file.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
public class CoverageRecorderTask extends Recorder {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
    // ATTRIBUTES
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
    /** The list of recorder entries. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
    private static Hashtable<String, CoverageRecorderEntry> recorderEntries = new Hashtable<String, CoverageRecorderEntry>();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
    /** The name of the file to record to. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
    private String filename;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
     * Whether to start or stop recording. Need Boolean to record an unset
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
     * state (null).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
    private Boolean start;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
    /** The level to log at. A level of -1 means not initialized yet. */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
    private int loglevel = -1;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
    // ACCESSOR METHODS
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
     * Sets the name of the file to log to, and the name of the recorder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
     * entry.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
     *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
     * @param fname File name of logfile.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
    public void setName(String fname) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
        filename = fname;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
     * Sets the action for the associated recorder entry.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
     *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
     * @param action The action for the entry to take: start or stop.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
    public void setAction(ActionChoices action) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
        if (action.getValue().equalsIgnoreCase("start")) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
            start = Boolean.TRUE;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
        } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
            start = Boolean.FALSE;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
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
     * Sets the level to which this recorder entry should log to.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
     * @param level the level to set.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
     * see VerbosityLevelChoices
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
    public void setLoglevel(VerbosityLevelChoices level) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
        loglevel = level.getLevel();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
    //////////////////////////////////////////////////////////////////////
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
    // CORE / MAIN BODY
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
     * The main execution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    92
     * @throws BuildException on error
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
    public void execute() {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
        if (filename == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
            throw new BuildException("No filename specified");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
        getProject().log("setting a recorder for name " + filename,
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
            Project.MSG_DEBUG);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
        String recordTaskName = this.getTaskName();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
        // get the recorder entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
        CoverageRecorderEntry recorder = getRecorder(filename, getProject(), recordTaskName);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
        if (start != null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
            if (start.booleanValue()) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
                //recorder.reopenFile();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
                recorder.setRecordState(start);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
            } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
                recorder.setRecordState(start);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
                recorder.cleanup();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
    }
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
     * Gets the recorder that's associated with the passed in name. If the
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   119
     * recorder doesn't exist, then a new one is created.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   120
     * @param name the name of the recoder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   121
     * @param proj the current project
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   122
     * @return a recorder
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   123
     * @throws BuildException on error
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   124
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   125
    protected CoverageRecorderEntry getRecorder(String name, Project proj, String recordTaskName)
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   126
    {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   127
        CoverageRecorderEntry entry = recorderEntries.get(name);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   128
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   129
        if (entry == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   130
            // create a recorder entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   131
            entry = new CoverageRecorderEntry(name, recordTaskName);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   132
            entry.setProject(proj);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   133
            recorderEntries.put(name, entry);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   134
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   135
        return entry;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   136
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   137
}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   138