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:
parent
265eef6200
commit
6b1645e6dd
@ -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
|
||||||
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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());
|
||||||
}
|
}
|
||||||
|
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user