aboutsummaryrefslogtreecommitdiffhomepage
path: root/experimental/PdfViewer/SkPdfReporter.cpp
blob: 7aebc431bfdc6a501b071ec2e4268bbd91a8c846 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/*
 * Copyright 2013 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifdef PDF_REPORT

#include "SkPdfReporter.h"

#include "SkTypes.h"

const char* severityName[] = {
"Info",
"CodeWarning",
"Warning",
"IgnoreError",
"Error",
"FatalError",
};

const char* getSeverityName(SkPdfIssueSeverity sev) {
    if (0 <= sev && sev < _kCount__SkPdfIssueSeverity) {
        return severityName[sev];
    }
    SkASSERT(false);
    return "UNKOWN SEVERITY";
}

// TODO(edisonn): add a flag to set the minimum warning level
// TODO(edisonn): get the address in the file, and report it.
// TODO(edisonn): build a html file based on warnings which would showe the original pdf
//                content, with tooltips where warnings/errors were reported.


void SkPdfReport(SkPdfIssueSeverity sev, SkPdfIssue issue,
                 const char* context,
                 const SkPdfNativeObject* obj,
                 SkPdfContext* pdfContext) {
    if (sev >= kIgnoreError_SkPdfIssueSeverity) {
        printf("%s: %s\n", getSeverityName(sev), context);
    }
}

void SkPdfReportIf(bool report,
                   SkPdfIssueSeverity sev, SkPdfIssue issue,
                   const char* context,
                   const SkPdfNativeObject* obj,
                   SkPdfContext* pdfContext) {
    if (!report) {
        return;
    }
    SkPdfReport(sev, issue, context, obj, pdfContext);
}

void SkPdfReportUnexpectedType(SkPdfIssueSeverity sev,
                               const char* context,
                               const SkPdfNativeObject* obj,
                               int anyOfTypes, SkPdfContext* pdfContext) {
    if (sev >= kIgnoreError_SkPdfIssueSeverity) {
        printf("%s: %s\n", getSeverityName(sev), context);
    }
}

#endif  // PDF_REPORT