Clover coverage report - Dependency Finder
Coverage timestamp: Mon Nov 29 2010 15:00:50 PST
file stats: LOC: 101   Methods: 7
NCLOC: 42   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
NameListMeasurement.java 87.5% 88.2% 100% 90.6%
coverage coverage
 1    /*
 2    * Copyright (c) 2001-2009, Jean Tessier
 3    * All rights reserved.
 4    *
 5    * Redistribution and use in source and binary forms, with or without
 6    * modification, are permitted provided that the following conditions
 7    * are met:
 8    *
 9    * * Redistributions of source code must retain the above copyright
 10    * notice, this list of conditions and the following disclaimer.
 11    *
 12    * * Redistributions in binary form must reproduce the above copyright
 13    * notice, this list of conditions and the following disclaimer in the
 14    * documentation and/or other materials provided with the distribution.
 15    *
 16    * * Neither the name of Jean Tessier nor the names of his contributors
 17    * may be used to endorse or promote products derived from this software
 18    * without specific prior written permission.
 19    *
 20    * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 21    * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 22    * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 23    * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR
 24    * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 25    * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 26    * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 27    * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 28    * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 29    * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 30    * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 31    */
 32   
 33    package com.jeantessier.metrics;
 34   
 35    import java.util.*;
 36   
 37    import org.apache.log4j.*;
 38   
 39    /**
 40    * <p>Accumulates a set of values. Its numerical value is the
 41    * cardinality (i.e., size) of the set. <code>OOMetrics</code>
 42    * uses it to keep track of dependencies.</p>
 43    *
 44    * <p>This is the syntax for initializing this type of
 45    * measurement:</p>
 46    *
 47    * <pre>
 48    * &lt;init&gt;
 49    * [SET | LIST]
 50    * &lt;/init&gt;
 51    * </pre>
 52    *
 53    * <p>Defaults to SET (i.e., does not count duplicates).</p>
 54    */
 55    public class NameListMeasurement extends MeasurementBase implements CollectionMeasurement {
 56    private Collection<String> values;
 57   
 58  11040 public NameListMeasurement(MeasurementDescriptor descriptor, Metrics context, String initText) {
 59  11040 super(descriptor, context, initText);
 60   
 61  11040 if (initText != null) {
 62  2 if (initText.trim().equalsIgnoreCase("list")) {
 63  1 values = new LinkedList<String>();
 64  1 } else if (initText.trim().equalsIgnoreCase("set")) {
 65  1 values = new HashSet<String>();
 66    } else {
 67  0 Logger.getLogger(getClass()).debug("Cannot initialize with \"" + initText + "\", using default value of SET instead");
 68  0 values = new HashSet<String>();
 69    }
 70    } else {
 71  11038 Logger.getLogger(getClass()).debug("Cannot initialize with null text, using default value of SET instead");
 72  11038 values = new HashSet<String>();
 73    }
 74    }
 75   
 76  10246 public void add(Object object) {
 77  10246 if (object instanceof String) {
 78  10241 values.add((String) object);
 79    }
 80    }
 81   
 82  24 public void accept(MeasurementVisitor visitor) {
 83  24 visitor.visitNameListMeasurement(this);
 84    }
 85   
 86  104 public Number getValue() {
 87  104 return values.size();
 88    }
 89   
 90  20 public boolean isEmpty() {
 91  20 return values.isEmpty();
 92    }
 93   
 94  41 protected double compute() {
 95  41 return values.size();
 96    }
 97   
 98  255 public Collection<String> getValues() {
 99  255 return Collections.unmodifiableCollection(values);
 100    }
 101    }