From 3baf2b6ab3c4df82bccea59e599e2d8d4cf70363 Mon Sep 17 00:00:00 2001 From: Mark Raynsford Date: Fri, 5 Apr 2024 15:57:44 +0000 Subject: [PATCH] Don't treat partial failures as complete failures Some books still have resources that cannot be opened. These resources should not cause the entire chapter request to fail. Affects: https://ebce-lyrasis.atlassian.net/browse/PP-1120 Affects: https://ebce-lyrasis.atlassian.net/browse/PP-1119 --- .../r2/vanilla/internal/SR2Controller.kt | 20 ++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/org.librarysimplified.r2.vanilla/src/main/java/org/librarysimplified/r2/vanilla/internal/SR2Controller.kt b/org.librarysimplified.r2.vanilla/src/main/java/org/librarysimplified/r2/vanilla/internal/SR2Controller.kt index f1aee3f..f627b9b 100644 --- a/org.librarysimplified.r2.vanilla/src/main/java/org/librarysimplified/r2/vanilla/internal/SR2Controller.kt +++ b/org.librarysimplified.r2.vanilla/src/main/java/org/librarysimplified/r2/vanilla/internal/SR2Controller.kt @@ -585,8 +585,8 @@ internal class SR2Controller private constructor( */ val link = apiCommand.link - if (apiCommand.link.startsWith(org.librarysimplified.r2.vanilla.internal.SR2Controller.Companion.PREFIX_PUBLICATION)) { - val target = Href(link.removePrefix(org.librarysimplified.r2.vanilla.internal.SR2Controller.Companion.PREFIX_PUBLICATION))!! + if (apiCommand.link.startsWith(PREFIX_PUBLICATION)) { + val target = Href(link.removePrefix(PREFIX_PUBLICATION))!! this.submitCommand(SR2Command.OpenChapter(SR2LocatorPercent(target, 0.0))) return CompletableFuture.completedFuture(Unit) } @@ -651,18 +651,20 @@ internal class SR2Controller private constructor( val chapterURL = this.currentNavigationIntent.chapterHref val resolvedURL = - chapterURL.resolve(Url(org.librarysimplified.r2.vanilla.internal.SR2Controller.Companion.PREFIX_PUBLICATION)) + chapterURL.resolve(Url(PREFIX_PUBLICATION)) val future = connection.openURL(resolvedURL.toString()) - .thenCompose { - this.executeThemeSet(connection, this.themeMostRecent) - } - .thenCompose { + .handle { _, exception -> + this.debug("Failed to completely open URL: ", exception) + }.thenCompose { connection.executeJS { js -> js.setScrollMode(this.configuration.scrollingMode) } - } - .thenCompose { + }.handle { _, exception -> + this.debug("Failed to set scroll mode: ", exception) + }.thenCompose { this.executeLocatorSet(connection, this.currentNavigationIntent) + }.handle { _, exception -> + this.debug("Failed to scroll to navigation intent: ", exception) } /*