xref: /openbsd-src/gnu/llvm/clang/tools/clang-fuzzer/ClangObjectiveCFuzzer.cpp (revision 1a8dbaac879b9f3335ad7fb25429ce63ac1d6bac)
1 //===-- ClangObjectiveCFuzzer.cpp - Fuzz Clang ----------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 ///
9 /// \file
10 /// This file implements a function that runs Clang on a single Objective-C
11 ///   input. This function is then linked into the Fuzzer library.
12 ///
13 //===----------------------------------------------------------------------===//
14 
15 #include "handle-cxx/handle_cxx.h"
16 
17 using namespace clang_fuzzer;
18 
19 extern "C" int LLVMFuzzerTestOneInput(uint8_t *data, size_t size) {
20   std::string s(reinterpret_cast<const char *>(data), size);
21   HandleCXX(s, "./test.m", {"-O2"});
22   return 0;
23 }
24 
25