From ed30ae01598dd49a7d9303ba803a4b56dc606fd0 Mon Sep 17 00:00:00 2001 From: Reinhard Pointner Date: Sun, 7 Apr 2013 08:22:41 +0000 Subject: [PATCH] * cache series ratings internally for likely repeated usage --- .../filebot/similarity/EpisodeMetrics.java | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/source/net/sourceforge/filebot/similarity/EpisodeMetrics.java b/source/net/sourceforge/filebot/similarity/EpisodeMetrics.java index b3168096..dd1e93b3 100644 --- a/source/net/sourceforge/filebot/similarity/EpisodeMetrics.java +++ b/source/net/sourceforge/filebot/similarity/EpisodeMetrics.java @@ -465,13 +465,24 @@ public enum EpisodeMetrics implements SimilarityMetric { return max(getRating(o1), getRating(o2)) >= 0.4 ? 1 : 0; } + private final Map seriesInfoCache = new HashMap(); + public float getRating(Object o) { if (o instanceof Episode) { try { - SeriesInfo seriesInfo = WebServices.TheTVDB.getSeriesInfoByLocalIndex(((Episode) o).getSeriesName(), Locale.ENGLISH); - if (seriesInfo != null && seriesInfo.getRatingCount() >= 10) { - return max(0, seriesInfo.getRating().floatValue()); + synchronized (seriesInfoCache) { + String n = ((Episode) o).getSeriesName(); + + SeriesInfo seriesInfo = seriesInfoCache.get(n); + if (seriesInfo == null && !seriesInfoCache.containsKey(n)) { + seriesInfo = WebServices.TheTVDB.getSeriesInfoByLocalIndex(((Episode) o).getSeriesName(), Locale.ENGLISH); + seriesInfoCache.put(n, seriesInfo); + } + + if (seriesInfo != null && seriesInfo.getRatingCount() >= 10) { + return max(0, seriesInfo.getRating().floatValue()); + } } } catch (Exception e) { Logger.getLogger(EpisodeMetrics.class.getName()).log(Level.WARNING, e.getMessage());