Coverage Report

Created: 2025-06-13 06:26

/src/boost/libs/json/fuzzing/fuzz_parse.cpp
Line
Count
Source (jump to first uncovered line)
1
//
2
// Copyright (c) 2019 Vinnie Falco (vinnie.falco@gmail.com)
3
// Copyright (c) 2020 Paul Dreik (github@pauldreik.se)
4
//
5
// Distributed under the Boost Software License, Version 1.0. (See accompanying
6
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7
//
8
// Official repository: https://github.com/boostorg/json
9
//
10
11
#include <boost/json/parse.hpp>
12
13
using namespace boost::json;
14
15
bool
16
fuzz_parse(string_view sv)
17
6.74k
{
18
6.74k
    boost::system::error_code ec;
19
6.74k
    value jv = parse( sv, ec );
20
6.74k
    if(ec)
21
4.51k
        return false;
22
2.22k
    return jv.is_number();
23
6.74k
}
24
25
extern "C"
26
int
27
LLVMFuzzerTestOneInput(
28
    const uint8_t* data, size_t size)
29
21.2k
{
30
21.2k
    try
31
21.2k
    {
32
21.2k
        string_view s{reinterpret_cast<
33
21.2k
            const char*>(data), size};
34
21.2k
        fuzz_parse(s);
35
21.2k
    }
36
21.2k
    catch(...)
37
21.2k
    {
38
0
    }
39
21.2k
    return 0;
40
21.2k
}