1
0
mirror of https://github.com/mitb-archive/filebot synced 2025-01-02 09:28:09 -05:00

* Improved support for mapping episode information between different databases and numbering schemes (e.g. via AnimeLists or XEM)

This commit is contained in:
Reinhard Pointner 2019-06-10 02:28:37 +07:00
parent 265eef6200
commit 6b1645e6dd
4 changed files with 29 additions and 40 deletions

View File

@ -1,7 +1,7 @@
Next Release (4.8.6) Next Release (4.8.6)
==================== ====================
* Enhanced `Selection Dialog` with thumbnails and tooltips * Enhanced `Selection Dialog` with thumbnails and tooltips
* Improved support for mapping episode information between different databases and numbering schemes * Improved support for mapping episode information between different databases and numbering schemes (e.g. via `AnimeLists` or `XEM`)
* Added `{history}` binding for looking up the original file path of `{f}` (e.g. useful for `-exec` post-processing commands) * Added `{history}` binding for looking up the original file path of `{f}` (e.g. useful for `-exec` post-processing commands)
* Evaluate `{closures}` automatically in `String.plus(Closure)` constructs (e.g. `{"[" + {n} + " " + {s00e00} + "]"}`) * Evaluate `{closures}` automatically in `String.plus(Closure)` constructs (e.g. `{"[" + {n} + " " + {s00e00} + "]"}`)
* Ensure that `ActionPopup` is always displayed on top of the Windows Task Bar * Ensure that `ActionPopup` is always displayed on top of the Windows Task Bar
@ -11,7 +11,7 @@ Next Release (4.8.6)
* Allow `@file.groovy` syntax in `Format Editor` and `Preset Editor` (e.g. `@/path/to/MyFormat.groovy`) * Allow `@file.groovy` syntax in `Format Editor` and `Preset Editor` (e.g. `@/path/to/MyFormat.groovy`)
* Added `--mapper` option (e.g. `--mapper XEM.TheTVDB`) * Added `--mapper` option (e.g. `--mapper XEM.TheTVDB`)
* Allow `*.groovy` files as argument value for `--format`, `--filter`, `--mapper` and `--file-filter` CLI options (e.g. `--format /path/to/MyFormat.groovy`) * Allow `*.groovy` files as argument value for `--format`, `--filter`, `--mapper` and `--file-filter` CLI options (e.g. `--format /path/to/MyFormat.groovy`)
* Support [bash completion](installer/bash/filebot_completion) * Support `bash_completion`
FileBot 4.8.5 FileBot 4.8.5

View File

