Coverage Report

Created: 2023-06-07 06:25

/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.85k
{
18
6.85k
    error_code ec;
19
6.85k
    value jv = parse( sv, ec );
20
6.85k
    if(ec)
21
4.73k
        return false;
22
2.11k
    return jv.is_number();
23
6.85k
}
24
25
extern "C"
26
int
27
LLVMFuzzerTestOneInput(
28
    const uint8_t* data, size_t size)
29
12.7k
{
30
12.7k
    try
31
12.7k
    {
32
12.7k
        string_view s{reinterpret_cast<
33
12.7k
            const char*>(data), size};
34
12.7k
        fuzz_parse(s);
35
12.7k
    }
36
12.7k
    catch(...)
37
12.7k
    {
38
0
    }
39
12.7k
    return 0;
40
12.7k
}