diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
commit | 267c6f2ac71f92999e969232431ba04678e7437e (patch) | |
tree | 358c9467650e1d0a1d7227a21dac2e3d08b622b2 /sc/inc/orcusxml.hxx | |
parent | Initial commit. (diff) | |
download | libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip |
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'sc/inc/orcusxml.hxx')
-rw-r--r-- | sc/inc/orcusxml.hxx | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/sc/inc/orcusxml.hxx b/sc/inc/orcusxml.hxx new file mode 100644 index 0000000000..c59bf100b3 --- /dev/null +++ b/sc/inc/orcusxml.hxx @@ -0,0 +1,79 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This file is part of the LibreOffice project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ + +#pragma once + +#include "scdllapi.h" +#include "address.hxx" + +#include <vector> +#include <memory> + +namespace weld { + class TreeIter; + class TreeView; +} + +/** + * Parameter used during call to ScOrcusFilters::loadXMLStructure(). + */ +struct ScOrcusXMLTreeParam +{ + enum EntryType { ElementDefault, ElementRepeat, Attribute }; + + /** Custom data stored with each tree item. */ + struct EntryData + { + size_t mnNamespaceID; /// numerical ID for xml namespace + EntryType meType; + ScAddress maLinkedPos; /// linked cell position (invalid if unlinked) + bool mbRangeParent:1; + bool mbLeafNode:1; /// Leaf if it has no child elements. Child Attributes don't count. + + SC_DLLPUBLIC EntryData(EntryType eType); + }; + + typedef std::vector<std::unique_ptr<EntryData>> UserDataStoreType; + + OUString maImgElementDefault; + OUString maImgElementRepeat; + OUString maImgAttribute; + + /** + * Store all custom data instances since the tree control doesn't manage + * the life cycle of user data. + */ + UserDataStoreType m_UserDataStore; + + static EntryData* getUserData(const weld::TreeView& rControl, const weld::TreeIter& rEntry); +}; + +struct ScOrcusImportXMLParam +{ + struct CellLink + { + ScAddress maPos; + OString maPath; + + CellLink(const ScAddress& rPos, OString aPath); + }; + + struct RangeLink + { + ScAddress maPos; + std::vector<OString> maFieldPaths; + std::vector<OString> maRowGroups; + }; + + std::vector<size_t> maNamespaces; + std::vector<CellLink> maCellLinks; + std::vector<RangeLink> maRangeLinks; +}; + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |