/* * (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 "WorkSheetStream.h" #include "Biff12_records/CommonRecords.h" #include "Biff12_records/BeginSheet.h"" #include "Biff12_unions/COLINFOS.h" #include "Biff12_records/BeginColInfos.h" #include "Biff12_records/EndColInfos.h" #include "Biff12_records/WsDim.h" #include "Biff12_records/Drawing.h"" #include "Biff12_records/LegacyDrawing.h" #include "Biff12_records/LegacyDrawingHF.h" #include "Biff12_unions/HLINKS.h" #include "Biff12_unions/MERGECELLS.h" #include "Biff12_unions/CELLTABLE.h" #include "Biff12_records/WsFmtInfo.h" #include "Biff12_unions/WSVIEWS2.h" #include "Biff12_records/Margins.h" #include "Biff12_records/PrintOptions.h" #include "Biff12_unions/HEADERFOOTER.h" #include "Biff12_records/SheetProtectionIso.h" #include "Biff12_records/SheetProtection.h" #include "Biff12_unions/LISTPARTS.h" #include "Biff12_unions/AUTOFILTER.h" #include "Biff12_unions/SORTSTATE.h" #include "Biff12_unions/CONDITIONALFORMATTING.h" #include "Biff12_unions/DVALS.h" #include "Biff12_unions/OLEOBJECTS.h" #include "Biff12_unions/ACTIVEXCONTROLS.h" #include "Biff12_records/WsProp.h" #include "Biff12_records/BkHim.h" #include "Biff12_unions/RWBRK.h" #include "Biff12_unions/COLBRK.h" #include "Biff12_records/RangeProtectionIso.h" #include "Biff12_records/RangeProtection.h" #include "Biff12_unions/DCON.h" #include "Biff12_unions/FRTWORKSHEET.h" #include "Biff12_records/EndSheet.h" using namespace XLS; namespace XLSB {; WorkSheetStream::WorkSheetStream() { } WorkSheetStream::~WorkSheetStream() { } BaseObjectPtr WorkSheetStream::clone() { return BaseObjectPtr(new WorkSheetStream(*this)); } const bool WorkSheetStream::loadContent(BinProcessor& proc) { int count = 0; std::vector shared_formulas_locations; while (true) { CFRecordType::TypeId type = proc.getNextRecordType(); if (type == rt_NONE) break; switch (type) { case rt_BeginSheet: { if (proc.optional()) { m_bBrtBeginSheet = true; elements_.pop_back(); } else m_bBrtBeginSheet = false; }break; case rt_BeginColInfos: { count = proc.repeated(0, 0); while (count > 0) { m_arCOLINFOS.insert(m_arCOLINFOS.begin(), elements_.back()); elements_.pop_back(); count--; } }break; case rt_WsDim: { if (proc.optional()) { m_BrtWsDim = elements_.back(); elements_.pop_back(); } }break; case rt_Drawing: { if (proc.optional()) { m_BrtDrawing = elements_.back(); elements_.pop_back(); } }break; case rt_LegacyDrawing: { if (proc.optional()) { m_BrtLegacyDrawing = elements_.back(); elements_.pop_back(); } }break; case rt_LegacyDrawingHF: { if (proc.optional()) { m_BrtLegacyDrawingHF = elements_.back(); elements_.pop_back(); } }break; case rt_HLink: { if (proc.optional()) { m_HLINKS = elements_.back(); elements_.pop_back(); } }break; case rt_BeginMergeCells: { if (proc.optional()) { m_MERGECELLS = elements_.back(); elements_.pop_back(); } }break; case rt_BeginSheetData: { /*CELLTABLE cell_table_temlate(shared_formulas_locations); if (proc.optional(cell_table_temlate)) { m_CELLTABLE = elements_.back(); elements_.pop_back(); }*/ m_SheetaDataPosition = proc.GetRecordPosition(); while (proc.getNextRecordType() != rt_EndSheetData) proc.SkipRecord(false); }break; case rt_BeginUserShViews: { while (proc.getNextRecordType() != rt_EndUserShViews) proc.SkipRecord(false); }break; case rt_WsFmtInfo: { if (proc.optional()) { m_BrtWsFmtInfo = elements_.back(); elements_.pop_back(); } }break; case rt_BeginWsViews: { if (proc.optional()) { m_WSVIEWS2 = elements_.back(); elements_.pop_back(); } }break; case rt_Margins: { if (proc.optional()) { m_BrtMargins = elements_.back(); elements_.pop_back(); } }break; case rt_PageSetup: { if (proc.optional()) { m_BrtPageSetup = elements_.back(); elements_.pop_back(); } }break; case rt_PrintOptions: { if (proc.optional()) { m_BrtPrintOptions = elements_.back(); elements_.pop_back(); } }break; case rt_BeginHeaderFooter: { if (proc.optional()) { m_HEADERFOOTER = elements_.back(); elements_.pop_back(); } }break; case rt_SheetProtectionIso: { if (proc.optional()) { m_BrtSheetProtectionIso = elements_.back(); elements_.pop_back(); } }break; case rt_SheetProtection: { if (proc.optional()) { m_BrtSheetProtection = elements_.back(); elements_.pop_back(); } }break; case rt_BeginListParts: { if (proc.optional()) { m_LISTPARTS = elements_.back(); elements_.pop_back(); } }break; case rt_BeginAFilter: case rt_ACBegin: { if (proc.optional()) { m_AUTOFILTER = elements_.back(); elements_.pop_back(); } }break; case rt_BeginSortState: { if (proc.optional()) { m_SORTSTATE = elements_.back(); elements_.pop_back(); } }break; case rt_BeginConditionalFormatting: { count = proc.repeated(0, 0); while (count > 0) { m_arCONDITIONALFORMATTING.insert(m_arCONDITIONALFORMATTING.begin(), elements_.back()); elements_.pop_back(); count--; } }break; case rt_BeginDVals: { if (proc.optional()) { m_DVALS = elements_.back(); elements_.pop_back(); } }break; case rt_BeginOleObjects: { if (proc.optional()) { m_OLEOBJECTS = elements_.back(); elements_.pop_back(); } }break; case rt_BeginActiveXControls: { if (proc.optional()) { m_ACTIVEXCONTROLS = elements_.back(); elements_.pop_back(); } }break; case rt_WsProp: { if (proc.optional()) { m_BrtWsProp = elements_.back(); elements_.pop_back(); } }break; case rt_BkHim: { if (proc.optional()) { m_BrtBkHim = elements_.back(); elements_.pop_back(); } }break; case rt_BeginRwBrk: { if (proc.optional()) { m_RWBRK = elements_.back(); elements_.pop_back(); } }break; case rt_BeginColBrk: { if (proc.optional()) { m_COLBRK = elements_.back(); elements_.pop_back(); } }break; case rt_RangeProtectionIso: { count = proc.repeated(0, 0); while (count > 0) { m_arBrtRangeProtectionIso.insert(m_arBrtRangeProtectionIso.begin(), elements_.back()); elements_.pop_back(); count--; } }break; case rt_RangeProtection: { count = proc.repeated(0, 0); while (count > 0) { m_arBrtRangeProtection.insert(m_arBrtRangeProtection.begin(), elements_.back()); elements_.pop_back(); count--; } }break; case rt_BeginDCon: { if (proc.optional()) { m_DCON = elements_.back(); elements_.pop_back(); } }break; case rt_FRTBegin: { FRTWORKSHEET oFRTWORKSHEET; if (proc.optional(oFRTWORKSHEET)) { if (m_FRTWORKSHEET != nullptr) { if (oFRTWORKSHEET.m_CONDITIONALFORMATTINGS != nullptr) boost::dynamic_pointer_cast(m_FRTWORKSHEET)->m_CONDITIONALFORMATTINGS = oFRTWORKSHEET.m_CONDITIONALFORMATTINGS; if (oFRTWORKSHEET.m_DVALS14 != nullptr) boost::dynamic_pointer_cast(m_FRTWORKSHEET)->m_DVALS14 = oFRTWORKSHEET.m_DVALS14; if (oFRTWORKSHEET.m_SPARKLINEGROUPS != nullptr) boost::dynamic_pointer_cast(m_FRTWORKSHEET)->m_SPARKLINEGROUPS = oFRTWORKSHEET.m_SPARKLINEGROUPS; if (oFRTWORKSHEET.m_SLICERSEX != nullptr) boost::dynamic_pointer_cast(m_FRTWORKSHEET)->m_SLICERSEX = oFRTWORKSHEET.m_SLICERSEX; if (oFRTWORKSHEET.m_TABLESLICERSEX != nullptr) boost::dynamic_pointer_cast(m_FRTWORKSHEET)->m_TABLESLICERSEX = oFRTWORKSHEET.m_TABLESLICERSEX; elements_.pop_back(); } else { m_FRTWORKSHEET = elements_.back(); elements_.pop_back(); } } }break; case rt_EndSheet: { if (proc.optional()) { m_bBrtEndSheet = true; elements_.pop_back(); } else m_bBrtEndSheet = false; }break; default://skip { proc.SkipRecord(); }break; } } return true; } const bool WorkSheetStream::saveContent(XLS::BinProcessor & proc) { proc.mandatory(); if (m_BrtWsProp != nullptr) proc.mandatory(*m_BrtWsProp); if (m_BrtWsDim != nullptr) proc.mandatory(*m_BrtWsDim); if (m_WSVIEWS2 != nullptr) proc.mandatory(*m_WSVIEWS2); if (m_BrtWsFmtInfo != nullptr) proc.mandatory(*m_BrtWsFmtInfo); if(!m_arCOLINFOS.empty()) { proc.mandatory(); for (auto &item : m_arCOLINFOS) { proc.mandatory(*item); } proc.mandatory(); } if (m_CELLTABLE != nullptr) proc.mandatory(*m_CELLTABLE); if (m_BrtSheetProtectionIso != nullptr) proc.mandatory(*m_BrtSheetProtectionIso); if (m_BrtSheetProtection != nullptr) proc.mandatory(*m_BrtSheetProtection); for (auto &item : m_arBrtRangeProtectionIso) { proc.mandatory(*item); } for (auto &item : m_arBrtRangeProtection) { proc.mandatory(*item); } if (m_AUTOFILTER != nullptr) proc.mandatory(*m_AUTOFILTER); if (m_SORTSTATE != nullptr) proc.mandatory(*m_SORTSTATE); if (m_DCON != nullptr) proc.mandatory(*m_DCON); if (m_MERGECELLS != nullptr) proc.mandatory(*m_MERGECELLS); for (auto &item : m_arCONDITIONALFORMATTING) { proc.mandatory(*item); } if (m_DVALS != nullptr) proc.mandatory(*m_DVALS); if (m_HLINKS != nullptr) proc.mandatory(*m_HLINKS); if (m_BrtPrintOptions != nullptr) proc.mandatory(*m_BrtPrintOptions); if (m_BrtMargins != nullptr) proc.mandatory(*m_BrtMargins); if (m_BrtPageSetup != nullptr) proc.mandatory(*m_BrtPageSetup); if (m_HEADERFOOTER != nullptr) proc.mandatory(*m_HEADERFOOTER); if (m_RWBRK != nullptr) proc.mandatory(*m_RWBRK); if (m_COLBRK != nullptr) proc.mandatory(*m_COLBRK); if (m_BrtDrawing != nullptr) proc.mandatory(*m_BrtDrawing); if (m_BrtLegacyDrawing != nullptr) proc.mandatory(*m_BrtLegacyDrawing); if (m_BrtLegacyDrawingHF != nullptr) proc.mandatory(*m_BrtLegacyDrawingHF); if (m_BrtBkHim != nullptr) proc.mandatory(*m_BrtBkHim); if (m_OLEOBJECTS != nullptr) proc.mandatory(*m_OLEOBJECTS); if (m_ACTIVEXCONTROLS != nullptr) proc.mandatory(*m_ACTIVEXCONTROLS); if (m_LISTPARTS != nullptr) proc.mandatory(*m_LISTPARTS); if (m_FRTWORKSHEET != nullptr) proc.mandatory(*m_FRTWORKSHEET); proc.mandatory(); return true; } } // namespace XLSB