Clover coverage report - QedeqKernelSe Coverage Report
Coverage timestamp: Sa Okt 21 2006 08:24:31 CEST
file stats: LOC: 103   Methods: 7
NCLOC: 57   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
LocationListBo.java 100% 100% 100% 100%
coverage
 1    /* $Id: LocationListBo.java,v 1.3 2006/10/20 20:23:00 m31 Exp $
 2    *
 3    * This file is part of the project "Hilbert II" - http://www.qedeq.org
 4    *
 5    * Copyright 2000-2006, Michael Meyling <mime@qedeq.org>.
 6    *
 7    * "Hilbert II" is free software; you can redistribute
 8    * it and/or modify it under the terms of the GNU General Public
 9    * License as published by the Free Software Foundation; either
 10    * version 2 of the License, or (at your option) any later version.
 11    *
 12    * This program is distributed in the hope that it will be useful,
 13    * but WITHOUT ANY WARRANTY; without even the implied warranty of
 14    * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 15    * GNU General Public License for more details.
 16    */
 17   
 18    package org.qedeq.kernel.bo.module;
 19   
 20    import java.util.ArrayList;
 21    import java.util.List;
 22   
 23    import org.qedeq.kernel.base.module.Location;
 24    import org.qedeq.kernel.base.module.LocationList;
 25    import org.qedeq.kernel.utility.EqualsUtility;
 26   
 27   
 28    /**
 29    * List of locations.
 30    *
 31    * @version $Revision: 1.3 $
 32    * @author Michael Meyling
 33    */
 34    public final class LocationListBo implements LocationList {
 35   
 36    /** Contains all list elements. */
 37    private final List list;
 38   
 39    /**
 40    * Constructs an empty list of locations.
 41    */
 42  174 public LocationListBo() {
 43  174 this.list = new ArrayList();
 44   
 45    }
 46   
 47    /**
 48    * Add location to this list.
 49    *
 50    * @param location Location to add.
 51    */
 52  161 public final void add(final Location location) {
 53  161 list.add(location);
 54    }
 55   
 56  1373 public final int size() {
 57  1373 return list.size();
 58    }
 59   
 60  1168 public final Location get(final int index) {
 61  1168 return (Location) list.get(index);
 62    }
 63   
 64  253 public boolean equals(final Object obj) {
 65  253 if (!(obj instanceof LocationListBo)) {
 66  6 return false;
 67    }
 68  247 final LocationListBo otherList = (LocationListBo) obj;
 69  247 if (size() != otherList.size()) {
 70  7 return false;
 71    }
 72  240 for (int i = 0; i < size(); i++) {
 73  239 if (!EqualsUtility.equals(get(i), otherList.get(i))) {
 74  2 return false;
 75    }
 76    }
 77  238 return true;
 78    }
 79   
 80  201 public int hashCode() {
 81  201 int hash = 0;
 82  201 for (int i = 0; i < size(); i++) {
 83  199 hash = hash ^ (i + 1);
 84  199 if (get(i) != null) {
 85  198 hash = hash ^ get(i).hashCode();
 86    }
 87    }
 88  201 return hash;
 89    }
 90   
 91  149 public String toString() {
 92  149 final StringBuffer buffer = new StringBuffer("List of locations:\n");
 93  149 for (int i = 0; i < list.size(); i++) {
 94  146 if (i != 0) {
 95  6 buffer.append("\n");
 96    }
 97  146 buffer.append((i + 1) + ":\t");
 98  146 buffer.append(get(i) != null ? get(i).toString() : null);
 99    }
 100  149 return buffer.toString();
 101    }
 102   
 103    }