aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/bookmarks/bookmarksmodel.cpp45
-rw-r--r--lib/bookmarks/bookmarksmodel.h10
-rw-r--r--lib/bookmarks/bookmarkswidget.cpp27
-rw-r--r--lib/bookmarks/bookmarkswidget.h2
-rw-r--r--lib/bookmarks/xbel.cpp72
-rw-r--r--lib/bookmarks/xbel.h4
6 files changed, 118 insertions, 42 deletions
diff --git a/lib/bookmarks/bookmarksmodel.cpp b/lib/bookmarks/bookmarksmodel.cpp
index e67668f..5cf343f 100644
--- a/lib/bookmarks/bookmarksmodel.cpp
+++ b/lib/bookmarks/bookmarksmodel.cpp
@@ -7,7 +7,6 @@
*/
#include "bookmarksmodel.h"
-#include <QStyle>
BookmarksModel::BookmarksModel(QStyle *style, QObject *parent)
: QAbstractItemModel(parent)
@@ -27,12 +26,25 @@ BookmarksModel::~BookmarksModel()
delete m_rootItem;
}
-void BookmarksModel::setRoot(BookmarkItem *root)
+bool BookmarksModel::isModified() const
{
- Q_CHECK_PTR(root);
+ return modified;
+}
- delete m_rootItem;
- m_rootItem = root;
+bool BookmarksModel::read(Xbel *xbel)
+{
+ Q_CHECK_PTR(xbel);
+ // if there are items in the bookmark list, we're adding to them, so the model becomes modified
+ if(m_rootItem->childCount() != 0) {
+ modified = true;
+ }
+ return xbel->read(m_rootItem);
+}
+
+bool BookmarksModel::write(Xbel *xbel)
+{
+ Q_CHECK_PTR(xbel);
+ return xbel->write(m_rootItem);
}
QVariant BookmarksModel::headerData(int section, Qt::Orientation orientation, int role) const
@@ -220,6 +232,7 @@ bool BookmarksModel::setData(const QModelIndex &index, const QVariant &value, in
case BookmarkItem::Folder:
if(index.column() == 0) {
node->title = value.toString();
+ modified = true;
emit dataChanged(index, index);
return true;
}
@@ -228,10 +241,12 @@ bool BookmarksModel::setData(const QModelIndex &index, const QVariant &value, in
case BookmarkItem::Bookmark:
if(index.column() == 0) {
node->title = value.toString();
+ modified = true;
emit dataChanged(index, index);
return true;
} else if(index.column() == 1) {
node->href = value.toString();
+ modified = true;
emit dataChanged(index, index);
return true;
}
@@ -275,3 +290,23 @@ QModelIndexList BookmarksModel::match(const QModelIndex &start, int role, const
return list;
}
+
+void BookmarksModel::expandItems(QTreeView *view, BookmarkItem *root)
+{
+ if(root == nullptr)
+ root = m_rootItem;
+
+ // iterate through children
+ for(int i = 0; i < root->childCount(); ++i) {
+ BookmarkItem *childNode = root->child(i);
+
+ // and if it's a folder
+ if(childNode->type() == BookmarkItem::Folder) {
+ QModelIndex idx = index(childNode);
+ view->setExpanded(idx, !childNode->folded);
+
+ // only folders have children, so go through them
+ expandItems(view, childNode);
+ }
+ }
+}
diff --git a/lib/bookmarks/bookmarksmodel.h b/lib/bookmarks/bookmarksmodel.h
index 986a195..79bd9ce 100644
--- a/lib/bookmarks/bookmarksmodel.h
+++ b/lib/bookmarks/bookmarksmodel.h
@@ -7,8 +7,10 @@
*/
#include "bookmarkitem.h"
+#include "xbel.h"
#include <QAbstractItemModel>
#include <QIcon>
+#include <QTreeView>
#ifndef BOOKMARKSMODEL_H
#define BOOKMARKSMODEL_H
@@ -26,7 +28,10 @@ public:
explicit BookmarksModel(QStyle *style, QObject *parent = nullptr);
~BookmarksModel() override;
- void setRoot(BookmarkItem *root);
+ bool isModified() const;
+
+ bool read(Xbel *xbel);
+ bool write(Xbel *xbel);
QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const override;
@@ -47,9 +52,12 @@ public:
QModelIndexList match(const QModelIndex &start, int role, const QVariant &value, int hits, Qt::MatchFlags flags) const override;
+ void expandItems(QTreeView *view, BookmarkItem *root = nullptr);
+
private:
QIcon folderIcon;
QIcon bookmarkIcon;
+ bool modified = false;
BookmarkItem *m_rootItem;
};
diff --git a/lib/bookmarks/bookmarkswidget.cpp b/lib/bookmarks/bookmarkswidget.cpp
index 27f00c3..575f52f 100644
--- a/lib/bookmarks/bookmarkswidget.cpp
+++ b/lib/bookmarks/bookmarkswidget.cpp
@@ -32,10 +32,8 @@ BookmarksWidget::BookmarksWidget(const QString &path, QWidget *parent)
ui->treeView->setModel(m_model);
xbel = new Xbel(path);
- BookmarkItem *rootNode = xbel->read();
- m_model->setRoot(rootNode);
- expandNodes(rootNode);
- //qDebug("Reading bookmarks [%s] %s", qUtf8Printable(m_path), xbel->read(m_path) ? "ok" : "failed");
+ qDebug("Reading bookmarks [%s] %s", qUtf8Printable(path), m_model->read(xbel) ? "ok" : "failed");
+ m_model->expandItems(ui->treeView);
connect(ui->treeView, &QTreeView::activated, this, [this](const QModelIndex &index) {
if(ui->treeView->isPersistentEditorOpen(index))
@@ -67,8 +65,8 @@ BookmarksWidget::~BookmarksWidget()
void BookmarksWidget::save()
{
- // TODO: check if saving is needed
- //qDebug("Writing bookmarks [%s] %s", qUtf8Printable(m_path), xbel->write(m_path) ? "ok" : "failed");
+ if(m_model->isModified())
+ qDebug("Writing bookmarks %s", m_model->write(xbel) ? "ok" : "failed");
}
QAbstractItemModel *BookmarksWidget::model() const
@@ -77,23 +75,6 @@ QAbstractItemModel *BookmarksWidget::model() const
return m_model;
}
-void BookmarksWidget::expandNodes(BookmarkItem *node)
-{
- // iterate through children
- for(int i = 0; i < node->childCount(); ++i) {
- BookmarkItem *childNode = node->child(i);
-
- // and if it's a folder
- if(childNode->type() == BookmarkItem::Folder) {
- QModelIndex index = m_model->index(childNode);
- ui->treeView->setExpanded(index, !childNode->folded);
-
- // only folders have children, so go through them
- expandNodes(childNode);
- }
- }
-}
-
void BookmarksWidget::closeOthers()
{
emit closeOthersSignal();
diff --git a/lib/bookmarks/bookmarkswidget.h b/lib/bookmarks/bookmarkswidget.h
index 0a44414..ca35457 100644
--- a/lib/bookmarks/bookmarkswidget.h
+++ b/lib/bookmarks/bookmarkswidget.h
@@ -37,8 +37,6 @@ signals:
void closeOthersSignal();
private:
- void expandNodes(BookmarkItem *node);
-
Ui::BookmarksDialog *ui;
BookmarksModel *m_model;
Xbel *xbel;
diff --git a/lib/bookmarks/xbel.cpp b/lib/bookmarks/xbel.cpp
index 7a7632c..122ccf8 100644
--- a/lib/bookmarks/xbel.cpp
+++ b/lib/bookmarks/xbel.cpp
@@ -14,21 +14,17 @@ Xbel::Xbel(const QString &path)
m_path = path;
}
-BookmarkItem *Xbel::read()
+bool Xbel::read(BookmarkItem *root)
{
- BookmarkItem *root = new BookmarkItem(BookmarkItem::Root, nullptr);
- root->title = QObject::tr("Title");
- root->href = QObject::tr("href");
-
// if the path is empty, there is nothing to load
if(m_path.isEmpty()) {
- return root;
+ return false;
}
QFile file(m_path);
if(!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
// file cannot be opened for reading
- return root;
+ return false;
}
QXmlStreamReader xmlReader(&file);
@@ -37,13 +33,14 @@ BookmarkItem *Xbel::read()
if(!(xmlReader.name() == "xbel" && xmlReader.attributes().value("version") == "1.0")) {
// invalid xbel
qWarning("Error parsing %s", qUtf8Printable(m_path));
- return root;
+ return false;
}
readChildElements(xmlReader, root);
}
- return root;
+ file.close();
+ return true;
}
void Xbel::readChildElements(QXmlStreamReader &reader, BookmarkItem *parentItem)
@@ -54,7 +51,6 @@ void Xbel::readChildElements(QXmlStreamReader &reader, BookmarkItem *parentItem)
} else if(reader.name() == "folder") {
BookmarkItem *item = new BookmarkItem(BookmarkItem::Folder, parentItem);
- item->href = reader.attributes().value("href").toString();
item->folded = reader.attributes().value("folded") == QLatin1String("yes");
readChildElements(reader, item);
@@ -68,3 +64,59 @@ void Xbel::readChildElements(QXmlStreamReader &reader, BookmarkItem *parentItem)
}
}
}
+
+bool Xbel::write(BookmarkItem *root)
+{
+
+ // if the path is empty, there is nothing to save to
+ if(m_path.isEmpty())
+ return false;
+
+ QFile file(m_path);
+ if(!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
+ // file cannot be opened for writing
+ return false;
+ }
+
+ QXmlStreamWriter xmlWriter(&file);
+ xmlWriter.setAutoFormatting(true);
+
+ xmlWriter.writeStartDocument();
+ xmlWriter.writeDTD("<!DOCTYPE xbel>");
+
+ xmlWriter.writeStartElement("xbel");
+ xmlWriter.writeAttribute("version", "1.0");
+
+ writeChildElements(xmlWriter, root);
+
+ xmlWriter.writeEndDocument();
+
+ file.close();
+ return true;
+}
+
+void Xbel::writeChildElements(QXmlStreamWriter &writer, BookmarkItem *parentItem)
+{
+ for(int i = 0; i < parentItem->childCount(); ++i) {
+ BookmarkItem *node = parentItem->child(i);
+ switch(node->type()) {
+ case BookmarkItem::Root:
+ break;
+ case BookmarkItem::Folder:
+ writer.writeStartElement("folder");
+ writer.writeAttribute("folded", node->folded ? "yes" : "no");
+ writer.writeTextElement("title", node->title);
+ for(int j = 0; j < node->childCount(); ++j) {
+ writeChildElements(writer, node);
+ }
+ writer.writeEndElement();
+ break;
+ case BookmarkItem::Bookmark:
+ writer.writeStartElement("bookmark");
+ writer.writeAttribute("href", node->href);
+ writer.writeTextElement("title", node->title);
+ writer.writeEndElement();
+ break;
+ }
+ }
+}
diff --git a/lib/bookmarks/xbel.h b/lib/bookmarks/xbel.h
index c425cc5..c1de1df 100644
--- a/lib/bookmarks/xbel.h
+++ b/lib/bookmarks/xbel.h
@@ -17,10 +17,12 @@ class Xbel
{
public:
explicit Xbel(const QString &path);
- BookmarkItem *read();
+ bool read(BookmarkItem *root);
+ bool write(BookmarkItem *root);
private:
void readChildElements(QXmlStreamReader &reader, BookmarkItem *parentItem);
+ void writeChildElements(QXmlStreamWriter &writer, BookmarkItem *parentItem);
QString m_path;
};