grulich je gej
This commit is contained in:
parent
41911f7f3e
commit
44661b36d8
@ -276,6 +276,7 @@ set(APP_SOURCES
|
|||||||
src/core/feedsmodelfeed.cpp
|
src/core/feedsmodelfeed.cpp
|
||||||
src/core/feedsmodelstandardcategory.cpp
|
src/core/feedsmodelstandardcategory.cpp
|
||||||
src/core/feedsmodelstandardfeed.cpp
|
src/core/feedsmodelstandardfeed.cpp
|
||||||
|
src/core/parsingfactory.cpp
|
||||||
|
|
||||||
# Basic application sources.
|
# Basic application sources.
|
||||||
src/main.cpp
|
src/main.cpp
|
||||||
|
@ -163,6 +163,11 @@ int FeedsModel::columnCount(const QModelIndex &parent) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FeedsModelRootItem *FeedsModel::itemForIndex(const QModelIndex &index) {
|
||||||
|
FeedsModelRootItem *item = static_cast<FeedsModelRootItem*>(index.internalPointer());
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
void FeedsModel::loadFromDatabase() {
|
void FeedsModel::loadFromDatabase() {
|
||||||
qDeleteAll(m_rootItem->m_childItems);
|
qDeleteAll(m_rootItem->m_childItems);
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ class FeedsModel : public QAbstractItemModel {
|
|||||||
explicit FeedsModel(QObject *parent = 0);
|
explicit FeedsModel(QObject *parent = 0);
|
||||||
virtual ~FeedsModel();
|
virtual ~FeedsModel();
|
||||||
|
|
||||||
|
// Model implementation.
|
||||||
QVariant data(const QModelIndex &index, int role) const;
|
QVariant data(const QModelIndex &index, int role) const;
|
||||||
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
|
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
|
||||||
QModelIndex index(int row, int column, const QModelIndex &parent) const;
|
QModelIndex index(int row, int column, const QModelIndex &parent) const;
|
||||||
@ -29,6 +30,10 @@ class FeedsModel : public QAbstractItemModel {
|
|||||||
int columnCount(const QModelIndex &parent) const;
|
int columnCount(const QModelIndex &parent) const;
|
||||||
int rowCount(const QModelIndex &parent) const;
|
int rowCount(const QModelIndex &parent) const;
|
||||||
|
|
||||||
|
// Returns feed/category which lies at the specified index.
|
||||||
|
FeedsModelRootItem *itemForIndex(const QModelIndex &index);
|
||||||
|
|
||||||
|
// Loads feed/categories from the database.
|
||||||
void loadFromDatabase();
|
void loadFromDatabase();
|
||||||
|
|
||||||
// Returns all categories.
|
// Returns all categories.
|
||||||
|
@ -43,3 +43,19 @@ QString FeedsModelCategory::title() const {
|
|||||||
void FeedsModelCategory::setTitle(const QString &title) {
|
void FeedsModelCategory::setTitle(const QString &title) {
|
||||||
m_title = title;
|
m_title = title;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString FeedsModelCategory::description() const {
|
||||||
|
return m_description;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FeedsModelCategory::setDescription(const QString &description) {
|
||||||
|
m_description = description;
|
||||||
|
}
|
||||||
|
|
||||||
|
QDateTime FeedsModelCategory::creationDate() const {
|
||||||
|
return m_creationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void FeedsModelCategory::setCreationDate(const QDateTime &creation_date) {
|
||||||
|
m_creationDate = creation_date;
|
||||||
|
}
|
||||||
|
@ -1,11 +1,14 @@
|
|||||||
#ifndef FEEDSMODELCLASSICCATEGORY_H
|
#ifndef FEEDSMODELCLASSICCATEGORY_H
|
||||||
#define FEEDSMODELCLASSICCATEGORY_H
|
#define FEEDSMODELCLASSICCATEGORY_H
|
||||||
|
|
||||||
|
#include <QDateTime>
|
||||||
|
|
||||||
#include "core/feedsmodelrootitem.h"
|
#include "core/feedsmodelrootitem.h"
|
||||||
|
|
||||||
|
|
||||||
// Base class for all categories contained in FeedsModel.
|
// Base class for all categories contained in FeedsModel.
|
||||||
// NOTE: This class should be derived to create PARTICULAR category types.
|
// NOTE: This class should be derived to create PARTICULAR category types.
|
||||||
|
// NOTE: This class should not be instantiated directly.
|
||||||
class FeedsModelCategory : public FeedsModelRootItem {
|
class FeedsModelCategory : public FeedsModelRootItem {
|
||||||
public:
|
public:
|
||||||
// Describes possible types of categories.
|
// Describes possible types of categories.
|
||||||
@ -23,15 +26,24 @@ class FeedsModelCategory : public FeedsModelRootItem {
|
|||||||
int countOfAllMessages() const;
|
int countOfAllMessages() const;
|
||||||
int countOfUnreadMessages() const;
|
int countOfUnreadMessages() const;
|
||||||
|
|
||||||
|
// All types of categories offer these getters/setters.
|
||||||
Type type() const;
|
Type type() const;
|
||||||
void setType(const Type &type);
|
void setType(const Type &type);
|
||||||
|
|
||||||
QString title() const;
|
QString title() const;
|
||||||
void setTitle(const QString &title);
|
void setTitle(const QString &title);
|
||||||
|
|
||||||
|
QString description() const;
|
||||||
|
void setDescription(const QString &description);
|
||||||
|
|
||||||
|
QDateTime creationDate() const;
|
||||||
|
void setCreationDate(const QDateTime &creation_date);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
QString m_title;
|
|
||||||
Type m_type;
|
Type m_type;
|
||||||
|
QString m_title;
|
||||||
|
QDateTime m_creationDate;
|
||||||
|
QString m_description;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FEEDSMODELCLASSICCATEGORY_H
|
#endif // FEEDSMODELCLASSICCATEGORY_H
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
#include <QSqlDatabase>
|
||||||
|
#include <QSqlQuery>
|
||||||
|
#include <QSqlError>
|
||||||
|
|
||||||
|
#include "core/databasefactory.h"
|
||||||
#include "core/feedsmodelfeed.h"
|
#include "core/feedsmodelfeed.h"
|
||||||
|
|
||||||
|
|
||||||
@ -13,7 +18,6 @@ int FeedsModelFeed::childCount() const {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int FeedsModelFeed::countOfAllMessages() const {
|
int FeedsModelFeed::countOfAllMessages() const {
|
||||||
return m_totalCount;
|
return m_totalCount;
|
||||||
}
|
}
|
||||||
@ -22,14 +26,6 @@ int FeedsModelFeed::countOfUnreadMessages() const {
|
|||||||
return m_unreadCount;
|
return m_unreadCount;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FeedsModelFeed::setCountOfAllMessages(int count_total) {
|
|
||||||
m_totalCount = count_total;
|
|
||||||
}
|
|
||||||
|
|
||||||
void FeedsModelFeed::setCountOfUnreadMessages(int count_unread) {
|
|
||||||
m_unreadCount = count_unread;
|
|
||||||
}
|
|
||||||
|
|
||||||
FeedsModelFeed::Type FeedsModelFeed::type() const {
|
FeedsModelFeed::Type FeedsModelFeed::type() const {
|
||||||
return m_type;
|
return m_type;
|
||||||
}
|
}
|
||||||
|
@ -20,13 +20,14 @@ class FeedsModelFeed : public FeedsModelRootItem {
|
|||||||
explicit FeedsModelFeed(FeedsModelRootItem *parent_item = NULL);
|
explicit FeedsModelFeed(FeedsModelRootItem *parent_item = NULL);
|
||||||
virtual ~FeedsModelFeed();
|
virtual ~FeedsModelFeed();
|
||||||
|
|
||||||
|
// Returns 0, feeds have no children.
|
||||||
int childCount() const;
|
int childCount() const;
|
||||||
|
|
||||||
|
// Getters/setters for count of messages.
|
||||||
int countOfAllMessages() const;
|
int countOfAllMessages() const;
|
||||||
int countOfUnreadMessages() const;
|
int countOfUnreadMessages() const;
|
||||||
void setCountOfAllMessages(int count_total);
|
|
||||||
void setCountOfUnreadMessages(int count_unread);
|
|
||||||
|
|
||||||
|
// Other getters/setters.
|
||||||
Type type() const;
|
Type type() const;
|
||||||
void setType(const Type &type);
|
void setType(const Type &type);
|
||||||
|
|
||||||
|
@ -20,6 +20,9 @@ void FeedsModelRootItem::setParent(FeedsModelRootItem *parent_item) {
|
|||||||
m_parentItem = parent_item;
|
m_parentItem = parent_item;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FeedsModelRootItem::update() {
|
||||||
|
}
|
||||||
|
|
||||||
FeedsModelRootItem *FeedsModelRootItem::child(int row) {
|
FeedsModelRootItem *FeedsModelRootItem::child(int row) {
|
||||||
return m_childItems.value(row);
|
return m_childItems.value(row);
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@ class FeedsModelRootItem {
|
|||||||
explicit FeedsModelRootItem(FeedsModelRootItem *parent_item = NULL);
|
explicit FeedsModelRootItem(FeedsModelRootItem *parent_item = NULL);
|
||||||
virtual ~FeedsModelRootItem();
|
virtual ~FeedsModelRootItem();
|
||||||
|
|
||||||
|
// Basic operations.
|
||||||
virtual void setParent(FeedsModelRootItem *parent_item);
|
virtual void setParent(FeedsModelRootItem *parent_item);
|
||||||
virtual FeedsModelRootItem *parent();
|
virtual FeedsModelRootItem *parent();
|
||||||
virtual FeedsModelRootItem *child(int row);
|
virtual FeedsModelRootItem *child(int row);
|
||||||
@ -24,11 +25,17 @@ class FeedsModelRootItem {
|
|||||||
virtual int row() const;
|
virtual int row() const;
|
||||||
virtual QVariant data(int column, int role) const;
|
virtual QVariant data(int column, int role) const;
|
||||||
|
|
||||||
|
// Each item offers "counts" of messages.
|
||||||
virtual int countOfUnreadMessages() const;
|
virtual int countOfUnreadMessages() const;
|
||||||
virtual int countOfAllMessages() const;
|
virtual int countOfAllMessages() const;
|
||||||
|
|
||||||
|
// Each item can be "updated".
|
||||||
|
virtual void update();
|
||||||
|
|
||||||
|
// Each item has icon.
|
||||||
void setIcon(const QIcon &icon);
|
void setIcon(const QIcon &icon);
|
||||||
|
|
||||||
|
// Each item has some kind of id.
|
||||||
int id() const;
|
int id() const;
|
||||||
void setId(int id);
|
void setId(int id);
|
||||||
|
|
||||||
@ -37,7 +44,6 @@ class FeedsModelRootItem {
|
|||||||
QIcon m_icon;
|
QIcon m_icon;
|
||||||
QList<FeedsModelRootItem*> m_childItems;
|
QList<FeedsModelRootItem*> m_childItems;
|
||||||
FeedsModelRootItem *m_parentItem;
|
FeedsModelRootItem *m_parentItem;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FEEDMODELROOTITEM_H
|
#endif // FEEDMODELROOTITEM_H
|
||||||
|
@ -43,6 +43,13 @@ QVariant FeedsModelStandardCategory::data(int column, int role) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FeedsModelStandardCategory::update() {
|
||||||
|
// Update all children.
|
||||||
|
foreach (FeedsModelRootItem *child, m_childItems) {
|
||||||
|
child->update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
FeedsModelStandardCategory *FeedsModelStandardCategory::loadFromRecord(const QSqlRecord &record) {
|
FeedsModelStandardCategory *FeedsModelStandardCategory::loadFromRecord(const QSqlRecord &record) {
|
||||||
FeedsModelStandardCategory *category = new FeedsModelStandardCategory(NULL);
|
FeedsModelStandardCategory *category = new FeedsModelStandardCategory(NULL);
|
||||||
|
|
||||||
@ -55,19 +62,3 @@ FeedsModelStandardCategory *FeedsModelStandardCategory::loadFromRecord(const QSq
|
|||||||
|
|
||||||
return category;
|
return category;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FeedsModelStandardCategory::description() const {
|
|
||||||
return m_description;
|
|
||||||
}
|
|
||||||
|
|
||||||
void FeedsModelStandardCategory::setDescription(const QString &description) {
|
|
||||||
m_description = description;
|
|
||||||
}
|
|
||||||
|
|
||||||
QDateTime FeedsModelStandardCategory::creationDate() const {
|
|
||||||
return m_creationDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
void FeedsModelStandardCategory::setCreationDate(const QDateTime &creation_date) {
|
|
||||||
m_creationDate = creation_date;
|
|
||||||
}
|
|
||||||
|
@ -18,20 +18,11 @@ class FeedsModelStandardCategory : public FeedsModelCategory {
|
|||||||
explicit FeedsModelStandardCategory(FeedsModelRootItem *parent_item = NULL);
|
explicit FeedsModelStandardCategory(FeedsModelRootItem *parent_item = NULL);
|
||||||
virtual ~FeedsModelStandardCategory();
|
virtual ~FeedsModelStandardCategory();
|
||||||
|
|
||||||
|
void update();
|
||||||
|
|
||||||
QVariant data(int column, int role) const;
|
QVariant data(int column, int role) const;
|
||||||
|
|
||||||
QString description() const;
|
|
||||||
void setDescription(const QString &description);
|
|
||||||
|
|
||||||
QDateTime creationDate() const;
|
|
||||||
void setCreationDate(const QDateTime &creation_date);
|
|
||||||
|
|
||||||
static FeedsModelStandardCategory *loadFromRecord(const QSqlRecord &record);
|
static FeedsModelStandardCategory *loadFromRecord(const QSqlRecord &record);
|
||||||
|
|
||||||
private:
|
|
||||||
QDateTime m_creationDate;
|
|
||||||
QString m_description;
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FEEDSMODELSTANDARDCATEGORY_H
|
#endif // FEEDSMODELSTANDARDCATEGORY_H
|
||||||
|
@ -97,3 +97,7 @@ QVariant FeedsModelStandardFeed::data(int column, int role) const {
|
|||||||
return QVariant();
|
return QVariant();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FeedsModelStandardFeed::update() {
|
||||||
|
// TODO: Perform fetching of new messages.
|
||||||
|
}
|
||||||
|
@ -18,6 +18,9 @@ class FeedsModelStandardFeed : public FeedsModelFeed {
|
|||||||
|
|
||||||
QVariant data(int column, int role) const;
|
QVariant data(int column, int role) const;
|
||||||
|
|
||||||
|
// Perform fetching of new messages.
|
||||||
|
void update();
|
||||||
|
|
||||||
// Various getters/setters.
|
// Various getters/setters.
|
||||||
QString description() const;
|
QString description() const;
|
||||||
void setDescription(const QString &description);
|
void setDescription(const QString &description);
|
||||||
|
@ -10,18 +10,13 @@
|
|||||||
|
|
||||||
|
|
||||||
// Represents single message.
|
// Represents single message.
|
||||||
// NOTE: This is primarily used for transfering data
|
|
||||||
// to WebBrowser responsible for displaying of messages.
|
|
||||||
class Message {
|
class Message {
|
||||||
friend class WebBrowser;
|
public:
|
||||||
friend class MessagesModel;
|
|
||||||
friend class MessagesView;
|
|
||||||
|
|
||||||
private:
|
|
||||||
QString m_title;
|
QString m_title;
|
||||||
QString m_url;
|
QString m_url;
|
||||||
QString m_author;
|
QString m_author;
|
||||||
QString m_contents;
|
QString m_contents;
|
||||||
|
QDateTime m_created;
|
||||||
QDateTime m_updated;
|
QDateTime m_updated;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
56
src/core/parsingfactory.cpp
Normal file
56
src/core/parsingfactory.cpp
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
#include <QDomDocument>
|
||||||
|
#include <QDomElement>
|
||||||
|
|
||||||
|
#include "core/parsingfactory.h"
|
||||||
|
#include "core/textfactory.h"
|
||||||
|
|
||||||
|
|
||||||
|
ParsingFactory::ParsingFactory() {
|
||||||
|
}
|
||||||
|
|
||||||
|
QList<Message> ParsingFactory::parseAsRSS20(const QString &data) {
|
||||||
|
QList<Message> messages;
|
||||||
|
QDomDocument xml_file;
|
||||||
|
xml_file.setContent(data, true);
|
||||||
|
QDomNodeList messages_in_xml = xml_file.elementsByTagName("item");
|
||||||
|
|
||||||
|
for (int i = 0; i < messages_in_xml.size(); i++) {
|
||||||
|
QDomElement elem_link = messages_in_xml.item(i).namedItem("link").toElement();
|
||||||
|
QDomElement elem_description = messages_in_xml.item(i).namedItem("description").toElement();
|
||||||
|
QDomElement elem_description2 = messages_in_xml.item(i).namedItem("encoded").toElement();
|
||||||
|
QDomElement elem_title = messages_in_xml.item(i).namedItem("title").toElement();
|
||||||
|
QDomElement elem_updated = messages_in_xml.item(i).namedItem("pubDate").toElement();
|
||||||
|
QDomElement elem_author = messages_in_xml.item(i).namedItem("author").toElement();
|
||||||
|
QDomElement elem_author2 = messages_in_xml.item(i).namedItem("creator").toElement();
|
||||||
|
|
||||||
|
// RSS 1.0 requires to have title and link valid.
|
||||||
|
if (elem_description.text().isEmpty() && elem_title.text().isEmpty()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
Message new_message;
|
||||||
|
new_message.m_title = TextFactory::stripTags(elem_title.text().simplified());
|
||||||
|
|
||||||
|
if (new_message.m_title.isEmpty()) {
|
||||||
|
new_message.m_title = TextFactory::stripTags(elem_description.text().simplified());
|
||||||
|
}
|
||||||
|
|
||||||
|
new_message.m_contents = elem_description2.text();
|
||||||
|
if (new_message.m_contents.isEmpty()) {
|
||||||
|
new_message.m_contents = elem_description.text();
|
||||||
|
}
|
||||||
|
|
||||||
|
new_message.m_url = elem_link.text();
|
||||||
|
new_message.m_author = elem_author.text();
|
||||||
|
|
||||||
|
if (new_message.m_author.isEmpty()) {
|
||||||
|
new_message.m_author = elem_author2.text();
|
||||||
|
}
|
||||||
|
|
||||||
|
new_message.m_updated = TextFactory::parseDateTime(elem_updated.text());
|
||||||
|
|
||||||
|
messages.append(new_message);
|
||||||
|
}
|
||||||
|
|
||||||
|
return messages;
|
||||||
|
}
|
20
src/core/parsingfactory.h
Normal file
20
src/core/parsingfactory.h
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#ifndef PARSINGFACTORY_H
|
||||||
|
#define PARSINGFACTORY_H
|
||||||
|
|
||||||
|
#include <QNetworkReply>
|
||||||
|
|
||||||
|
#include "core/messagesmodel.h"
|
||||||
|
|
||||||
|
|
||||||
|
class ParsingFactory {
|
||||||
|
private:
|
||||||
|
ParsingFactory();
|
||||||
|
|
||||||
|
public:
|
||||||
|
// Parses inpute textual data into Message objects.
|
||||||
|
// NOTE: Input is correctly encoded in Unicode.
|
||||||
|
QList<Message> parseAsRSS20(const QString &data);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // PARSINGFACTORY_H
|
@ -45,3 +45,7 @@ QString TextFactory::shorten(const QString &input, int text_length_limit) {
|
|||||||
return input;
|
return input;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString TextFactory::stripTags(QString text) {
|
||||||
|
return text.remove(QRegExp("<[^>]*>"));
|
||||||
|
}
|
||||||
|
@ -15,6 +15,9 @@ class TextFactory {
|
|||||||
// Returns invalid date/time if processing fails.
|
// Returns invalid date/time if processing fails.
|
||||||
static QDateTime parseDateTime(const QString &date_time);
|
static QDateTime parseDateTime(const QString &date_time);
|
||||||
|
|
||||||
|
// Strips "<....>" tags from given text.
|
||||||
|
static QString stripTags(QString text);
|
||||||
|
|
||||||
// Shortens input string according to given length limit.
|
// Shortens input string according to given length limit.
|
||||||
static QString shorten(const QString &input, int text_length_limit = TEXT_TITLE_LIMIT);
|
static QString shorten(const QString &input, int text_length_limit = TEXT_TITLE_LIMIT);
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user