2017-10-04 22:23:03 +00:00
|
|
|
// -*- C++ -*-
|
|
|
|
//===-------------------------- fuzzing.h --------------------------------===//
|
|
|
|
//
|
2019-01-19 10:56:40 +00:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2017-10-04 22:23:03 +00:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef _LIBCPP_FUZZING
|
|
|
|
#define _LIBCPP_FUZZING
|
|
|
|
|
|
|
|
#include <cstddef> // for size_t
|
|
|
|
#include <cstdint> // for uint8_t
|
|
|
|
|
|
|
|
namespace fuzzing {
|
|
|
|
|
2017-10-23 23:19:30 +00:00
|
|
|
// These all return 0 on success; != 0 on failure
|
|
|
|
int sort (const uint8_t *data, size_t size);
|
|
|
|
int stable_sort (const uint8_t *data, size_t size);
|
|
|
|
int partition (const uint8_t *data, size_t size);
|
2017-10-30 19:51:58 +00:00
|
|
|
int partition_copy (const uint8_t *data, size_t size);
|
2017-10-23 23:19:30 +00:00
|
|
|
int stable_partition (const uint8_t *data, size_t size);
|
2017-10-30 19:51:58 +00:00
|
|
|
int unique (const uint8_t *data, size_t size);
|
|
|
|
int unique_copy (const uint8_t *data, size_t size);
|
2017-10-23 23:19:30 +00:00
|
|
|
|
|
|
|
// partition and stable_partition take Bi-Di iterators.
|
|
|
|
// Should test those, too
|
2017-10-30 19:51:58 +00:00
|
|
|
int nth_element (const uint8_t *data, size_t size);
|
|
|
|
int partial_sort (const uint8_t *data, size_t size);
|
|
|
|
int partial_sort_copy (const uint8_t *data, size_t size);
|
2017-10-23 23:19:30 +00:00
|
|
|
|
|
|
|
// Heap operations
|
|
|
|
int make_heap (const uint8_t *data, size_t size);
|
|
|
|
int push_heap (const uint8_t *data, size_t size);
|
|
|
|
int pop_heap (const uint8_t *data, size_t size);
|
|
|
|
|
|
|
|
// Various flavors of regex
|
|
|
|
int regex_ECMAScript (const uint8_t *data, size_t size);
|
|
|
|
int regex_POSIX (const uint8_t *data, size_t size);
|
|
|
|
int regex_extended (const uint8_t *data, size_t size);
|
|
|
|
int regex_awk (const uint8_t *data, size_t size);
|
|
|
|
int regex_grep (const uint8_t *data, size_t size);
|
|
|
|
int regex_egrep (const uint8_t *data, size_t size);
|
|
|
|
|
|
|
|
// Searching
|
|
|
|
int search (const uint8_t *data, size_t size);
|
|
|
|
// int search_boyer_moore (const uint8_t *data, size_t size);
|
|
|
|
// int search_boyer_moore_horspool (const uint8_t *data, size_t size);
|
2017-10-12 14:48:09 +00:00
|
|
|
|
2017-10-30 19:51:58 +00:00
|
|
|
// Set operations
|
|
|
|
// int includes (const uint8_t *data, size_t size);
|
|
|
|
// int set_union (const uint8_t *data, size_t size);
|
|
|
|
// int set_intersection (const uint8_t *data, size_t size);
|
|
|
|
// int set_difference (const uint8_t *data, size_t size);
|
|
|
|
// int set_symmetric_difference (const uint8_t *data, size_t size);
|
|
|
|
// int merge (const uint8_t *data, size_t size);
|
|
|
|
|
2017-10-04 22:23:03 +00:00
|
|
|
} // namespace fuzzing
|
|
|
|
|
|
|
|
#endif // _LIBCPP_FUZZING
|