X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Frhynodge%2Ffilters%2FComicSiteFilter.java;h=0b52045f241758b98b8742b5af9f87348a5d1bab;hb=f78a78032ee008d2e8c3a669ead89485ea60c0f3;hp=fec856c6b15574db7b58f307dc2f84156c8fe20a;hpb=18f582bf98ae3957f1ba55a024961c1519eed54e;p=rhynodge.git diff --git a/src/main/java/net/pterodactylus/rhynodge/filters/ComicSiteFilter.java b/src/main/java/net/pterodactylus/rhynodge/filters/ComicSiteFilter.java index fec856c..0b52045 100644 --- a/src/main/java/net/pterodactylus/rhynodge/filters/ComicSiteFilter.java +++ b/src/main/java/net/pterodactylus/rhynodge/filters/ComicSiteFilter.java @@ -17,14 +17,17 @@ package net.pterodactylus.rhynodge.filters; -import static com.google.common.base.Preconditions.*; +import static com.google.common.base.Preconditions.checkArgument; +import java.net.URI; +import java.net.URISyntaxException; import java.util.List; import net.pterodactylus.rhynodge.Filter; import net.pterodactylus.rhynodge.State; import net.pterodactylus.rhynodge.states.ComicState; import net.pterodactylus.rhynodge.states.ComicState.Comic; +import net.pterodactylus.rhynodge.states.ComicState.Strip; import net.pterodactylus.rhynodge.states.HtmlState; import com.google.common.base.Optional; @@ -49,12 +52,22 @@ public abstract class ComicSiteFilter implements Filter { /* extract comics. */ Optional title = extractTitle(htmlState.document()); List imageUrls = extractImageUrls(htmlState.document()); + List imageComments = extractImageComments(htmlState.document()); /* store comic, if found, into state. */ if (title.isPresent() && !imageUrls.isEmpty()) { Comic comic = new Comic(title.get()); + int imageCounter = 0; for (String imageUrl : imageUrls) { - comic.addImageUrl(imageUrl); + String imageComment = (imageCounter < imageComments.size()) ? imageComments.get(imageCounter) : ""; + try { + URI stripUri = new URI(htmlState.uri()).resolve(imageUrl); + Strip strip = new Strip(stripUri.toString(), imageComment); + imageCounter++; + comic.add(strip); + } catch (URISyntaxException use1) { + throw new IllegalStateException(String.format("Could not resolve image URL “%s” against base URL “%s”.", imageUrl, htmlState.uri()), use1); + } } comicState.add(comic); }