Recover reader from process restart

This commit is contained in:
inorichi 2015-12-09 14:55:32 +01:00
parent e1b68f66f2
commit 39d3033d44
5 changed files with 35 additions and 46 deletions

View file

@ -3,11 +3,13 @@ package eu.kanade.mangafeed.data.database.models;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType;
import java.io.Serializable;
import eu.kanade.mangafeed.data.database.tables.ChapterTable; import eu.kanade.mangafeed.data.database.tables.ChapterTable;
import eu.kanade.mangafeed.util.UrlUtil; import eu.kanade.mangafeed.util.UrlUtil;
@StorIOSQLiteType(table = ChapterTable.TABLE) @StorIOSQLiteType(table = ChapterTable.TABLE)
public class Chapter { public class Chapter implements Serializable {
@StorIOSQLiteColumn(name = ChapterTable.COLUMN_ID, key = true) @StorIOSQLiteColumn(name = ChapterTable.COLUMN_ID, key = true)
public Long id; public Long id;

View file

@ -3,11 +3,13 @@ package eu.kanade.mangafeed.data.database.models;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType;
import java.io.Serializable;
import eu.kanade.mangafeed.data.database.tables.MangaTable; import eu.kanade.mangafeed.data.database.tables.MangaTable;
import eu.kanade.mangafeed.util.UrlUtil; import eu.kanade.mangafeed.util.UrlUtil;
@StorIOSQLiteType(table = MangaTable.TABLE) @StorIOSQLiteType(table = MangaTable.TABLE)
public class Manga { public class Manga implements Serializable {
@StorIOSQLiteColumn(name = MangaTable.COLUMN_ID, key = true) @StorIOSQLiteColumn(name = MangaTable.COLUMN_ID, key = true)
public Long id; public Long id;

View file

@ -1,17 +0,0 @@
package eu.kanade.mangafeed.event;
import eu.kanade.mangafeed.data.source.model.Page;
public class RetryPageEvent {
private Page page;
public RetryPageEvent(Page page) {
this.page = page;
}
public Page getPage() {
return page;
}
}

View file

@ -17,9 +17,9 @@ import eu.kanade.mangafeed.data.database.models.ChapterSync;
import eu.kanade.mangafeed.data.database.models.Manga; import eu.kanade.mangafeed.data.database.models.Manga;
import eu.kanade.mangafeed.data.download.DownloadManager; import eu.kanade.mangafeed.data.download.DownloadManager;
import eu.kanade.mangafeed.data.preference.PreferencesHelper; import eu.kanade.mangafeed.data.preference.PreferencesHelper;
import eu.kanade.mangafeed.data.source.SourceManager;
import eu.kanade.mangafeed.data.source.base.Source; import eu.kanade.mangafeed.data.source.base.Source;
import eu.kanade.mangafeed.data.source.model.Page; import eu.kanade.mangafeed.data.source.model.Page;
import eu.kanade.mangafeed.event.RetryPageEvent;
import eu.kanade.mangafeed.event.ReaderEvent; import eu.kanade.mangafeed.event.ReaderEvent;
import eu.kanade.mangafeed.event.UpdateChapterSyncEvent; import eu.kanade.mangafeed.event.UpdateChapterSyncEvent;
import eu.kanade.mangafeed.ui.base.presenter.BasePresenter; import eu.kanade.mangafeed.ui.base.presenter.BasePresenter;
@ -38,16 +38,18 @@ public class ReaderPresenter extends BasePresenter<ReaderActivity> {
@Inject DatabaseHelper db; @Inject DatabaseHelper db;
@Inject DownloadManager downloadManager; @Inject DownloadManager downloadManager;
@Inject ChapterSyncManager syncManager; @Inject ChapterSyncManager syncManager;
@Inject SourceManager sourceManager;
@State Manga manga;
@State Chapter chapter;
@State int sourceId;
@State boolean isDownloaded;
@State int currentPage;
private Source source; private Source source;
private Manga manga;
private Chapter chapter;
private Chapter nextChapter; private Chapter nextChapter;
private Chapter previousChapter; private Chapter previousChapter;
private List<Page> pageList; private List<Page> pageList;
private List<Page> nextChapterPageList; private List<Page> nextChapterPageList;
private boolean isDownloaded;
@State int currentPage;
private PublishSubject<Page> retryPageSubject; private PublishSubject<Page> retryPageSubject;
@ -63,6 +65,10 @@ public class ReaderPresenter extends BasePresenter<ReaderActivity> {
protected void onCreate(Bundle savedState) { protected void onCreate(Bundle savedState) {
super.onCreate(savedState); super.onCreate(savedState);
if (savedState != null) {
onProcessRestart();
}
retryPageSubject = PublishSubject.create(); retryPageSubject = PublishSubject.create();
restartableLatestCache(GET_PAGE_LIST, restartableLatestCache(GET_PAGE_LIST,
@ -97,42 +103,35 @@ public class ReaderPresenter extends BasePresenter<ReaderActivity> {
this::getPreloadNextChapterObservable, this::getPreloadNextChapterObservable,
(view, pages) -> {}, (view, pages) -> {},
(view, error) -> Timber.e("An error occurred while preloading a chapter")); (view, error) -> Timber.e("An error occurred while preloading a chapter"));
}
@Override
protected void onTakeView(ReaderActivity view) {
super.onTakeView(view);
registerForStickyEvents(); registerForStickyEvents();
} }
@Override
protected void onDropView() {
unregisterForEvents();
super.onDropView();
}
@Override @Override
protected void onDestroy() { protected void onDestroy() {
unregisterForEvents();
onChapterLeft(); onChapterLeft();
super.onDestroy(); super.onDestroy();
} }
private void onProcessRestart() {
source = sourceManager.get(sourceId);
// These are started by GET_PAGE_LIST, so we don't let them restart itselves
stop(GET_PAGE_IMAGES);
stop(RETRY_IMAGES);
stop(PRELOAD_NEXT_CHAPTER);
}
@EventBusHook @EventBusHook
public void onEventMainThread(ReaderEvent event) { public void onEventMainThread(ReaderEvent event) {
EventBus.getDefault().removeStickyEvent(event); EventBus.getDefault().removeStickyEvent(event);
source = event.getSource();
manga = event.getManga(); manga = event.getManga();
source = event.getSource();
sourceId = source.getSourceId();
loadChapter(event.getChapter()); loadChapter(event.getChapter());
} }
@EventBusHook
public void onEventMainThread(RetryPageEvent event) {
EventBus.getDefault().removeStickyEvent(event);
Page page = event.getPage();
page.setStatus(Page.QUEUE);
retryPageSubject.onNext(page);
}
// Returns the page list of a chapter // Returns the page list of a chapter
private Observable<List<Page>> getPageListObservable() { private Observable<List<Page>> getPageListObservable() {
return isDownloaded ? return isDownloaded ?
@ -216,6 +215,11 @@ public class ReaderPresenter extends BasePresenter<ReaderActivity> {
return downloadManager.isChapterDownloaded(source, manga, chapter); return downloadManager.isChapterDownloaded(source, manga, chapter);
} }
public void retryPage(Page page) {
page.setStatus(Page.QUEUE);
retryPageSubject.onNext(page);
}
// Called before loading another chapter or leaving the reader. It allows to do operations // Called before loading another chapter or leaving the reader. It allows to do operations
// over the chapter read like saving progress // over the chapter read like saving progress
private void onChapterLeft() { private void onChapterLeft() {

View file

@ -19,10 +19,8 @@ import java.util.concurrent.atomic.AtomicInteger;
import butterknife.Bind; import butterknife.Bind;
import butterknife.ButterKnife; import butterknife.ButterKnife;
import de.greenrobot.event.EventBus;
import eu.kanade.mangafeed.R; import eu.kanade.mangafeed.R;
import eu.kanade.mangafeed.data.source.model.Page; import eu.kanade.mangafeed.data.source.model.Page;
import eu.kanade.mangafeed.event.RetryPageEvent;
import eu.kanade.mangafeed.ui.base.fragment.BaseFragment; import eu.kanade.mangafeed.ui.base.fragment.BaseFragment;
import eu.kanade.mangafeed.ui.reader.ReaderActivity; import eu.kanade.mangafeed.ui.reader.ReaderActivity;
import rx.Observable; import rx.Observable;
@ -63,7 +61,7 @@ public class ViewPagerReaderFragment extends BaseFragment {
retryButton.setOnTouchListener((v, event) -> { retryButton.setOnTouchListener((v, event) -> {
if (event.getAction() == MotionEvent.ACTION_UP) { if (event.getAction() == MotionEvent.ACTION_UP) {
if (page != null) if (page != null)
EventBus.getDefault().postSticky(new RetryPageEvent(page)); ((ReaderActivity) getActivity()).getPresenter().retryPage(page);
return true; return true;
} }
return true; return true;