Coverage Report

Created: 2026-05-23 06:43

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/igl_fuzzer.cpp
Line
Count
Source
1
/*  Copyright 2021 Google LLC
2
Licensed under the Apache License, Version 2.0 (the "License");
3
you may not use this file except in compliance with the License.
4
You may obtain a copy of the License at
5
      http://www.apache.org/licenses/LICENSE-2.0
6
Unless required by applicable law or agreed to in writing, software
7
distributed under the License is distributed on an "AS IS" BASIS,
8
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
See the License for the specific language governing permissions and
10
limitations under the License.
11
*/
12
13
#include <stdint.h>
14
#include <string.h>
15
#include <stdlib.h>
16
#include <igl/MshLoader.h>
17
#include <iostream>
18
19
extern "C"
20
941
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size){
21
941
    char *nullt_string = (char *)malloc(size+1);
22
941
    if (nullt_string == NULL){
23
0
            return 0;
24
0
    }
25
941
    memcpy(nullt_string, data, size);
26
941
    nullt_string[size] = '\0';
27
941
    std::ofstream fuzz_file;
28
941
    fuzz_file.open ("fuzz_file.msh");
29
941
    fuzz_file << nullt_string;
30
941
    fuzz_file.close();
31
941
    try {
32
941
      igl::MshLoader msh_loader("fuzz_file.msh");
33
941
    } catch (...) {}
34
941
    free(nullt_string);
35
941
    return 0;
36
941
}
37