2058 lines
56 KiB
C++
2058 lines
56 KiB
C++
/*
|
|
* (c) Copyright Ascensio System SIA 2010-2023
|
|
*
|
|
* This program is a free software product. You can redistribute it and/or
|
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|
* version 3 as published by the Free Software Foundation. In accordance with
|
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|
* of any third-party rights.
|
|
*
|
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|
*
|
|
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
|
|
* street, Riga, Latvia, EU, LV-1050.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of the Program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU AGPL version 3.
|
|
*
|
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|
* grant you any rights under trademark law for use of our trademarks.
|
|
*
|
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
|
* well as technical writing content are licensed under the terms of the
|
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|
*
|
|
*/
|
|
#include "SlicerCache.h"
|
|
#include "SlicerCacheExt.h"
|
|
#include "../../XlsbFormat/Xlsb.h"
|
|
#include "../../XlsbFormat/SlicerCachesStream.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHE.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHEOLAPIMPL.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHENATIVEITEMS.h"
|
|
#include "../../XlsbFormat/Biff12_unions/FRTSLICERCACHE.h"
|
|
#include "../../XlsbFormat/Biff12_records/BeginSlicerCacheDef.h"
|
|
#include "../../XlsbFormat/Biff12_records/SlicerCachePivotTables.h"
|
|
#include "../../XlsbFormat/Biff12_records/BeginSlicerCacheNative.h"
|
|
#include "../../XlsbFormat/Biff12_records/SlicerCacheNativeItem.h"
|
|
#include "../../XlsbFormat/Biff12_records/BeginSlicerCacheOlapImpl.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHESELECTIONS.h"
|
|
#include "../../XlsbFormat/Biff12_records/SlicerCacheSelection.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHELEVELSDATA.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHELEVELDATA.h"
|
|
#include "../../XlsbFormat/Biff12_records/BeginSlicerCacheLevelData.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHESIRANGES.h"
|
|
#include "../../XlsbFormat/Biff12_unions/SLICERCACHESIRANGE.h"
|
|
#include "../../XlsbFormat/Biff12_records/BeginSlicerCacheSiRange.h"
|
|
#include "../../XlsbFormat/Biff12_records/SlicerCacheOlapItem.h"
|
|
|
|
#include "../../DocxFormat/Drawing/DrawingExt.h"
|
|
|
|
#include "../../Common/SimpleTypes_Shared.h"
|
|
#include "../../Common/SimpleTypes_Spreadsheet.h"
|
|
|
|
#include "../../../MsBinaryFile/XlsFile/Format/Logic/Biff_structures/BiffStructure.h"
|
|
|
|
#include "../../Binary/XlsbFormat/FileTypes_SpreadsheetBin.h"
|
|
namespace OOX
|
|
{
|
|
namespace Spreadsheet
|
|
{
|
|
void COlapSlicerCacheItem::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
ReadAttributes(obj);
|
|
auto ptr = static_cast<XLSB::SlicerCacheOlapItem*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
COlapSlicerCacheItemParent oCOlapSlicerCacheItemParent;
|
|
for(auto &item : ptr->parents)
|
|
{
|
|
oCOlapSlicerCacheItemParent.m_oN = item.value();
|
|
m_oP.push_back(oCOlapSlicerCacheItemParent);
|
|
}
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheItem::toBin()
|
|
{
|
|
auto ptr(new XLSB::SlicerCacheOlapItem);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oNd.IsInit())
|
|
ptr->fNoData = m_oNd.get();
|
|
if(m_oN.IsInit())
|
|
ptr->stName = m_oN.get();
|
|
else
|
|
ptr->stName.setSize(0xFFFFFFFF);
|
|
if(m_oC.IsInit())
|
|
ptr->stTitle = m_oC.get();
|
|
else
|
|
ptr->stTitle.setSize(0xFFFFFFFF);
|
|
for(auto i:m_oP)
|
|
if(i.m_oN.IsInit())
|
|
ptr->parents.push_back(i.m_oN.get());
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheItem::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCacheOlapItem*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oNd = ptr->fNoData;
|
|
|
|
if(!ptr->stName.value().empty())
|
|
m_oN = ptr->stName.value();
|
|
|
|
if(!ptr->stTitle.value().empty())
|
|
m_oC = ptr->stTitle.value();
|
|
}
|
|
}
|
|
void COlapSlicerCacheItem::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "n", m_oN)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "c", m_oC)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "nd", m_oNd)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheItem::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("p", sName) == 0)
|
|
{
|
|
m_oP.emplace_back();
|
|
m_oP.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheItem::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oN, writer.WriteAttributeEncodeXml(L"n", *m_oN););
|
|
WritingNullable(m_oC, writer.WriteAttributeEncodeXml(L"c", *m_oC););
|
|
WritingNullable(m_oNd, writer.WriteAttribute(L"nd", *m_oNd););
|
|
writer.EndAttributes();
|
|
if(m_oP.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oP.size(); ++i)
|
|
{
|
|
(&m_oP[i])->toXML(writer, L"p");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheItem::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteString2(0, m_oN);
|
|
pWriter->WriteString2(1, m_oC);
|
|
pWriter->WriteBool2(2, m_oNd);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oP);
|
|
}
|
|
void COlapSlicerCacheItem::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oN = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oC = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
m_oNd = pReader->GetBool();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oP.emplace_back();
|
|
m_oP.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void COlapSlicerCacheItemParent::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "n", m_oN)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheItemParent::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
oReader.ReadTillEnd();
|
|
}
|
|
void COlapSlicerCacheItemParent::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oN, writer.WriteAttributeEncodeXml(L"n", *m_oN););
|
|
writer.EndAttributes();
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheItemParent::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteString2(0, m_oN);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
}
|
|
void COlapSlicerCacheItemParent::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oN = pReader->GetString2();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheRange::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHESIRANGE);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oStartItem.IsInit())
|
|
{
|
|
auto ptr1(new XLSB::BeginSlicerCacheSiRange);
|
|
if(m_oStartItem.IsInit())
|
|
ptr1->iitemstart = m_oStartItem.get();
|
|
else
|
|
ptr1->iitemstart = 0;
|
|
ptr1->crange = m_oI.size();
|
|
ptr->m_BrtBeginSlicerCacheSiRange = XLS::BaseObjectPtr{ptr1};
|
|
}
|
|
for(auto i:m_oI)
|
|
ptr->m_arBrtSlicerCacheOlapItem.push_back(i.toBin());
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheRange::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHESIRANGE*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
ReadAttributes(ptr->m_BrtBeginSlicerCacheSiRange);
|
|
|
|
COlapSlicerCacheItem oCOlapSlicerCacheItem;
|
|
for(auto &item : ptr->m_arBrtSlicerCacheOlapItem)
|
|
{
|
|
oCOlapSlicerCacheItem.fromBin(item);
|
|
m_oI.push_back(oCOlapSlicerCacheItem);
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheRange::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::BeginSlicerCacheSiRange*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oStartItem = ptr->iitemstart;
|
|
}
|
|
}
|
|
void COlapSlicerCacheRange::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "startItem", m_oStartItem)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheRange::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("i", sName) == 0)
|
|
{
|
|
m_oI.emplace_back();
|
|
m_oI.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheRange::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oStartItem, writer.WriteAttribute(L"startItem", *m_oStartItem););
|
|
writer.EndAttributes();
|
|
if(m_oI.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oI.size(); ++i)
|
|
{
|
|
(&m_oI[i])->toXML(writer, L"i");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheRange::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oStartItem);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oI);
|
|
}
|
|
void COlapSlicerCacheRange::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oStartItem = pReader->GetULong();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oI.emplace_back();
|
|
m_oI.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void CTabularSlicerCacheItem::fromBin(XLS::BiffStructure& obj)
|
|
{
|
|
ReadAttributes(obj);
|
|
}
|
|
void CTabularSlicerCacheItem::toBin(XLS::BiffStructure *obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCacheNativeItemStruct*>(obj);
|
|
|
|
if(m_oX.IsInit())
|
|
ptr->iCache = m_oX.get();
|
|
if(m_oS.IsInit())
|
|
ptr->fSelected = m_oS.get();
|
|
if(m_oNd.IsInit())
|
|
ptr->fNoData = m_oNd.get();
|
|
}
|
|
void CTabularSlicerCacheItem::ReadAttributes(XLS::BiffStructure& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCacheNativeItemStruct*>(&obj);
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oX = ptr->iCache;
|
|
m_oS = ptr->fSelected;
|
|
m_oNd = ptr->fNoData;
|
|
}
|
|
}
|
|
void CTabularSlicerCacheItem::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "x", m_oX)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "s", m_oS)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "nd", m_oNd)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CTabularSlicerCacheItem::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
oReader.ReadTillEnd();
|
|
}
|
|
void CTabularSlicerCacheItem::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oX, writer.WriteAttribute(L"x", *m_oX););
|
|
WritingNullable(m_oS, writer.WriteAttribute(L"s", *m_oS););
|
|
WritingNullable(m_oNd, writer.WriteAttribute(L"nd", *m_oNd););
|
|
writer.EndAttributes();
|
|
writer.EndNode(sName);
|
|
}
|
|
void CTabularSlicerCacheItem::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oX);
|
|
pWriter->WriteBool2(1, m_oS);
|
|
pWriter->WriteBool2(2, m_oNd);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
}
|
|
void CTabularSlicerCacheItem::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oX = pReader->GetULong();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oS = pReader->GetBool();
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
m_oNd = pReader->GetBool();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void COlapSlicerCacheSelection::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
ReadAttributes(obj);
|
|
|
|
auto ptr = static_cast<XLSB::SlicerCacheSelection*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
COlapSlicerCacheItemParent oCOlapSlicerCacheItemParent;
|
|
for(auto &item : ptr->parents)
|
|
{
|
|
oCOlapSlicerCacheItemParent.m_oN = item.value();
|
|
m_oP.push_back(oCOlapSlicerCacheItemParent);
|
|
}
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheSelection::toBin()
|
|
{
|
|
auto ptr(new XLSB::SlicerCacheSelection);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oN.IsInit())
|
|
ptr->stUniqueName = m_oN.get();
|
|
else
|
|
ptr->stUniqueName = L"";
|
|
|
|
for(auto i:m_oP)
|
|
{
|
|
if(i.m_oN.IsInit())
|
|
ptr->parents.push_back(i.m_oN.get());
|
|
}
|
|
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheSelection::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCacheSelection*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
if(!ptr->stUniqueName.value().empty())
|
|
m_oN = ptr->stUniqueName.value();
|
|
}
|
|
}
|
|
void COlapSlicerCacheSelection::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "n", m_oN)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheSelection::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("p", sName) == 0)
|
|
{
|
|
m_oP.emplace_back();
|
|
m_oP.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheSelection::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oN, writer.WriteAttributeEncodeXml(L"n", *m_oN););
|
|
writer.EndAttributes();
|
|
if(m_oP.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oP.size(); ++i)
|
|
{
|
|
(&m_oP[i])->toXML(writer, L"p");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheSelection::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteString2(0, m_oN);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oP);
|
|
}
|
|
void COlapSlicerCacheSelection::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oN = pReader->GetString2();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oP.emplace_back();
|
|
m_oP.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void COlapSlicerCacheLevelData::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHELEVELDATA*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
ReadAttributes(ptr->m_BrtBeginSlicerCacheLevelData);
|
|
|
|
auto ptr1 = static_cast<XLSB::SLICERCACHESIRANGES*>(ptr->m_SLICERCACHESIRANGES.get());
|
|
if(ptr1 != nullptr)
|
|
{
|
|
COlapSlicerCacheRange oCOlapSlicerCacheRange;
|
|
for(auto &item : ptr1->m_arSLICERCACHESIRANGE)
|
|
{
|
|
oCOlapSlicerCacheRange.fromBin(item);
|
|
m_oRanges.push_back(oCOlapSlicerCacheRange);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheLevelData::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHELEVELDATA);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
auto ptr1(new XLSB::BeginSlicerCacheLevelData);
|
|
ptr->m_BrtBeginSlicerCacheLevelData = XLS::BaseObjectPtr{ptr1};
|
|
|
|
if(m_oCount.IsInit())
|
|
ptr1->citem = m_oCount.get();
|
|
else
|
|
ptr1->citem = 0;
|
|
if(m_oSortOrder.IsInit())
|
|
ptr1->fSortOrder = m_oSortOrder->GetValue();
|
|
else
|
|
ptr1->fSortOrder = false;
|
|
if(m_oUniqueName.IsInit())
|
|
ptr1->stUniqueName = m_oUniqueName.get();
|
|
else
|
|
ptr1->stUniqueName.setSize(0xFFFFFFFF);
|
|
if(m_oSourceCaption.IsInit())
|
|
ptr1->stSourceCaption = m_oSourceCaption.get();
|
|
else
|
|
ptr1->stSourceCaption.setSize(0xFFFFFFFF);
|
|
if(m_oCrossFilter.IsInit())
|
|
ptr1->fCrossFilter = m_oCrossFilter->GetValue();
|
|
else
|
|
ptr1->fCrossFilter = false;
|
|
|
|
auto ptr2(new XLSB::SLICERCACHESIRANGES);
|
|
ptr->m_SLICERCACHESIRANGES = XLS::BaseObjectPtr{ptr2};
|
|
for(auto i:m_oRanges)
|
|
{
|
|
ptr2->m_arSLICERCACHESIRANGE.push_back(i.toBin());
|
|
}
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheLevelData::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::BeginSlicerCacheLevelData*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oCount = ptr->citem;
|
|
m_oSortOrder = (SimpleTypes::Spreadsheet::EOlapSlicerCacheSortOrder)ptr->fSortOrder;
|
|
|
|
if(!ptr->stUniqueName.value().empty())
|
|
m_oUniqueName = ptr->stUniqueName.value();
|
|
|
|
if(!ptr->stSourceCaption.value().empty())
|
|
m_oSourceCaption = ptr->stSourceCaption.value();
|
|
|
|
m_oCrossFilter = (SimpleTypes::Spreadsheet::ESlicerCacheCrossFilter)ptr->fCrossFilter;
|
|
}
|
|
}
|
|
void COlapSlicerCacheLevelData::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "uniqueName", m_oUniqueName)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "sourceCaption", m_oSourceCaption)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "count", m_oCount)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "sortOrder", m_oSortOrder)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "crossFilter", m_oCrossFilter)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheLevelData::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("ranges", sName) == 0)
|
|
{
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("range", sName) == 0)
|
|
{
|
|
m_oRanges.emplace_back();
|
|
m_oRanges.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheLevelData::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oUniqueName, writer.WriteAttributeEncodeXml(L"uniqueName", *m_oUniqueName););
|
|
WritingNullable(m_oSourceCaption, writer.WriteAttributeEncodeXml(L"sourceCaption", *m_oSourceCaption););
|
|
WritingNullable(m_oCount, writer.WriteAttribute(L"count", *m_oCount););
|
|
WritingNullable(m_oSortOrder, writer.WriteAttribute(L"sortOrder", m_oSortOrder->ToString()););
|
|
WritingNullable(m_oCrossFilter, writer.WriteAttribute(L"crossFilter", m_oCrossFilter->ToString()););
|
|
writer.EndAttributes();
|
|
if(m_oRanges.size() > 0)
|
|
{
|
|
writer.StartNode(L"ranges");
|
|
writer.StartAttributes();
|
|
writer.EndAttributes();
|
|
for(size_t i = 0; i < m_oRanges.size(); ++i)
|
|
{
|
|
(&m_oRanges[i])->toXML(writer, L"range");
|
|
}
|
|
writer.EndNode(L"ranges");
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheLevelData::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteString2(0, m_oUniqueName);
|
|
pWriter->WriteString2(1, m_oSourceCaption);
|
|
pWriter->WriteUInt2(2, m_oCount);
|
|
if(m_oSortOrder.IsInit())
|
|
{
|
|
pWriter->WriteByte1(3, m_oSortOrder->GetValue());
|
|
}
|
|
if(m_oCrossFilter.IsInit())
|
|
{
|
|
pWriter->WriteByte1(4, m_oCrossFilter->GetValue());
|
|
}
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oRanges);
|
|
}
|
|
void COlapSlicerCacheLevelData::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oUniqueName = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oSourceCaption = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
m_oCount = pReader->GetULong();
|
|
break;
|
|
}
|
|
case 3:
|
|
{
|
|
m_oSortOrder.Init();
|
|
m_oSortOrder->SetValue((SimpleTypes::Spreadsheet::EOlapSlicerCacheSortOrder)pReader->GetUChar());
|
|
break;
|
|
}
|
|
case 4:
|
|
{
|
|
m_oCrossFilter.Init();
|
|
m_oCrossFilter->SetValue((SimpleTypes::Spreadsheet::ESlicerCacheCrossFilter)pReader->GetUChar());
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oRanges.emplace_back();
|
|
m_oRanges.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
|
|
void CTabularSlicerCacheItems::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCacheNativeItem*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oCount = ptr->cItems;
|
|
CTabularSlicerCacheItem oCTabularSlicerCacheItem;
|
|
for(auto &item : ptr->rgItems)
|
|
{
|
|
oCTabularSlicerCacheItem.fromBin(item);
|
|
m_oI.push_back(oCTabularSlicerCacheItem);
|
|
}
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr CTabularSlicerCacheItems::toBin()
|
|
{
|
|
auto ptr(new XLSB::SlicerCacheNativeItem);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oCount.IsInit())
|
|
ptr->cItems = m_oCount.get();
|
|
for(auto i:m_oI)
|
|
{
|
|
XLSB::SlicerCacheNativeItemStruct object;
|
|
i.toBin(&object);
|
|
ptr->rgItems.push_back(object);
|
|
}
|
|
return objectPtr;
|
|
}
|
|
void CTabularSlicerCacheItems::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "count", m_oCount)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CTabularSlicerCacheItems::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("i", sName) == 0)
|
|
{
|
|
m_oI.emplace_back();
|
|
m_oI.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void CTabularSlicerCacheItems::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oCount, writer.WriteAttribute(L"count", *m_oCount););
|
|
writer.EndAttributes();
|
|
if(m_oI.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oI.size(); ++i)
|
|
{
|
|
(&m_oI[i])->toXML(writer, L"i");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void CTabularSlicerCacheItems::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oCount);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oI);
|
|
}
|
|
void CTabularSlicerCacheItems::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oCount = pReader->GetULong();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oI.emplace_back();
|
|
m_oI.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheSelections::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHESELECTIONS);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
for(auto i:m_oSelection)
|
|
ptr->m_arBrtSlicerCacheSelection.push_back(i.toBin());
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheSelections::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHESELECTIONS*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oCount = ptr->m_arBrtSlicerCacheSelection.size();
|
|
|
|
COlapSlicerCacheSelection oCOlapSlicerCacheSelection;
|
|
for(auto &item : ptr->m_arBrtSlicerCacheSelection)
|
|
{
|
|
oCOlapSlicerCacheSelection.fromBin(item);
|
|
m_oSelection.push_back(oCOlapSlicerCacheSelection);
|
|
}
|
|
|
|
}
|
|
}
|
|
void COlapSlicerCacheSelections::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "count", m_oCount)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheSelections::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("selection", sName) == 0)
|
|
{
|
|
m_oSelection.emplace_back();
|
|
m_oSelection.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheSelections::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oCount, writer.WriteAttribute(L"count", *m_oCount););
|
|
writer.EndAttributes();
|
|
if(m_oSelection.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oSelection.size(); ++i)
|
|
{
|
|
(&m_oSelection[i])->toXML(writer, L"selection");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheSelections::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oCount);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oSelection);
|
|
}
|
|
void COlapSlicerCacheSelections::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oCount = pReader->GetULong();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oSelection.emplace_back();
|
|
m_oSelection.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void COlapSlicerCacheLevelsData::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHELEVELSDATA*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oCount = ptr->m_arSLICERCACHELEVELDATA.size();
|
|
|
|
COlapSlicerCacheLevelData oCOlapSlicerCacheLevelData;
|
|
for(auto &item : ptr->m_arSLICERCACHELEVELDATA)
|
|
{
|
|
oCOlapSlicerCacheLevelData.fromBin(item);
|
|
m_oLevel.push_back(oCOlapSlicerCacheLevelData);
|
|
}
|
|
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCacheLevelsData::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHELEVELSDATA);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(!m_oLevel.empty())
|
|
{
|
|
for(auto i:m_oLevel)
|
|
ptr->m_arSLICERCACHELEVELDATA.push_back(i.toBin());
|
|
}
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCacheLevelsData::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "count", m_oCount)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCacheLevelsData::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("level", sName) == 0)
|
|
{
|
|
m_oLevel.emplace_back();
|
|
m_oLevel.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
void COlapSlicerCacheLevelsData::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oCount, writer.WriteAttribute(L"count", *m_oCount););
|
|
writer.EndAttributes();
|
|
if(m_oLevel.size() > 0)
|
|
{
|
|
for(size_t i = 0; i < m_oLevel.size(); ++i)
|
|
{
|
|
(&m_oLevel[i])->toXML(writer, L"level");
|
|
}
|
|
}
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCacheLevelsData::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oCount);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oLevel);
|
|
}
|
|
void COlapSlicerCacheLevelsData::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oCount = pReader->GetULong();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oLevel.emplace_back();
|
|
m_oLevel.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void CTabularSlicerCache::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHENATIVEITEMS*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
ReadAttributes(ptr->m_BrtBeginSlicerCacheNative);
|
|
|
|
if(ptr->m_BrtSlicerCacheNativeItem != nullptr)
|
|
m_oItems = ptr->m_BrtSlicerCacheNativeItem;
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr CTabularSlicerCache::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHENATIVEITEMS);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
auto ptr1(new XLSB::BeginSlicerCacheNative);
|
|
ptr->m_BrtBeginSlicerCacheNative= XLS::BaseObjectPtr{ptr1};
|
|
if(m_oPivotCacheId.IsInit())
|
|
ptr1->dwcacheId = m_oPivotCacheId.get();
|
|
if(m_oSortOrder.IsInit())
|
|
ptr1->fSortOrder = m_oSortOrder->GetValue() + 1;
|
|
if(m_oCustomListSort.IsInit())
|
|
ptr1->fSortUsingCustomLists = m_oCustomListSort.get();
|
|
if(m_oShowMissing.IsInit())
|
|
ptr1->fShowAllItems = m_oShowMissing.get();
|
|
if(m_oCrossFilter.IsInit())
|
|
ptr1->fCrossFilter = m_oCrossFilter->GetValue();
|
|
|
|
ptr->m_BrtSlicerCacheNativeItem = m_oItems->toBin();
|
|
return objectPtr;
|
|
}
|
|
void CTabularSlicerCache::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::BeginSlicerCacheNative*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oPivotCacheId = ptr->dwcacheId;
|
|
m_oSortOrder = (SimpleTypes::Spreadsheet::ETabularSlicerCacheSortOrder)(ptr->fSortOrder - 1);
|
|
m_oCustomListSort = ptr->fSortUsingCustomLists;
|
|
m_oShowMissing = ptr->fShowAllItems;
|
|
|
|
m_oCrossFilter = (SimpleTypes::Spreadsheet::ESlicerCacheCrossFilter)ptr->fCrossFilter;
|
|
}
|
|
}
|
|
void CTabularSlicerCache::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "pivotCacheId", m_oPivotCacheId)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "sortOrder", m_oSortOrder)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "customListSort", m_oCustomListSort)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "showMissing", m_oShowMissing)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "crossFilter", m_oCrossFilter)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CTabularSlicerCache::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("items", sName) == 0)
|
|
m_oItems = oReader;
|
|
else if (strcmp("extLst", sName) == 0)
|
|
m_oExtLst = oReader;
|
|
}
|
|
}
|
|
void CTabularSlicerCache::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oPivotCacheId, writer.WriteAttribute(L"pivotCacheId", *m_oPivotCacheId););
|
|
WritingNullable(m_oSortOrder, writer.WriteAttribute(L"sortOrder", m_oSortOrder->ToString()););
|
|
WritingNullable(m_oCustomListSort, writer.WriteAttribute(L"customListSort", *m_oCustomListSort););
|
|
WritingNullable(m_oShowMissing, writer.WriteAttribute(L"showMissing", *m_oShowMissing););
|
|
WritingNullable(m_oCrossFilter, writer.WriteAttribute(L"crossFilter", m_oCrossFilter->ToString()););
|
|
writer.EndAttributes();
|
|
WritingNullable(m_oItems, m_oItems->toXML(writer, L"items"););
|
|
WritingNullable(m_oExtLst, writer.WriteString(m_oExtLst->toXMLWithNS(L"")););
|
|
writer.EndNode(sName);
|
|
}
|
|
void CTabularSlicerCache::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oPivotCacheId);
|
|
if(m_oSortOrder.IsInit())
|
|
{
|
|
pWriter->WriteByte1(1, m_oSortOrder->GetValue());
|
|
}
|
|
pWriter->WriteBool2(2, m_oCustomListSort);
|
|
pWriter->WriteBool2(3, m_oShowMissing);
|
|
if(m_oCrossFilter.IsInit())
|
|
{
|
|
pWriter->WriteByte1(4, m_oCrossFilter->GetValue());
|
|
}
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecord2(0, m_oItems);
|
|
// pWriter->WriteRecord2(1, m_oExtLst);
|
|
}
|
|
void CTabularSlicerCache::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oPivotCacheId = pReader->GetULong();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oSortOrder.Init();
|
|
m_oSortOrder->SetValue((SimpleTypes::Spreadsheet::ETabularSlicerCacheSortOrder)pReader->GetUChar());
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
m_oCustomListSort = pReader->GetBool();
|
|
break;
|
|
}
|
|
case 3:
|
|
{
|
|
m_oShowMissing = pReader->GetBool();
|
|
break;
|
|
}
|
|
case 4:
|
|
{
|
|
m_oCrossFilter.Init();
|
|
m_oCrossFilter->SetValue((SimpleTypes::Spreadsheet::ESlicerCacheCrossFilter)pReader->GetUChar());
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oItems.Init();
|
|
m_oItems->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
// case 1:
|
|
// {
|
|
// m_oExtLst.Init();
|
|
// m_oExtLst->fromPPTY(pReader);
|
|
// break;
|
|
// }
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
|
|
void COlapSlicerCache::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHEOLAPIMPL*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
ReadAttributes(ptr->m_BrtBeginSlicerCacheOlapImpl);
|
|
|
|
if(ptr->m_SLICERCACHELEVELSDATA != nullptr)
|
|
m_oLevels = ptr->m_SLICERCACHELEVELSDATA;
|
|
|
|
if(ptr->m_SLICERCACHESELECTIONS != nullptr)
|
|
m_oSelections = ptr->m_SLICERCACHESELECTIONS;
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr COlapSlicerCache::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHEOLAPIMPL);
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oPivotCacheId.IsInit())
|
|
{
|
|
auto ptr1(new XLSB::BeginSlicerCacheOlapImpl);
|
|
ptr->m_BrtBeginSlicerCacheOlapImpl = XLS::BaseObjectPtr{ptr1};
|
|
ptr1->ipivotcacheid = m_oPivotCacheId.get();
|
|
}
|
|
if(m_oLevels.IsInit())
|
|
ptr->m_SLICERCACHELEVELSDATA = m_oLevels->toBin();
|
|
if(m_oSelections.IsInit())
|
|
ptr->m_SLICERCACHESELECTIONS = m_oSelections->toBin();
|
|
return objectPtr;
|
|
}
|
|
void COlapSlicerCache::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::BeginSlicerCacheOlapImpl*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oPivotCacheId = ptr->ipivotcacheid;
|
|
}
|
|
}
|
|
|
|
void COlapSlicerCache::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "pivotCacheId", m_oPivotCacheId)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void COlapSlicerCache::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("levels", sName) == 0)
|
|
m_oLevels = oReader;
|
|
else if (strcmp("selections", sName) == 0)
|
|
m_oSelections = oReader;
|
|
// else if (strcmp("extLst", sName) == 0)
|
|
// m_oExtLst = oReader;
|
|
}
|
|
}
|
|
void COlapSlicerCache::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oPivotCacheId, writer.WriteAttribute(L"pivotCacheId", *m_oPivotCacheId););
|
|
writer.EndAttributes();
|
|
WritingNullable(m_oLevels, m_oLevels->toXML(writer, L"levels"););
|
|
WritingNullable(m_oSelections, m_oSelections->toXML(writer, L"selections"););
|
|
WritingNullable(m_oExtLst, writer.WriteString(m_oExtLst->toXMLWithNS(L"")););
|
|
writer.EndNode(sName);
|
|
}
|
|
void COlapSlicerCache::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oPivotCacheId);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecord2(0, m_oLevels);
|
|
pWriter->WriteRecord2(1, m_oSelections);
|
|
// pWriter->WriteRecord2(2, m_oExtLst);
|
|
}
|
|
void COlapSlicerCache::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oPivotCacheId = pReader->GetULong();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oLevels.Init();
|
|
m_oLevels->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oSelections.Init();
|
|
m_oSelections->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
// case 2:
|
|
// {
|
|
// m_oExtLst.Init();
|
|
// m_oExtLst->fromPPTY(pReader);
|
|
// break;
|
|
// }
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
|
|
void CSlicerCacheData::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
if(obj->get_type() == XLS::typeSLICERCACHEOLAPIMPL)
|
|
{
|
|
m_oOlap = obj;
|
|
}
|
|
|
|
if(obj->get_type() == XLS::typeSLICERCACHENATIVEITEMS)
|
|
{
|
|
m_oTabular = obj;
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr CSlicerCacheData::toBin()
|
|
{
|
|
XLS::BaseObjectPtr objectPtr;
|
|
if(m_oOlap.IsInit())
|
|
objectPtr = m_oOlap->toBin();
|
|
else if(m_oTabular.IsInit())
|
|
objectPtr = m_oTabular->toBin();
|
|
return objectPtr;
|
|
}
|
|
void CSlicerCacheData::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CSlicerCacheData::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("olap", sName) == 0)
|
|
m_oOlap = oReader;
|
|
else if (strcmp("tabular", sName) == 0)
|
|
m_oTabular = oReader;
|
|
}
|
|
}
|
|
void CSlicerCacheData::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
writer.EndAttributes();
|
|
WritingNullable(m_oOlap, m_oOlap->toXML(writer, L"olap"););
|
|
WritingNullable(m_oTabular, m_oTabular->toXML(writer, L"tabular"););
|
|
writer.EndNode(sName);
|
|
}
|
|
void CSlicerCacheData::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecord2(0, m_oOlap);
|
|
pWriter->WriteRecord2(1, m_oTabular);
|
|
}
|
|
void CSlicerCacheData::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oOlap.Init();
|
|
m_oOlap->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oTabular.Init();
|
|
m_oTabular->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
|
|
void CSlicerCachePivotTable::fromBin(XLS::BiffStructure& obj)
|
|
{
|
|
ReadAttributes(obj);
|
|
}
|
|
void CSlicerCachePivotTable::ReadAttributes(XLS::BiffStructure& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCachePivotTable*>(&obj);
|
|
if(ptr != nullptr)
|
|
{
|
|
m_oTabId = ptr->iTabId;
|
|
|
|
if(!ptr->stPivotTable.value().empty())
|
|
m_oName = ptr->stPivotTable.value();
|
|
}
|
|
}
|
|
void CSlicerCachePivotTable::toBin(XLS::BiffStructure* obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SlicerCachePivotTable*>(obj);
|
|
if(m_oTabId.IsInit())
|
|
ptr->iTabId = m_oTabId.get();
|
|
if(m_oName.IsInit())
|
|
ptr->stPivotTable = m_oName.get();
|
|
else
|
|
ptr->stPivotTable = 0xFFFFFFFF;
|
|
}
|
|
void CSlicerCachePivotTable::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "tabId", m_oTabId)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "name", m_oName)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CSlicerCachePivotTable::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
oReader.ReadTillEnd();
|
|
}
|
|
void CSlicerCachePivotTable::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oTabId, writer.WriteAttribute(L"tabId", *m_oTabId););
|
|
WritingNullable(m_oName, writer.WriteAttributeEncodeXml(L"name", *m_oName););
|
|
writer.EndAttributes();
|
|
writer.EndNode(sName);
|
|
}
|
|
void CSlicerCachePivotTable::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteUInt2(0, m_oTabId);
|
|
pWriter->WriteString2(1, m_oName);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
}
|
|
void CSlicerCachePivotTable::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oTabId = pReader->GetULong();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oName = pReader->GetString2();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
void CSlicerCacheDefinition::fromBin(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::SLICERCACHE*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
ReadAttributes(ptr->m_BrtBeginSlicerCacheDef);
|
|
|
|
if(ptr->m_BrtSlicerCachePivotTables != nullptr)
|
|
{
|
|
auto ptrSCPT = static_cast<XLSB::SlicerCachePivotTables*>(ptr->m_BrtSlicerCachePivotTables.get());
|
|
CSlicerCachePivotTable oCSlicerCachePivotTable;
|
|
for(auto &item : ptrSCPT->pivotTables)
|
|
{
|
|
oCSlicerCachePivotTable.fromBin(item);
|
|
m_oPivotTables.push_back(oCSlicerCachePivotTable);
|
|
}
|
|
}
|
|
|
|
if(ptr->m_slicerCacheData != nullptr)
|
|
m_oData = ptr->m_slicerCacheData;
|
|
|
|
if(ptr->m_FRTSLICERCACHE != nullptr)
|
|
m_oExtLst = ptr->m_FRTSLICERCACHE;
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr CSlicerCacheDefinition::toBin()
|
|
{
|
|
auto ptr(new XLSB::SLICERCACHE);
|
|
auto ptr1(new XLSB::BeginSlicerCacheDef);
|
|
ptr->m_BrtBeginSlicerCacheDef = XLS::BaseObjectPtr{ptr1};
|
|
XLS::BaseObjectPtr objectPtr(ptr);
|
|
if(m_oName.IsInit())
|
|
ptr1->stName = m_oName.get();
|
|
else
|
|
ptr1->stName = 0xFFFFFFFF;
|
|
if(m_oSourceName.IsInit())
|
|
ptr1->stHierarchy = m_oSourceName.get();
|
|
else
|
|
ptr1->stHierarchy = 0xFFFFFFFF;
|
|
if(!m_oPivotTables.empty())
|
|
{
|
|
auto ptr2(new XLSB::SlicerCachePivotTables);
|
|
ptr->m_BrtSlicerCachePivotTables = XLS::BaseObjectPtr{ptr2};
|
|
for(auto i:m_oPivotTables)
|
|
{
|
|
XLSB::SlicerCachePivotTable table;
|
|
i.toBin(&table);
|
|
ptr2->pivotTables.push_back(table);
|
|
}
|
|
}
|
|
if(m_oData.IsInit())
|
|
ptr->m_slicerCacheData = m_oData->toBin();
|
|
if(m_oExtLst.IsInit())
|
|
ptr->m_FRTSLICERCACHE = m_oExtLst->toBinSlicerCache();
|
|
|
|
return objectPtr;
|
|
}
|
|
void CSlicerCacheDefinition::ReadAttributes(XLS::BaseObjectPtr& obj)
|
|
{
|
|
auto ptr = static_cast<XLSB::BeginSlicerCacheDef*>(obj.get());
|
|
if(ptr != nullptr)
|
|
{
|
|
if(!ptr->stName.value().empty())
|
|
m_oName = ptr->stName.value();
|
|
|
|
if(!ptr->stHierarchy.value().empty())
|
|
m_oSourceName = ptr->stHierarchy.value();
|
|
|
|
}
|
|
}
|
|
void CSlicerCacheDefinition::ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_StartChar_No_NS(oReader)
|
|
WritingElement_ReadAttributes_Read_ifChar( oReader, "name", m_oName)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "uid", m_oUid)
|
|
WritingElement_ReadAttributes_Read_else_ifChar( oReader, "sourceName", m_oSourceName)
|
|
WritingElement_ReadAttributes_EndChar_No_NS( oReader )
|
|
}
|
|
void CSlicerCacheDefinition::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
ReadAttributes(oReader);
|
|
if (oReader.IsEmptyNode())
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("pivotTables", sName) == 0)
|
|
{
|
|
int nCurDepth = oReader.GetDepth();
|
|
while (oReader.ReadNextSiblingNode(nCurDepth))
|
|
{
|
|
const char* sName = XmlUtils::GetNameNoNS(oReader.GetNameChar());
|
|
if (strcmp("pivotTable", sName) == 0)
|
|
{
|
|
m_oPivotTables.emplace_back();
|
|
m_oPivotTables.back() = oReader;
|
|
}
|
|
}
|
|
}
|
|
else if (strcmp("data", sName) == 0)
|
|
m_oData = oReader;
|
|
else if (strcmp("extLst", sName) == 0)
|
|
m_oExtLst = oReader;
|
|
}
|
|
}
|
|
void CSlicerCacheDefinition::toXML(NSStringUtils::CStringBuilder& writer, const std::wstring& sName) const
|
|
{
|
|
writer.StartNode(sName);
|
|
writer.WriteString(L" xmlns=\"http://schemas.microsoft.com/office/spreadsheetml/2009/9/main\" xmlns:mc=\"http://schemas.openxmlformats.org/markup-compatibility/2006\" mc:Ignorable=\"x xr10\" xmlns:x=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" xmlns:xr10=\"http://schemas.microsoft.com/office/spreadsheetml/2016/revision10\"");
|
|
writer.StartAttributes();
|
|
WritingNullable(m_oName, writer.WriteAttributeEncodeXml(L"name", *m_oName););
|
|
WritingNullable(m_oUid, writer.WriteAttribute(L"xr10:uid", m_oUid->ToString()););
|
|
WritingNullable(m_oSourceName, writer.WriteAttributeEncodeXml(L"sourceName", *m_oSourceName););
|
|
writer.EndAttributes();
|
|
if(m_oPivotTables.size() > 0)
|
|
{
|
|
writer.StartNode(L"pivotTables");
|
|
writer.StartAttributes();
|
|
writer.EndAttributes();
|
|
for(size_t i = 0; i < m_oPivotTables.size(); ++i)
|
|
{
|
|
(&m_oPivotTables[i])->toXML(writer, L"pivotTable");
|
|
}
|
|
writer.EndNode(L"pivotTables");
|
|
}
|
|
WritingNullable(m_oData, m_oData->toXML(writer, L"data"););
|
|
WritingNullable(m_oExtLst, writer.WriteString(m_oExtLst->toXMLWithNS(L"")););
|
|
writer.EndNode(sName);
|
|
}
|
|
void CSlicerCacheDefinition::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
|
pWriter->WriteString2(0, m_oName);
|
|
if(m_oUid.IsInit())
|
|
{
|
|
pWriter->WriteString1(1, m_oUid->ToString());
|
|
}
|
|
pWriter->WriteString2(2, m_oSourceName);
|
|
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
|
|
|
pWriter->WriteRecordArray(0, 0, m_oPivotTables);
|
|
pWriter->WriteRecord2(1, m_oData);
|
|
if (m_oExtLst.IsInit())
|
|
{
|
|
for(size_t i = 0; i < m_oExtLst->m_arrExt.size(); ++i)
|
|
{
|
|
OOX::Drawing::COfficeArtExtension* pExt = m_oExtLst->m_arrExt[i];
|
|
if(!pExt->m_oSlicerCachePivotTables.empty())
|
|
{
|
|
pWriter->StartRecord(2);
|
|
|
|
_UINT32 len = (_UINT32)pExt->m_oSlicerCachePivotTables.size();
|
|
pWriter->WriteULONG(len);
|
|
|
|
for (_UINT32 i = 0; i < len; ++i)
|
|
pWriter->WriteRecord1(0, *pExt->m_oSlicerCachePivotTables[i]);
|
|
|
|
pWriter->EndRecord();
|
|
}
|
|
pWriter->WriteRecord2(3, pExt->m_oTableSlicerCache);
|
|
pWriter->WriteRecord2(4, pExt->m_oSlicerCacheHideItemsWithNoData);
|
|
}
|
|
}
|
|
}
|
|
void CSlicerCacheDefinition::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
LONG _end_rec = pReader->GetPos() + pReader->GetRecordSize() + 4;
|
|
pReader->Skip(1); // start attributes
|
|
while (true)
|
|
{
|
|
BYTE _at = pReader->GetUChar_TypeNode();
|
|
if (_at == NSBinPptxRW::g_nodeAttributeEnd)
|
|
break;
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
m_oName = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oUid = pReader->GetString2();
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
m_oSourceName = pReader->GetString2();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
while (pReader->GetPos() < _end_rec)
|
|
{
|
|
BYTE _at = pReader->GetUChar();
|
|
switch (_at)
|
|
{
|
|
case 0:
|
|
{
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
m_oPivotTables.emplace_back();
|
|
m_oPivotTables.back().fromPPTY(pReader);
|
|
}
|
|
break;
|
|
}
|
|
case 1:
|
|
{
|
|
m_oData.Init();
|
|
m_oData->fromPPTY(pReader);
|
|
break;
|
|
}
|
|
case 2:
|
|
{
|
|
OOX::Drawing::COfficeArtExtension* pOfficeArtExtension = new OOX::Drawing::COfficeArtExtension();
|
|
|
|
pReader->Skip(4);
|
|
ULONG _c = pReader->GetULong();
|
|
for (ULONG i = 0; i < _c; ++i)
|
|
{
|
|
pReader->Skip(1); // type
|
|
OOX::Spreadsheet::CSlicerCachePivotTable* pSlicerCachePivotTable = new OOX::Spreadsheet::CSlicerCachePivotTable();
|
|
pSlicerCachePivotTable->fromPPTY(pReader);
|
|
pOfficeArtExtension->m_oSlicerCachePivotTables.push_back(pSlicerCachePivotTable);
|
|
}
|
|
|
|
pOfficeArtExtension->m_sUri = L"{03082B11-2C62-411c-B77F-237D8FCFBE4C}";
|
|
pOfficeArtExtension->m_sAdditionalNamespace = L"xmlns:x15=\"http://schemas.microsoft.com/office/spreadsheetml/2010/11/main\"";
|
|
if(!m_oExtLst.IsInit())
|
|
{
|
|
m_oExtLst.Init();
|
|
}
|
|
m_oExtLst->m_arrExt.push_back(pOfficeArtExtension);
|
|
break;
|
|
}
|
|
case 3:
|
|
{
|
|
OOX::Drawing::COfficeArtExtension* pOfficeArtExtension = new OOX::Drawing::COfficeArtExtension();
|
|
pOfficeArtExtension->m_oTableSlicerCache.Init();
|
|
pOfficeArtExtension->m_oTableSlicerCache->fromPPTY(pReader);
|
|
|
|
pOfficeArtExtension->m_sUri = L"{2F2917AC-EB37-4324-AD4E-5DD8C200BD13}";
|
|
pOfficeArtExtension->m_sAdditionalNamespace = L"xmlns:x15=\"http://schemas.microsoft.com/office/spreadsheetml/2010/11/main\"";
|
|
if(!m_oExtLst.IsInit())
|
|
{
|
|
m_oExtLst.Init();
|
|
}
|
|
m_oExtLst->m_arrExt.push_back(pOfficeArtExtension);
|
|
break;
|
|
}
|
|
case 4:
|
|
{
|
|
OOX::Drawing::COfficeArtExtension* pOfficeArtExtension = new OOX::Drawing::COfficeArtExtension();
|
|
pOfficeArtExtension->m_oSlicerCacheHideItemsWithNoData.Init();
|
|
pOfficeArtExtension->m_oSlicerCacheHideItemsWithNoData->fromPPTY(pReader);
|
|
|
|
pOfficeArtExtension->m_sUri = L"{470722E0-AACD-4C17-9CDC-17EF765DBC7E}";
|
|
pOfficeArtExtension->m_sAdditionalNamespace = L"xmlns:x15=\"http://schemas.microsoft.com/office/spreadsheetml/2010/11/main\"";
|
|
if(!m_oExtLst.IsInit())
|
|
{
|
|
m_oExtLst.Init();
|
|
}
|
|
m_oExtLst->m_arrExt.push_back(pOfficeArtExtension);
|
|
break;
|
|
}
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
pReader->Seek(_end_rec);
|
|
}
|
|
|
|
void CSlicerCacheFile::readBin(const CPath& oPath)
|
|
{
|
|
CXlsb* xlsb = dynamic_cast<CXlsb*>(File::m_pMainDocument);
|
|
if (xlsb)
|
|
{
|
|
XLSB::SlicerCachesStreamPtr slicerCachesStream(new XLSB::SlicerCachesStream);
|
|
|
|
xlsb->ReadBin(oPath, slicerCachesStream.get());
|
|
|
|
if (slicerCachesStream != nullptr)
|
|
{
|
|
if (slicerCachesStream->m_SLICERCACHE != nullptr)
|
|
m_oSlicerCacheDefinition = slicerCachesStream->m_SLICERCACHE;
|
|
}
|
|
|
|
//slicerCachesStream.reset();
|
|
}
|
|
}
|
|
XLS::BaseObjectPtr CSlicerCacheFile::WriteBin() const
|
|
{
|
|
XLSB::SlicerCachesStreamPtr slicerCachesStream(new XLSB::SlicerCachesStream);
|
|
XLS::BaseObjectPtr objectPtr(slicerCachesStream);
|
|
if(m_oSlicerCacheDefinition.IsInit())
|
|
slicerCachesStream->m_SLICERCACHE = m_oSlicerCacheDefinition->toBin();
|
|
return objectPtr;
|
|
|
|
}
|
|
void CSlicerCacheFile::read(const CPath& oRootPath, const CPath& oPath)
|
|
{
|
|
m_oReadPath = oPath;
|
|
IFileContainer::Read( oRootPath, oPath );
|
|
|
|
if( m_oReadPath.GetExtention() == _T(".bin"))
|
|
{
|
|
readBin(m_oReadPath);
|
|
return;
|
|
}
|
|
|
|
XmlUtils::CXmlLiteReader oReader;
|
|
|
|
if ( !oReader.FromFile( oPath.GetPath() ) )
|
|
return;
|
|
|
|
if ( !oReader.ReadNextNode() )
|
|
return;
|
|
|
|
m_oSlicerCacheDefinition = oReader;
|
|
}
|
|
|
|
void CSlicerCacheFile::write(const CPath& oPath, const CPath& oDirectory, CContentTypes& oContent) const
|
|
{
|
|
if(!m_oSlicerCacheDefinition.IsInit())
|
|
return;
|
|
CXlsb* xlsb = dynamic_cast<CXlsb*>(File::m_pMainDocument);
|
|
if ((xlsb) && (xlsb->m_bWriteToXlsb))
|
|
{
|
|
XLS::BaseObjectPtr object = WriteBin();
|
|
xlsb->WriteBin(oPath, object.get());
|
|
}
|
|
else
|
|
{
|
|
NSStringUtils::CStringBuilder sXml;
|
|
|
|
sXml.WriteString(L"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>");
|
|
m_oSlicerCacheDefinition->toXML(sXml, L"slicerCacheDefinition");
|
|
|
|
std::wstring sPath = oPath.GetPath();
|
|
NSFile::CFileBinary::SaveToFile(sPath, sXml.GetData());
|
|
}
|
|
oContent.Registration( type().OverrideType(), oDirectory, oPath.GetFilename() );
|
|
IFileContainer::Write( oPath, oDirectory, oContent );
|
|
}
|
|
|
|
const OOX::FileType CSlicerCacheFile::type() const
|
|
{
|
|
CXlsb* xlsb = dynamic_cast<CXlsb*>(File::m_pMainDocument);
|
|
if ((xlsb) && (xlsb->m_bWriteToXlsb))
|
|
{
|
|
return OOX::SpreadsheetBin::FileTypes::SlicerCacheBin;
|
|
}
|
|
return OOX::Spreadsheet::FileTypes::SlicerCache;
|
|
}
|
|
|
|
} //Spreadsheet
|
|
} // namespace OOX
|