org.verapdf.gf.model.impl.sa.GFSAPDFDocument Maven / Gradle / Ivy
/**
* This file is part of veraPDF WCAG Validation, a module of the veraPDF project.
* Copyright (c) 2015, veraPDF Consortium
* All rights reserved.
*
* veraPDF WCAG Validation is free software: you can redistribute it and/or modify
* it under the terms of either:
*
* The GNU General public license GPLv3+.
* You should have received a copy of the GNU General Public License
* along with veraPDF WCAG Validation as the LICENSE.GPL file in the root of the source
* tree. If not, see http://www.gnu.org/licenses/ or
* https://www.gnu.org/licenses/gpl-3.0.en.html.
*
* The Mozilla Public License MPLv2+.
* You should have received a copy of the Mozilla Public License along with
* veraPDF WCAG Validation as the LICENSE.MPL file in the root of the source tree.
* If a copy of the MPL was not distributed with this file, you can obtain one at
* http://mozilla.org/MPL/2.0/.
*/
package org.verapdf.gf.model.impl.sa;
import org.verapdf.gf.model.impl.sa.lists.GFSAList;
import org.verapdf.model.GenericModelObject;
import org.verapdf.model.baselayer.Object;
import org.verapdf.model.salayer.SAList;
import org.verapdf.model.salayer.SAPDFDocument;
import org.verapdf.model.salayer.SARepeatedCharacters;
import org.verapdf.model.salayer.SAStructTreeRoot;
import org.verapdf.gf.model.impl.containers.StaticStorages;
import org.verapdf.tools.PageLabels;
import org.verapdf.wcag.algorithms.entities.IDocument;
import org.verapdf.wcag.algorithms.entities.IPage;
import org.verapdf.wcag.algorithms.entities.ITree;
import org.verapdf.wcag.algorithms.entities.RepeatedCharacters;
import org.verapdf.wcag.algorithms.entities.content.*;
import org.verapdf.wcag.algorithms.entities.lists.PDFList;
import org.verapdf.wcag.algorithms.semanticalgorithms.AccumulatedNodeSemanticChecker;
import org.verapdf.wcag.algorithms.semanticalgorithms.containers.StaticContainers;
import java.util.*;
/**
* @author Maxim Plushchov
*/
public class GFSAPDFDocument extends GenericModelObject implements SAPDFDocument, IDocument {
public static final String DOCUMENT_TYPE = "SAPDFDocument";
protected org.verapdf.pd.PDDocument document;
public static final int MAX_NUMBER_OF_ELEMENTS = 1;
public static final String STRUCTURE_TREE_ROOT = "StructTreeRoot";
public static final String PAGES = "pages";
private static final String REPEATED_CHARACTERS = "repeatedCharacters";
private static final String LISTS = "lists";
private List repeatedCharacters = null;
private List lists = null;
private List pages;
private GFSAStructTreeRoot treeRoot = null;
private Boolean hasStructTreeRoot = null;
public GFSAPDFDocument(org.verapdf.pd.PDDocument document) {
super(DOCUMENT_TYPE);
this.document = document;
StaticStorages.clearAllContainers();
}
@Override
public List extends Object> getLinkedObjects(String link) {
switch (link) {
case STRUCTURE_TREE_ROOT:
return this.getStructureTreeRoot();
case PAGES:
return getpages();
case REPEATED_CHARACTERS:
return this.getRepeatedCharacters();
case LISTS:
return this.getLists();
default:
return super.getLinkedObjects(link);
}
}
private List parsePages() {
List result = new ArrayList<>();
List rawPages = document.getPages();
PageLabels pageLabels = document.getCatalog() != null ? document.getCatalog().getPageLabels() : null;
for (int pageNumber = 0; pageNumber < rawPages.size(); pageNumber++) {
org.verapdf.pd.PDPage page = rawPages.get(pageNumber);
result.add(new GFSAPage(page, (pageLabels != null ? pageLabels.getLabel(pageNumber) : null)));
}
return Collections.unmodifiableList(result);
}
private List getpages() {
if (this.pages == null) {
this.pages = parsePages();
}
return this.pages;
}
@Override
public int getNumberOfPages() {
if (this.pages == null) {
this.pages = parsePages();
}
return pages.size();
}
@Override
public List getPages() {
if (this.pages == null) {
this.pages = parsePages();
}
return Collections.unmodifiableList(this.pages);
}
private void parseStructureTreeRoot() {
org.verapdf.pd.structure.PDStructTreeRoot root = document.getStructTreeRoot();
if (root != null) {
this.treeRoot = new GFSAStructTreeRoot(root);
hasStructTreeRoot = true;
} else {
hasStructTreeRoot = false;
}
}
public List getStructureTreeRoot() {
if (hasStructTreeRoot == null) {
checkSemantic();
}
if (treeRoot != null) {
List res = new ArrayList<>(MAX_NUMBER_OF_ELEMENTS);
res.add(treeRoot);
return Collections.unmodifiableList(res);
}
return Collections.emptyList();
}
private List getRepeatedCharacters() {
if (this.repeatedCharacters == null) {
if (StaticContainers.getRepeatedCharacters() == null) {
this.repeatedCharacters = new ArrayList<>();
} else {
this.repeatedCharacters = new ArrayList<>(StaticContainers.getRepeatedCharacters().size());
for (RepeatedCharacters characters : StaticContainers.getRepeatedCharacters()) {
this.repeatedCharacters.add(new GFSARepeatedCharacters(characters));
}
}
}
return this.repeatedCharacters;
}
private List getLists() {
if (this.lists == null) {
if (StaticContainers.getListsCollection() == null) {
this.lists = new ArrayList<>();
} else {
this.lists = new ArrayList<>(StaticContainers.getListsCollection().size());
for (PDFList list : StaticContainers.getListsCollection()) {
this.lists.add(new GFSAList(list));
}
}
}
return this.lists;
}
private void parseChunks() {
if (this.pages == null) {
pages = parsePages();
}
for (GFSAPage page : pages) {
GFSAContentStream contentStream = page.getContentStream();
if (contentStream != null) {
contentStream.parseChunks();
}
}
}
@Override
public List getArtifacts(Integer pageNumber) {
if (pageNumber < pages.size()) {
return pages.get(pageNumber).getArtifacts();
}
return Collections.emptyList();
}
@Override
public IPage getPage(Integer pageNumber) {
if (pageNumber < pages.size()) {
return pages.get(pageNumber);
}
return null;
}
@Override
public List getArtifacts() {
List artifacts = new LinkedList<>();
for (GFSAPage page : pages) {
artifacts.addAll(page.getArtifacts());
}
return artifacts;
}
@Override
public ITree getTree() {
return treeRoot;
}
private void checkSemantic() {
parseChunks();
parseStructureTreeRoot();
AccumulatedNodeSemanticChecker accumulatedNodeSemanticChecker = new AccumulatedNodeSemanticChecker();
accumulatedNodeSemanticChecker.checkSemanticDocument(this, document.getDocument().getFileName());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy