* improved substring matching for instances like Doctor Who vs Doctor Who (2005), The Office vs The Office (US), etc

This commit is contained in:
Reinhard Pointner 2011-10-28 08:07:02 +00:00
parent 93d2e0f379
commit 1f0d9214fb
9 changed files with 29 additions and 15 deletions

View File

@ -5,6 +5,7 @@ package net.sourceforge.filebot.ui.rename;
import static java.util.Collections.*; import static java.util.Collections.*;
import static javax.swing.JOptionPane.*; import static javax.swing.JOptionPane.*;
import static net.sourceforge.filebot.MediaTypes.*; import static net.sourceforge.filebot.MediaTypes.*;
import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.tuned.FileUtilities.*; import static net.sourceforge.tuned.FileUtilities.*;
import static net.sourceforge.tuned.ui.TunedUtilities.*; import static net.sourceforge.tuned.ui.TunedUtilities.*;
@ -65,7 +66,7 @@ class EpisodeListMatcher implements AutoCompleteMatcher {
// find probable matches using name similarity > 0.9 // find probable matches using name similarity > 0.9
for (SearchResult result : searchResults) { for (SearchResult result : searchResults) {
if (metric.getSimilarity(normalize(query), normalize(result.getName())) > 0.9) { if (metric.getSimilarity(normalizeName(query), normalizeName(result.getName())) > 0.9) {
probableMatches.add(result); probableMatches.add(result);
} }
} }
@ -107,9 +108,9 @@ class EpisodeListMatcher implements AutoCompleteMatcher {
} }
private String normalize(String value) { private String normalizeName(String value) {
// remove trailing braces, e.g. Doctor Who (2005) -> doctor who // remove trailing braces, e.g. Doctor Who (2005) -> doctor who
return value.replaceAll("[(]([^)]*)[)]", "").trim().toLowerCase(); return removeTrailingBraces(value).toLowerCase();
} }

View File

@ -4,6 +4,7 @@ package net.sourceforge.filebot.ui.rename;
import static java.lang.Math.*; import static java.lang.Math.*;
import static net.sourceforge.filebot.hash.VerificationUtilities.*; import static net.sourceforge.filebot.hash.VerificationUtilities.*;
import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.tuned.FileUtilities.*; import static net.sourceforge.tuned.FileUtilities.*;
import java.io.File; import java.io.File;
@ -22,6 +23,7 @@ import net.sourceforge.filebot.similarity.SeasonEpisodeMatcher.SxE;
import net.sourceforge.filebot.vfs.AbstractFile; import net.sourceforge.filebot.vfs.AbstractFile;
import net.sourceforge.filebot.web.Date; import net.sourceforge.filebot.web.Date;
import net.sourceforge.filebot.web.Episode; import net.sourceforge.filebot.web.Episode;
import net.sourceforge.filebot.web.Movie;
public enum MatchSimilarityMetric implements SimilarityMetric { public enum MatchSimilarityMetric implements SimilarityMetric {
@ -121,8 +123,8 @@ public enum MatchSimilarityMetric implements SimilarityMetric {
protected String[] fields(Object object) { protected String[] fields(Object object) {
if (object instanceof Episode) { if (object instanceof Episode) {
Episode e = (Episode) object; Episode episode = (Episode) object;
return new String[] { e.getSeriesName(), e.getTitle() }; return new String[] { removeTrailingBraces(episode.getSeriesName()), episode.getTitle() };
} }
if (object instanceof File) { if (object instanceof File) {
@ -130,6 +132,16 @@ public enum MatchSimilarityMetric implements SimilarityMetric {
return new String[] { getName(file.getParentFile()), getName(file) }; return new String[] { getName(file.getParentFile()), getName(file) };
} }
if (object instanceof Movie) {
Movie movie = (Movie) object;
return new String[] { movie.getName(), Integer.toString(movie.getYear()) };
}
if (object instanceof AbstractFile) {
AbstractFile file = (AbstractFile) object;
return new String[] { getNameWithoutExtension(file.getName()) };
}
return new String[] { object.toString() }; return new String[] { object.toString() };
} }

View File

@ -2,7 +2,7 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import static net.sourceforge.filebot.web.EpisodeListUtilities.*; import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;

View File

@ -2,7 +2,7 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import static net.sourceforge.filebot.web.EpisodeListUtilities.*; import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.filebot.web.WebRequest.*; import static net.sourceforge.filebot.web.WebRequest.*;
import static net.sourceforge.tuned.XPathUtilities.*; import static net.sourceforge.tuned.XPathUtilities.*;

View File

@ -2,7 +2,7 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import static net.sourceforge.filebot.web.EpisodeListUtilities.*; import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.filebot.web.WebRequest.*; import static net.sourceforge.filebot.web.WebRequest.*;
import java.io.IOException; import java.io.IOException;

View File

@ -2,7 +2,7 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import static net.sourceforge.filebot.web.EpisodeListUtilities.*; import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.filebot.web.WebRequest.*; import static net.sourceforge.filebot.web.WebRequest.*;
import static net.sourceforge.tuned.XPathUtilities.*; import static net.sourceforge.tuned.XPathUtilities.*;

View File

@ -2,7 +2,7 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import static net.sourceforge.filebot.web.EpisodeListUtilities.*; import static net.sourceforge.filebot.web.EpisodeUtilities.*;
import static net.sourceforge.filebot.web.WebRequest.*; import static net.sourceforge.filebot.web.WebRequest.*;
import static net.sourceforge.tuned.XPathUtilities.*; import static net.sourceforge.tuned.XPathUtilities.*;

View File

@ -37,11 +37,6 @@ public final class StringUtilities {
} }
public static boolean isNullOrEmpty(String value) {
return value == null || value.isEmpty();
}
/** /**
* Dummy constructor to prevent instantiation. * Dummy constructor to prevent instantiation.
*/ */

View File

@ -12,6 +12,7 @@ AiRWAVES
ALLiANCE ALLiANCE
ANiHLS ANiHLS
ARiGOLD ARiGOLD
ASAP
AW AW
aWake aWake
aXXo aXXo
@ -72,6 +73,7 @@ DiVERSiTY
DivXNL-Team DivXNL-Team
DMT DMT
DnB DnB
DNL
DOT DOT
DOWN DOWN
ELECTRiC ELECTRiC
@ -80,6 +82,7 @@ EnDoR
ESiR ESiR
ETM ETM
EUHD EUHD
EuReKA
ExtraTorrentRG ExtraTorrentRG
FHM FHM
FLAiTE FLAiTE
@ -110,6 +113,7 @@ HDFiRE
HDFL HDFL
HDi HDi
HDL HDL
HDMaNiAcS
HDMI HDMI
HDQ HDQ
HDVD HDVD
@ -140,6 +144,7 @@ JAVLiU
k2 k2
KaKa KaKa
KOENiG KOENiG
KRaLiMaRKo
KYR KYR
Larceny Larceny
LEViTY LEViTY
@ -262,6 +267,7 @@ VanRay
VCDVaULT VCDVaULT
ViNYL ViNYL
ViSiON ViSiON
ViSTA
VOA VOA
VoMiT VoMiT
VoX VoX