Coverage Report

Created: 2026-04-04 06:06

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/xpdf-4.06/build/fuzz_pdfload.cc
Line
Count
Source
1
/*  Copyright 2020 Google Inc.
2
3
Licensed under the Apache License, Version 2.0 (the "License");
4
you may not use this file except in compliance with the License.
5
You may obtain a copy of the License at
6
7
      http://www.apache.org/licenses/LICENSE-2.0
8
9
Unless required by applicable law or agreed to in writing, software
10
distributed under the License is distributed on an "AS IS" BASIS,
11
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
See the License for the specific language governing permissions and
13
limitations under the License.
14
*/
15
#include <fuzzer/FuzzedDataProvider.h>
16
17
#include <vector>
18
#include <aconf.h>
19
#include <stdio.h>
20
#include <stdint.h>
21
#include <stdlib.h>
22
#include <stddef.h>
23
#include <string.h>
24
#include <png.h>
25
26
#include "gmem.h"
27
#include "gmempp.h"
28
#include "parseargs.h"
29
#include "GString.h"
30
#include "gfile.h"
31
#include "GlobalParams.h"
32
#include "Object.h"
33
#include "PDFDoc.h"
34
#include "SplashBitmap.h"
35
#include "Splash.h"
36
#include "SplashOutputDev.h"
37
#include "Stream.h"
38
#include "config.h"
39
#include "JBIG2Stream.h"
40
41
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
42
18.2k
{
43
18.2k
    FuzzedDataProvider fdp (data, size);
44
18.2k
    double hdpi = fdp.ConsumeFloatingPoint<double>();
45
18.2k
    double vdpi = fdp.ConsumeFloatingPoint<double>();
46
18.2k
    int rotate = fdp.ConsumeIntegral<int>();
47
18.2k
    bool useMediaBox = fdp.ConsumeBool();
48
18.2k
    bool crop = fdp.ConsumeBool();
49
18.2k
    bool printing = fdp.ConsumeBool();
50
18.2k
    std::vector<char> payload = fdp.ConsumeRemainingBytes<char>();
51
52
18.2k
    Object xpdf_obj;
53
18.2k
    xpdf_obj.initNull();
54
18.2k
    BaseStream *stream = new MemStream(payload.data(), 0, payload.size(), &xpdf_obj);
55
56
18.2k
    Object info, xfa;
57
18.2k
    Object *acroForm;
58
18.2k
    globalParams = new GlobalParams(NULL);
59
18.2k
    globalParams->setErrQuiet(1);
60
18.2k
    globalParams->setupBaseFonts(NULL);
61
18.2k
    char yes[] = "yes";
62
18.2k
    globalParams->setEnableFreeType(yes);  // Yes, it's a string and not a bool.
63
18.2k
    globalParams->setErrQuiet(1);
64
65
18.2k
    PDFDoc *doc = NULL;
66
18.2k
    try {
67
18.2k
      PDFDoc doc(stream);
68
18.2k
        if (doc.isOk() == gTrue)
69
14.9k
        {
70
14.9k
            doc.getNumPages();
71
14.9k
            doc.getOutline();
72
14.9k
            doc.getStructTreeRoot();
73
14.9k
            doc.getXRef();
74
14.9k
            doc.okToPrint(gTrue);
75
14.9k
            doc.okToCopy(gTrue);
76
14.9k
            doc.okToChange(gTrue);
77
14.9k
            doc.okToAddNotes(gTrue);
78
14.9k
            doc.isLinearized();
79
14.9k
            doc.getPDFVersion();
80
81
14.9k
            GString *metadata;
82
14.9k
            if ((metadata = doc.readMetadata())) {
83
1.17k
              (void)metadata->getCString();
84
1.17k
            }
85
14.9k
            delete metadata;
86
87
14.9k
            Object info;
88
14.9k
            doc.getDocInfo(&info);
89
14.9k
            if (info.isDict()) {
90
3.37k
              info.getDict();
91
3.37k
            }
92
14.9k
            info.free();
93
94
14.9k
            if ((acroForm = doc.getCatalog()->getAcroForm())->isDict()) {
95
1.38k
                acroForm->dictLookup("XFA", &xfa);
96
1.38k
                xfa.free();
97
1.38k
            }
98
99
374k
            for (size_t i = 1; i <= doc.getNumPages(); i++) {
100
359k
              doc.getLinks(i);
101
359k
              auto page = doc.getCatalog()->getPage(i);
102
359k
              if (!page->isOk()) {
103
0
                continue;
104
0
              }
105
359k
              page->getResourceDict();
106
359k
              page->getMetadata();
107
359k
              page->getResourceDict();
108
359k
            }
109
110
14.9k
            SplashColor paperColor = {0xff, 0xff, 0xff};
111
14.9k
            SplashOutputDev *splashOut = new SplashOutputDev(splashModeRGB8, 1, gFalse, paperColor);
112
14.9k
            splashOut->setNoComposite(gTrue);
113
14.9k
            splashOut->startDoc(doc.getXRef());
114
374k
            for (size_t i = 1; i <= doc.getNumPages(); ++i) {
115
359k
              doc.displayPage(splashOut, NULL, i, hdpi, vdpi, rotate, useMediaBox, crop, printing);
116
359k
            }
117
14.9k
            (void)splashOut->getBitmap();
118
119
14.9k
            delete splashOut;
120
14.9k
        }
121
18.2k
    } catch (...) {
122
123
56
    }
124
125
18.2k
    delete globalParams;
126
127
18.2k
    return 0;
128
18.2k
}
129