From fdf59bc21ade5e8721ea83ddce06990025981f52 Mon Sep 17 00:00:00 2001 From: Jean-Yves Tinevez Date: Thu, 12 Dec 2024 15:55:22 +0100 Subject: [PATCH] Implement equals() for FeatureFilter. Important if we want to decide whether a filter is present in a collection or not. --- .../trackmate/features/FeatureFilter.java | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/main/java/fiji/plugin/trackmate/features/FeatureFilter.java b/src/main/java/fiji/plugin/trackmate/features/FeatureFilter.java index 6d2ca0142..ee0d0b599 100644 --- a/src/main/java/fiji/plugin/trackmate/features/FeatureFilter.java +++ b/src/main/java/fiji/plugin/trackmate/features/FeatureFilter.java @@ -21,6 +21,9 @@ */ package fiji.plugin.trackmate.features; +import org.apache.commons.lang3.builder.EqualsBuilder; +import org.apache.commons.lang3.builder.HashCodeBuilder; + /** * A helper class to store a feature filter. It is just made of 3 public fields. *

@@ -55,4 +58,31 @@ public String toString() return str; } + @Override + public boolean equals( final Object obj ) + { + if ( obj == null ) + return false; + if ( obj == this ) + return true; + if ( obj.getClass() != getClass() ) + return false; + final FeatureFilter other = ( FeatureFilter ) obj; + return new EqualsBuilder() + .append( feature, other.feature ) + .append( value, other.value ) + .append( isAbove, other.isAbove ) + .isEquals(); + } + + @Override + public int hashCode() + { + return new HashCodeBuilder( 17, 37 ) + .append( feature ) + .append( value ) + .append( isAbove ) + .toHashCode(); + } + }