/* * FindBugs - Find Bugs in Java programs * Copyright (C) 2006, University of Maryland * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston MA 02111-1307, USA */ package edu.umd.cs.findbugs.gui2; import java.io.IOException; import java.io.Serializable; import edu.umd.cs.findbugs.BugInstance; import edu.umd.cs.findbugs.filter.Matcher; import edu.umd.cs.findbugs.gui2.BugAspects.SortableValue; import edu.umd.cs.findbugs.xml.XMLOutput; /** * Why this wasn't just called Filter is still somewhat of a mystery. * FilterMatchers are Filters, pass in a StringPair like Priority, High * and all the high priority bugs disappear, Its that easy. */ @Deprecated public class FilterMatcher implements Matcher, Serializable, Comparable<FilterMatcher> { enum FilterWhere {FILTER_EXACTLY, FILTER_AT_OR_AFTER, FILTER_AT_OR_BEFORE, FILTER_ALL_BUT}; private static final long serialVersionUID = -4859486064351510016L; private Sortables filterBy; private String value; private FilterWhere mode; protected boolean active; public FilterMatcher(SortableValue sp) { this(sp.key, sp.value); } Sortables getFilterBy() { return filterBy; } String getValue() { return value; } public FilterMatcher(Sortables filterBy, String value, FilterWhere mode) //0 = exactly; 1 = at or after; 2 = at or before; 3 = not at { this.filterBy = filterBy; this.value = value; this.mode = mode; this.active = true; } public FilterMatcher(Sortables filterBy, String value) { this.filterBy = filterBy; this.value = value; this.mode = FilterWhere.FILTER_EXACTLY; this.active = true; } public void setActive(boolean active) { if (active != this.active) { this.active = active; if (active==true) FilterActivity.notifyListeners(FilterListener.Action.FILTERING, null); else FilterActivity.notifyListeners(FilterListener.Action.UNFILTERING, null); } } public boolean isActive() { return active; } public boolean match(BugInstance bugInstance) { if (!active) return true; SortableStringComparator ssc = filterBy.getComparator(); int compare = ssc.compare(filterBy.getFrom(bugInstance), value); switch(mode) { case FILTER_EXACTLY: return (compare != 0); case FILTER_AT_OR_AFTER: return (compare < 0); case FILTER_AT_OR_BEFORE: return (compare > 0); case FILTER_ALL_BUT: return (compare == 0); default: return true; } } @Override public String toString() { switch(mode) { case FILTER_EXACTLY: return filterBy.toString() + " " + edu.umd.cs.findbugs.L10N.getLocalString("dlg.is", "is") + " " + edu.umd.cs.findbugs.L10N.getLocalString("mode.equal_to", "equal to") + " " + filterBy.formatValue(value); case FILTER_AT_OR_AFTER: return filterBy.toString() + " " + edu.umd.cs.findbugs.L10N.getLocalString("dlg.is", "is") + " " + edu.umd.cs.findbugs.L10N.getLocalString("mode.at_or_after", "at or after") + " " + filterBy.formatValue(value); case FILTER_AT_OR_BEFORE: return filterBy.toString() + " " + edu.umd.cs.findbugs.L10N.getLocalString("dlg.is", "is") + " " + edu.umd.cs.findbugs.L10N.getLocalString("mode.at_or_before", "at or before") + " " + filterBy.formatValue(value); case FILTER_ALL_BUT: return filterBy.toString() + " " + edu.umd.cs.findbugs.L10N.getLocalString("dlg.is", "is") + " " + edu.umd.cs.findbugs.L10N.getLocalString("mode.not_equal_to", "not equal to") + " " + filterBy.formatValue(value); default: throw new RuntimeException(); } } @Override public boolean equals(Object o) { if (o == null) return false; if (getClass() != o.getClass()) return false; if (filterBy.equals(((FilterMatcher)o).filterBy) && value.equals(((FilterMatcher)o).value)) return true; return false; } @Override public int hashCode() { return value.hashCode() + filterBy.hashCode(); } public int compareTo(FilterMatcher that) { if (this.filterBy != that.filterBy) return (this.filterBy.ordinal() < that.filterBy.ordinal() ? -1 : 1); return this.value.compareTo(that.value); } public void writeXML(XMLOutput xmlOutput, boolean disabled) throws IOException { throw new UnsupportedOperationException(); } }