Coverage Report

Created: 2025-12-05 06:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/qpdf/libqpdf/SHA2_native.cc
Line
Count
Source
1
#include <qpdf/SHA2_native.hh>
2
3
#include <qpdf/QUtil.hh>
4
#include <cstdio>
5
#include <stdexcept>
6
7
SHA2_native::SHA2_native(int bits) :
8
83.0k
    bits(bits)
9
83.0k
{
10
83.0k
    switch (bits) {
11
28.8k
    case 256:
12
28.8k
        sph_sha256_init(&ctx256);
13
28.8k
        break;
14
29.4k
    case 384:
15
29.4k
        sph_sha384_init(&ctx384);
16
29.4k
        break;
17
24.7k
    case 512:
18
24.7k
        sph_sha512_init(&ctx512);
19
24.7k
        break;
20
0
    default:
21
0
        badBits();
22
0
        break;
23
83.0k
    }
24
83.0k
}
25
26
void
27
SHA2_native::badBits()
28
0
{
29
0
    throw std::logic_error("SHA2_native has bits != 256, 384, or 512");
30
0
}
31
32
void
33
SHA2_native::update(unsigned char const* buf, size_t len)
34
83.6k
{
35
83.6k
    switch (bits) {
36
29.4k
    case 256:
37
29.4k
        sph_sha256(&ctx256, buf, len);
38
29.4k
        break;
39
29.4k
    case 384:
40
29.4k
        sph_sha384(&ctx384, buf, len);
41
29.4k
        break;
42
24.7k
    case 512:
43
24.7k
        sph_sha512(&ctx512, buf, len);
44
24.7k
        break;
45
0
    default:
46
0
        badBits();
47
0
        break;
48
83.6k
    }
49
83.6k
}
50
51
void
52
SHA2_native::finalize()
53
83.0k
{
54
83.0k
    switch (bits) {
55
28.8k
    case 256:
56
28.8k
        sph_sha256_close(&ctx256, sha256sum);
57
28.8k
        break;
58
29.4k
    case 384:
59
29.4k
        sph_sha384_close(&ctx384, sha384sum);
60
29.4k
        break;
61
24.7k
    case 512:
62
24.7k
        sph_sha512_close(&ctx512, sha512sum);
63
24.7k
        break;
64
0
    default:
65
0
        badBits();
66
0
        break;
67
83.0k
    }
68
83.0k
}
69
70
std::string
71
SHA2_native::getRawDigest()
72
83.0k
{
73
83.0k
    std::string result;
74
83.0k
    switch (bits) {
75
28.8k
    case 256:
76
28.8k
        result = std::string(reinterpret_cast<char*>(sha256sum), sizeof(sha256sum));
77
28.8k
        break;
78
29.4k
    case 384:
79
29.4k
        result = std::string(reinterpret_cast<char*>(sha384sum), sizeof(sha384sum));
80
29.4k
        break;
81
24.7k
    case 512:
82
24.7k
        result = std::string(reinterpret_cast<char*>(sha512sum), sizeof(sha512sum));
83
24.7k
        break;
84
0
    default:
85
0
        badBits();
86
0
        break;
87
83.0k
    }
88
83.0k
    return result;
89
83.0k
}