Jump to exact position on page, as identified by TOC entry. Handle
[dorian] / model / opshandler.h
index e27f766..8440afb 100644 (file)
@@ -1,38 +1,21 @@
 #ifndef OPSHANDLER_H
 #define OPSHANDLER_H
 
-#include <QXmlContentHandler>
-
+#include "xmlhandler.h"
 #include "book.h"
 #include "trace.h"
 
 /** XML content handler for OPS format. */
-class OpsHandler: public QXmlContentHandler
+class OpsHandler: public XmlHandler
 {
 public:
     OpsHandler(Book &b): book(b), partCount(0) {}
-    bool endDocument() {return true;}
-    bool endPrefixMapping(const QString &) {return true;}
-    QString errorString() const {return "";}
-    bool ignorableWhitespace(const QString &) {return true;}
-    bool processingInstruction(const QString &, const QString &) {
-        return true;
-    }
-    void setDocumentLocator(QXmlLocator *) {}
-    bool skippedEntity(const QString &) {return true;}
-    bool startDocument() {return true;}
-    bool startPrefixMapping(const QString &, const QString &) {return true;}
-
-    bool characters(const QString &ch) {
-        currentText += ch;
-        return true;
-    }
 
     bool endElement(const QString &namespaceUri, const QString &name,
                     const QString &qName) {
         (void)namespaceUri;
         (void)qName;
-        if (currentText != "") {
+        if (currentText.size()) {
             if (name == "title") {
                 book.title = currentText;
             } else if (name == "creator") {
@@ -52,32 +35,30 @@ public:
 
     bool startElement(const QString &namespaceUri, const QString &name,
                       const QString &qName, const QXmlAttributes &attrs) {
-        Trace t("OpsHandler::startElement" + name);
         (void)namespaceUri;
         (void)qName;
         currentText = "";
 
         if (name == "item") {
             Book::ContentItem item;
-            item.href = book.rootPath() + "/" + attrs.value("href");
+            item.href = attrs.value("href");
             item.name = QString("Part %1").arg(partCount + 1);
+            item.size = 0;
             QString key = attrs.value("id");
             book.content[key] = item;
             partCount++;
-            t.trace(QString("name: ") + item.name);
-            t.trace(QString("href: ") + attrs.value("href"));
-            t.trace(QString("id: ") + key);
-        }
-        else if (name == "itemref") {
-            t.trace(QString("id: ") + attrs.value("idref"));
-            book.toc.append(attrs.value("idref"));
+            qDebug() << "OpsHandler::startElement: name" << item.name << "href"
+                    << attrs.value("href") << "id" << key;
+        } else if (name == "itemref") {
+            qDebug() << "OpsHandler::startElement: parts[" << book.parts.size()
+                    << "]" << attrs.value("idref");
+            book.parts.append(attrs.value("idref"));
         }
         return true;
     }
 
 private:
     Book &book;
-    QString currentText;
     int partCount;
 };