X-Git-Url: http://git.nikiroo.be/?p=nikiroo-utils.git;a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Fdata%2FMetaData.java;h=b2217ae3f4b721d235d7ee830c611514b68c9b90;hp=d72b55732adde9098b98914968f0196c3abc0562;hb=aa8b74a318769354c5cb512ead428beb372503a2;hpb=16a81ef7656c5c692fb831927e75edde25dd77a0 diff --git a/src/be/nikiroo/fanfix/data/MetaData.java b/src/be/nikiroo/fanfix/data/MetaData.java index d72b557..b2217ae 100644 --- a/src/be/nikiroo/fanfix/data/MetaData.java +++ b/src/be/nikiroo/fanfix/data/MetaData.java @@ -380,8 +380,35 @@ public class MetaData implements Cloneable, Comparable { @Override public int compareTo(MetaData o) { - String oUuid = o == null ? null : o.getUuid(); - return getUuid().compareTo(oUuid); + if (o == null) { + return 1; + } + + String id = (getUuid() == null ? "" : getUuid()) + + (getLuid() == null ? "" : getLuid()); + String oId = (getUuid() == null ? "" : o.getUuid()) + + (o.getLuid() == null ? "" : o.getLuid()); + + return id.compareTo(oId); + } + + @Override + public boolean equals(Object obj) { + if (!(obj instanceof MetaData)) { + return false; + } + + return compareTo((MetaData) obj) == 0; + } + + @Override + public int hashCode() { + String uuid = getUuid(); + if (uuid == null) { + uuid = "" + title + author + source; + } + + return uuid.hashCode(); } @Override