mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-18 16:27:34 +01:00
[reader] Added detection of rich text files (.urt) TODO: parse differently this files
This commit is contained in:
@@ -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() {
|
||||
|
||||
@@ -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;
|
||||
|
||||
@@ -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) {
|
||||
|
||||
@@ -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;
|
||||
|
||||
@@ -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() {
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user