File: cmExprParserFuzzer.cxx

package info (click to toggle)
cmake 4.3.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 158,704 kB
  • sloc: ansic: 406,077; cpp: 309,512; sh: 4,233; python: 3,696; yacc: 3,109; lex: 1,279; f90: 538; asm: 471; lisp: 375; java: 310; cs: 270; fortran: 239; objc: 215; perl: 213; xml: 198; makefile: 110; javascript: 83; pascal: 63; tcl: 55; php: 25; ruby: 22; sed: 2
file content (48 lines) | stat: -rw-r--r-- 1,261 bytes parent folder | download | duplicates (2)
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
/* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying
   file LICENSE.rst or https://cmake.org/licensing for details.  */

/*
 * Fuzzer for CMake's math expression parser
 *
 * The math() command uses cmExprParserHelper to evaluate mathematical
 * expressions. This fuzzer tests the expression parser for crashes,
 * hangs, and undefined behavior.
 *
 * Coverage targets:
 * - Integer arithmetic parsing
 * - Operator precedence handling
 * - Parentheses nesting
 * - Error handling for invalid expressions
 */

#include <cstddef>
#include <cstdint>
#include <string>

#include "cmExprParserHelper.h"

// Limit input size to prevent DoS via deeply nested expressions
static constexpr size_t kMaxInputSize = 4096;

extern "C" int LLVMFuzzerTestOneInput(uint8_t const* data, size_t size)
{
  if (size == 0 || size > kMaxInputSize) {
    return 0;
  }

  // Create null-terminated string
  std::string input(reinterpret_cast<char const*>(data), size);

  cmExprParserHelper helper;

  // Parse with different verbosity levels
  int result = helper.ParseString(input.c_str(), 0);
  (void)result;

  // Always check result and error accessors
  (void)helper.GetResult();
  (void)helper.GetError();
  (void)helper.GetWarning();

  return 0;
}