[reader] Added detection of rich text files (.urt) TODO: parse differently this files

This commit is contained in:
Laury
2021-12-13 21:54:25 +01:00
parent 2248e415c4
commit 7fc28f8b72
6 changed files with 31 additions and 21 deletions

View File

@@ -15,12 +15,13 @@ ListBookController::ListBookController(Responder * parentResponder):
m_tableView(this, this, this),
m_readBookController(this)
{
m_filesNumber = filesWithExtension(".txt", m_files, k_maxFilesNumber);
m_txtFilesNumber = filesWithExtension(".txt", m_files, k_maxFilesNumber);
m_urtFilesNumber = filesWithExtension(".urt", m_files + m_txtFilesNumber, k_maxFilesNumber - m_txtFilesNumber);
cleanRemovedBookRecord();
}
int ListBookController::numberOfRows() const {
return m_filesNumber;
return m_txtFilesNumber + m_urtFilesNumber;
}
KDCoordinate ListBookController::cellHeight() {
@@ -52,7 +53,7 @@ void ListBookController::didBecomeFirstResponder() {
bool ListBookController::handleEvent(Ion::Events::Event event) {
if (event == Ion::Events::OK || event == Ion::Events::EXE || event == Ion::Events::Right)
{
m_readBookController.setBook(m_files[selectedRow()]);
m_readBookController.setBook(m_files[selectedRow()], selectedRow() >= m_txtFilesNumber);
static_cast<StackViewController*>(parentResponder())->push(&m_readBookController);
Container::activeApp()->setFirstResponder(&m_readBookController);
return true;
@@ -63,10 +64,9 @@ bool ListBookController::handleEvent(Ion::Events::Event event) {
bool ListBookController::hasBook(const char* filename) const {
for(int i=0;i<m_filesNumber;i++)
for(int i=0;i<m_txtFilesNumber + m_urtFilesNumber;i++)
{
if(strcmp(m_files[i].name, filename) == 0)
{
if(strcmp(m_files[i].name, filename) == 0) {
return true;
}
}
@@ -75,18 +75,24 @@ bool ListBookController::hasBook(const char* filename) const {
void ListBookController::cleanRemovedBookRecord() {
int nb = Ion::Storage::sharedStorage()->numberOfRecordsWithExtension("txt");
for(int i=0; i<nb; i++)
{
Ion::Storage::Record r = Ion::Storage::sharedStorage()->recordWithExtensionAtIndex("txt", i);
if(!hasBook(r.fullName()))
{
r.destroy();
for(int i=0; i<nb; i++) {
Ion::Storage::Record r = Ion::Storage::sharedStorage()->recordWithExtensionAtIndex("txt", i);
if(!hasBook(r.fullName())) {
r.destroy();
}
}
nb = Ion::Storage::sharedStorage()->numberOfRecordsWithExtension("urt");
for(int i=0; i<nb; i++) {
Ion::Storage::Record r = Ion::Storage::sharedStorage()->recordWithExtensionAtIndex("urt", i);
if(!hasBook(r.fullName())) {
r.destroy();
}
}
}
bool ListBookController::isEmpty() const {
return m_filesNumber == 0;
return m_txtFilesNumber + m_urtFilesNumber == 0;
}
I18n::Message ListBookController::emptyMessage() {

View File

@@ -31,7 +31,8 @@ private:
SelectableTableView m_tableView;
static const int k_maxFilesNumber = 20;
External::Archive::File m_files[k_maxFilesNumber];
int m_filesNumber = 0;
int m_txtFilesNumber;
int m_urtFilesNumber;
static const int k_cellsNumber = 6;
MessageTableCellWithChevron m_cells[k_cellsNumber];
ReadBookController m_readBookController;

View File

@@ -12,10 +12,10 @@ View * ReadBookController::view() {
return &m_readerView;
}
void ReadBookController::setBook(const External::Archive::File& file) {
void ReadBookController::setBook(const External::Archive::File& file, bool isRichTextFile) {
m_file = &file;
loadPosition();
m_readerView.setText(reinterpret_cast<const char*>(file.data), file.dataLength);
m_readerView.setText(reinterpret_cast<const char*>(file.data), file.dataLength, isRichTextFile);
}
bool ReadBookController::handleEvent(Ion::Events::Event event) {

View File

@@ -11,7 +11,7 @@ class ReadBookController : public ViewController {
public:
ReadBookController(Responder * parentResponder);
View * view() override;
void setBook(const External::Archive::File& file);
void setBook(const External::Archive::File& file, bool isRichTextFile);
bool handleEvent(Ion::Events::Event event) override;
void viewDidDisappear() override;
void savePosition() const;

View File

@@ -12,7 +12,8 @@ WordWrapTextView::WordWrapTextView() :
PointerTextView(GlobalPreferences::sharedGlobalPreferences()->font()),
m_pageOffset(0),
m_nextPageOffset(0),
m_length(0)
m_length(0),
m_isRichTextFile(false) // Value isn't important, it will change when the file is loaded
{
}
@@ -25,9 +26,10 @@ void WordWrapTextView::nextPage() {
markRectAsDirty(bounds());
}
void WordWrapTextView::setText(const char* text, int length) {
void WordWrapTextView::setText(const char* text, int length, bool isRichTextFile) {
PointerTextView::setText(text);
m_length = length;
m_isRichTextFile = isRichTextFile;
}
void WordWrapTextView::previousPage() {

View File

@@ -16,7 +16,7 @@ class WordWrapTextView : public PointerTextView {
public:
WordWrapTextView();
void drawRect(KDContext * ctx, KDRect rect) const override;
void setText(const char*, int length);
void setText(const char*, int length, bool isRichTextFile);
void nextPage();
void previousPage();
BookSave getBookSave() const;
@@ -28,9 +28,10 @@ private:
int m_pageOffset;
mutable int m_nextPageOffset;
int m_length;
bool m_isRichTextFile;
mutable KDColor m_textColor;
};
}
#endif
#endif