summaryrefslogtreecommitdiff
path: root/archived/projt-launcher/fuzz/CMakeLists.txt
blob: 8828726a7b4e427e6ff11ec083a2b40a08f91f7d (plain)
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
set(FUZZ_ENGINE "")
if(DEFINED ENV{LIB_FUZZING_ENGINE})
    set(FUZZ_ENGINE $ENV{LIB_FUZZING_ENGINE})
endif()

function(add_fuzzer target)
    add_executable(${target} ${ARGN})
    target_compile_features(${target} PRIVATE cxx_std_20)
    if(FUZZ_ENGINE)
        target_link_libraries(${target} PRIVATE ${FUZZ_ENGINE})
    else()
        target_compile_options(${target} PRIVATE -fsanitize=fuzzer)
        target_link_options(${target} PRIVATE -fsanitize=fuzzer)
    endif()
endfunction()

add_fuzzer(fuzz_nbt_reader fuzz_nbt_reader.cpp)
target_link_libraries(fuzz_nbt_reader PRIVATE nbt++)

# Disabled: Qt6 adds unnecessary glib dependency in fuzzing environment
# add_fuzzer(fuzz_qjson_parse fuzz_qjson_parse.cpp)
# target_link_libraries(fuzz_qjson_parse PRIVATE Qt6::Core)

# fuzz_gzip requires Qt6::Core for QByteArray/QFile usage in GZip.cpp
# Only build if Qt6::Core is available
if(TARGET Qt6::Core)
    add_fuzzer(fuzz_gzip fuzz_gzip.cpp ${PROJECT_SOURCE_DIR}/launcher/GZip.cpp)
    target_include_directories(fuzz_gzip PRIVATE ${PROJECT_SOURCE_DIR}/launcher)
    # Use static ptlibzippy for fuzzer to avoid sanitizer symbol mismatch
    if(TARGET ptlibzippystatic)
        target_link_libraries(fuzz_gzip PRIVATE Qt6::Core ptlibzippystatic)
    else()
        target_link_libraries(fuzz_gzip PRIVATE Qt6::Core PTlibzippy::PTlibzippy)
    endif()

    add_fuzzer(fuzz_separator_prefix_tree fuzz_separator_prefix_tree.cpp)
    target_include_directories(fuzz_separator_prefix_tree PRIVATE ${PROJECT_SOURCE_DIR}/launcher)
    target_link_libraries(fuzz_separator_prefix_tree PRIVATE Qt6::Core)
endif()