FindFuzzer.cmake 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # Copyright 2018 Google
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License");
  4. # you may not use this file except in compliance with the License.
  5. # You may obtain a copy of the License at
  6. #
  7. # http://www.apache.org/licenses/LICENSE-2.0
  8. #
  9. # Unless required by applicable law or agreed to in writing, software
  10. # distributed under the License is distributed on an "AS IS" BASIS,
  11. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. # See the License for the specific language governing permissions and
  13. # limitations under the License.
  14. if(TARGET Fuzzer)
  15. return()
  16. endif()
  17. # OSS Fuzz provides its own fuzzing library libFuzzingEngine.a in the path
  18. # defined by LIB_FUZZING_ENGINE environment variable. For local fuzzing, search
  19. # for the libFuzzer.a library that was manually built.
  20. find_library(
  21. FUZZER_LOCATION
  22. NAMES FuzzingEngine Fuzzer
  23. HINTS
  24. $ENV{LIB_FUZZING_ENGINE}
  25. ${FIREBASE_BINARY_DIR}/external/src/libfuzzer
  26. )
  27. include(FindPackageHandleStandardArgs)
  28. find_package_handle_standard_args(
  29. FUZZER
  30. DEFAULT_MSG
  31. FUZZER_LOCATION
  32. )
  33. if(FUZZER_FOUND)
  34. add_library(Fuzzer STATIC IMPORTED)
  35. set_target_properties(
  36. Fuzzer PROPERTIES
  37. IMPORTED_LOCATION ${FUZZER_LOCATION}
  38. )
  39. endif(FUZZER_FOUND)