Make constructor of Workbook private

This commit is contained in:
Debao Zhang
2013-09-11 17:12:56 +08:00
parent 5817ebdbfd
commit 6ee507b0d8
4 changed files with 54 additions and 26 deletions
+26
View File
@@ -33,6 +33,7 @@
#include "xlsxworksheet_p.h"
#include <QFile>
#include <QBuffer>
namespace QXlsx {
@@ -281,4 +282,29 @@ void Workbook::saveToXmlFile(QIODevice *device)
writer.writeEndDocument();
}
QByteArray Workbook::saveToXmlData()
{
QByteArray data;
QBuffer buffer(&data);
buffer.open(QIODevice::WriteOnly);
saveToXmlFile(&buffer);
return data;
}
QSharedPointer<Workbook> Workbook::loadFromXmlFile(QIODevice *device)
{
return QSharedPointer<Workbook>(new Workbook);
}
QSharedPointer<Workbook> Workbook::loadFromXmlData(const QByteArray &data)
{
QBuffer buffer;
buffer.setData(data);
buffer.open(QIODevice::ReadOnly);
return loadFromXmlFile(&buffer);
}
} //namespace
+13 -2
View File
@@ -29,6 +29,8 @@
#include <QObject>
#include <QList>
#include <QImage>
#include <QSharedPointer>
class QIODevice;
namespace QXlsx {
@@ -39,6 +41,8 @@ class SharedStrings;
class Styles;
class Package;
class Drawing;
class Document;
class DocumentPrivate;
class WorkbookPrivate;
class Q_XLSX_EXPORT Workbook : public QObject
@@ -46,7 +50,6 @@ class Q_XLSX_EXPORT Workbook : public QObject
Q_OBJECT
Q_DECLARE_PRIVATE(Workbook)
public:
Workbook(QObject *parent=0);
~Workbook();
QList<Worksheet *> worksheets() const;
@@ -66,13 +69,21 @@ public:
private:
friend class Package;
friend class Worksheet;
friend class Document;
friend class DocumentPrivate;
Workbook(QObject *parent=0);
void saveToXmlFile(QIODevice *device);
QByteArray saveToXmlData();
static QSharedPointer<Workbook> loadFromXmlFile(QIODevice *device);
static QSharedPointer<Workbook> loadFromXmlData(const QByteArray &data);
SharedStrings *sharedStrings();
Styles *styles();
QList<QImage> images();
QList<Drawing *> drawings();
void prepareDrawings();
void saveToXmlFile(QIODevice *device);
WorkbookPrivate * const d_ptr;
};
+13 -16
View File
@@ -2,7 +2,7 @@
#include <QtTest>
#include "xlsxworksheet.h"
#include "xlsxworkbook.h"
#include "xlsxdocument.h"
class MergeCellTest : public QObject
{
@@ -23,45 +23,42 @@ MergeCellTest::MergeCellTest()
void MergeCellTest::testWithoutMerge()
{
QXlsx::Workbook book;
QXlsx::Worksheet *sheet = book.addWorksheet("Sheet1");
sheet->write("B1", "Hello");
QXlsx::Document xlsx;
xlsx.write("B1", "Hello");
QByteArray xmldata;
QBuffer buffer(&xmldata);
buffer.open(QIODevice::WriteOnly);
sheet->saveToXmlFile(&buffer);
xlsx.activedWorksheet()->saveToXmlFile(&buffer);
QVERIFY2(!xmldata.contains("<mergeCell"), "");
}
void MergeCellTest::testMerge()
{
QXlsx::Workbook book;
QXlsx::Worksheet *sheet = book.addWorksheet("Sheet1");
sheet->write("B1", "Test Merged Cell");
sheet->mergeCells("B1:B5");
QXlsx::Document xlsx;
xlsx.write("B1", "Test Merged Cell");
xlsx.mergeCells("B1:B5");
QByteArray xmldata;
QBuffer buffer(&xmldata);
buffer.open(QIODevice::WriteOnly);
sheet->saveToXmlFile(&buffer);
xlsx.activedWorksheet()->saveToXmlFile(&buffer);
QVERIFY2(xmldata.contains("<mergeCells count=\"1\"><mergeCell ref=\"B1:B5\"/></mergeCells>"), "");
}
void MergeCellTest::testUnMerge()
{
QXlsx::Workbook book;
QXlsx::Worksheet *sheet = book.addWorksheet("Sheet1");
sheet->write("B1", "Test Merged Cell");
sheet->mergeCells("B1:B5");
sheet->unmergeCells("B1:B5");
QXlsx::Document xlsx;
xlsx.write("B1", "Test Merged Cell");
xlsx.mergeCells("B1:B5");
xlsx.unmergeCells("B1:B5");
QByteArray xmldata;
QBuffer buffer(&xmldata);
buffer.open(QIODevice::WriteOnly);
sheet->saveToXmlFile(&buffer);
xlsx.activedWorksheet()->saveToXmlFile(&buffer);
QVERIFY2(!xmldata.contains("<mergeCell"), "");
}
@@ -24,10 +24,7 @@ void RelationshipsTest::testSaveXml()
QXlsx::Relationships rels;
rels.addDocumentRelationship("/officeDocument", "xl/workbook.xml");
QByteArray xmldata;
QBuffer buffer(&xmldata);
buffer.open(QIODevice::WriteOnly);
rels.saveToXmlFile(&buffer);
QByteArray xmldata = rels.saveToXmlData();
QVERIFY2(xmldata.contains("<Relationship Id=\"rId1\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\" Target=\"xl/workbook.xml\"/>"), "");
}
@@ -38,11 +35,8 @@ void RelationshipsTest::testLoadXml()
"<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">"
"<Relationship Id=\"rId1\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\" Target=\"xl/workbook.xml\"/>"
"</Relationships>");
QBuffer buffer(&xmldata);
buffer.open(QIODevice::ReadOnly);
QXlsx::Relationships rels;
rels.loadFromXmlFile(&buffer);
QXlsx::Relationships rels = QXlsx::Relationships::loadFromXmlData(xmldata);
QCOMPARE(rels.documentRelationships("/officeDocument").size(), 1);
}