Make constructor of Workbook private
This commit is contained in:
@@ -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
@@ -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;
|
||||
};
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user