@ -36,7 +36,10 @@ public enum AnimeLists {
AniDB, TheTVDB; AniDB, TheTVDB;
public Optional<Episode> map(Episode episode, AnimeLists destination) throws Exception { public Optional<Episode> map(Episode episode, AnimeLists destination) throws Exception {
return find(episode.getSeriesInfo().getId()).map(a -> { int id = episode.getSeriesInfo().getId();
int series = getSeasonNumber(episode);
return find(id, series).map(a -> {
// auto-align mode // auto-align mode
if (a.defaulttvdbseason == null) { if (a.defaulttvdbseason == null) {
try { try {
@ -57,7 +60,7 @@ public enum AnimeLists {
if (s == getSeason(m)) { if (s == getSeason(m)) {
Optional<Integer> episodeMapping = destination.getEpisodeNumber(m, e); Optional<Integer> episodeMapping = destination.getEpisodeNumber(m, e);
if (episodeMapping.isPresent()) { if (episodeMapping.isPresent()) {
return derive(episode, destination.getSeason(m), episodeMapping.get()); return destination.derive(a, episode, destination.getSeason(m), episodeMapping.get());
} }
} }
} }
@ -69,16 +72,22 @@ public enum AnimeLists {
// apply episode offset // apply episode offset
e += destination.getEpisodeNumberOffset(a); e += destination.getEpisodeNumberOffset(a);
return derive(episode, s, e); return destination.derive(a, episode, s, e);
}); }).findFirst();
} }
private Episode derive(Episode episode, int s, int e) { private Episode derive(Entry a, Episode episode, int s, int e) {
return s == 0 ? episode.deriveSpecial(e) : episode.derive(s, e); if (s == 0) {
// special
return this == AniDB ? episode.derive(a.name, null, null, null, e) : episode.deriveSpecial(e);
} else {
// regular
return this == AniDB ? episode.derive(a.name, null, e, null, null) : episode.derive(s, e);
}
} }
public Optional<Integer> map(int id, AnimeLists destination) throws Exception { public Optional<Integer> map(int id, int s, AnimeLists destination) throws Exception {
return find(id).map(destination::getId); return find(id, s).map(destination::getId).findFirst();
} }
protected Episode mapAutoAligned(Entry a, Episode episode) throws Exception { protected Episode mapAutoAligned(Entry a, Episode episode) throws Exception {
@ -113,7 +122,7 @@ public enum AnimeLists {
protected int getSeasonNumber(Episode e) { protected int getSeasonNumber(Episode e) {
// special episode // special episode
if (e.getSpecial() != null) { if (e.isSpecial()) {
return 0; return 0;
} }
@ -127,7 +136,7 @@ public enum AnimeLists {
} }
protected int getEpisodeNumber(Episode e) { protected int getEpisodeNumber(Episode e) {
return e.getSpecial() != null ? e.getSpecial() : e.getEpisode(); return e.isSpecial() ? e.getSpecial() : e.getEpisode();
} }
protected int getSeason(Mapping m) { protected int getSeason(Mapping m) {
@ -135,7 +144,7 @@ public enum AnimeLists {
} }
protected int getSeason(Entry a, Episode e) { protected int getSeason(Entry a, Episode e) {
return e.getSpecial() != null ? 0 : this == AniDB ? 1 : a.defaulttvdbseason; return e.isSpecial() ? 0 : this == AniDB ? 1 : a.defaulttvdbseason;
} }
protected int getId(Entry a) { protected int getId(Entry a) {
@ -146,8 +155,12 @@ public enum AnimeLists {
return a.anidbid != null && a.tvdbid != null; return a.anidbid != null && a.tvdbid != null;
} }
public Optional<Entry> find(int id) throws Exception { public Stream<Entry> find(int id) throws Exception {
return stream(MODEL.get().anime).filter(this::isValid).filter(a -> id == getId(a)).findFirst(); return stream(MODEL.get().anime).filter(this::isValid).filter(a -> id == getId(a));
}
public Stream<Entry> find(int id, int s) throws Exception {
return this == AniDB ? find(id) : find(id).filter(a -> a.defaulttvdbseason == null || s == a.defaulttvdbseason);
} }
protected static Cache getCache() { protected static Cache getCache() {
@ -294,24 +307,4 @@ public enum AnimeLists {
throw new IllegalArgumentException(String.format("%s not in %s", name, asList(values()))); throw new IllegalArgumentException(String.format("%s not in %s", name, asList(values())));
} }
public static void main(String[] args) throws Exception {
System.out.println(AnimeLists.AniDB.map(9183, AnimeLists.TheTVDB));
List<Episode> episodes = WebServices.AniDB.getEpisodeList(9183, SortOrder.Absolute, Locale.ENGLISH);
for (Episode episode : episodes) {
System.out.println("\n" + episode);
System.out.println(AnimeLists.AniDB.map(episode, AnimeLists.TheTVDB).get());
}
System.out.println("----------------------------");
List<Episode> episodes2 = WebServices.TheTVDB.getEpisodeList(102261, SortOrder.Airdate, Locale.ENGLISH);
for (Episode episode : episodes2) {
System.out.println("\n" + episode);
System.out.println(AnimeLists.TheTVDB.map(episode, AnimeLists.AniDB).get());
}
System.exit(0);
}
} }

View File

@ -153,10 +153,6 @@ public class Episode implements Serializable {
return derive(getSeriesName(), getSeason(), null, getAbsolute(), special); return derive(getSeriesName(), getSeason(), null, getAbsolute(), special);
} }
public Episode derive(String seriesName, Integer season, Integer episode, Integer absolute) {
return derive(seriesName, season, episode, absolute, null);
}
public Episode derive(String seriesName, Integer season, Integer episode, Integer absolute, Integer special) { public Episode derive(String seriesName, Integer season, Integer episode, Integer absolute, Integer special) {
return new Episode(seriesName, season, episode, getTitle(), absolute, special, getAirdate(), getId(), getSeriesInfo()); return new Episode(seriesName, season, episode, getTitle(), absolute, special, getAirdate(), getId(), getSeriesInfo());
} }

View File

@ -74,7 +74,7 @@ public enum XEM {
Integer e = getInteger(mappedNumbers, "episode"); Integer e = getInteger(mappedNumbers, "episode");
Integer a = getInteger(mappedNumbers, "absolute"); Integer a = getInteger(mappedNumbers, "absolute");
return episode.derive(mappedSeriesName, mappedSeason, e, a); return episode.derive(mappedSeriesName, mappedSeason, e, a, null);
}).collect(toList()); }).collect(toList());
if (mappedEpisode.size() == 1) { if (mappedEpisode.size() == 1) {