blob: 9ea8920e5ed2e1ea01f6014f8806eb82ca92a71c [file] [log] [blame] [edit]
//========================================================================
//
// StructTreeRoot.h
//
// This file is licensed under the GPLv2 or later
//
// Copyright 2013, 2014 Igalia S.L.
// Copyright 2018, 2019, 2024 Albert Astals Cid <aacid@kde.org>
// Copyright 2018 Adrian Johnson <ajohnson@redneon.com>
// Copyright 2018 Adam Reichold <adam.reichold@t-online.de>
//
//========================================================================
#ifndef STRUCTTREEROOT_H
#define STRUCTTREEROOT_H
#include "Object.h"
#include "StructElement.h"
#include <map>
#include <vector>
class Dict;
class PDFDoc;
class POPPLER_PRIVATE_EXPORT StructTreeRoot
{
public:
StructTreeRoot(PDFDoc *docA, Dict *rootDict);
~StructTreeRoot();
StructTreeRoot &operator=(const StructTreeRoot &) = delete;
StructTreeRoot(const StructTreeRoot &) = delete;
PDFDoc *getDoc() { return doc; }
Dict *getRoleMap() { return roleMap.isDict() ? roleMap.getDict() : nullptr; }
Dict *getClassMap() { return classMap.isDict() ? classMap.getDict() : nullptr; }
unsigned getNumChildren() const { return elements.size(); }
const StructElement *getChild(int i) const { return elements.at(i); }
StructElement *getChild(int i) { return elements.at(i); }
void appendChild(StructElement *element)
{
if (element && element->isOk()) {
elements.push_back(element);
}
}
const StructElement *findParentElement(int key, unsigned mcid = 0) const
{
auto it = parentTree.find(key);
if (it != parentTree.end()) {
if (mcid < it->second.size()) {
return it->second[mcid].element;
}
}
return nullptr;
}
private:
typedef std::vector<StructElement *> ElemPtrArray;
// Structure for items in /ParentTree, it keeps a mapping of
// object references and pointers to StructElement objects.
struct Parent
{
Ref ref;
StructElement *element;
Parent() : element(nullptr) { ref = Ref::INVALID(); }
Parent(const Parent &p) = default;
Parent &operator=(const Parent &) = default;
~Parent() { }
};
PDFDoc *doc;
Object roleMap;
Object classMap;
ElemPtrArray elements;
std::map<int, std::vector<Parent>> parentTree;
std::multimap<Ref, Parent *> refToParentMap;
void parse(Dict *rootDict);
void parseNumberTreeNode(Dict *node);
void parentTreeAdd(const Ref objectRef, StructElement *element);
friend class StructElement;
};
#endif