mirror of https://github.com/google/oss-fuzz.git
41 lines
1.6 KiB
Bash
Executable File
41 lines
1.6 KiB
Bash
Executable File
#!/bin/bash -eu
|
|
# Copyright 2021 Google LLC
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
################################################################################
|
|
|
|
# build project
|
|
cd FuzzTesting
|
|
# Maybe we should have a helper script to set $SWIFT_FLAGS
|
|
# for instance about -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION in -Xcc
|
|
swift build -c debug -Xswiftc -sanitize=fuzzer,address \
|
|
-Xswiftc -parse-as-library -Xswiftc -static-stdlib \
|
|
-Xswiftc -use-ld=/usr/bin/ld --static-swift-stdlib \
|
|
--sanitize=address -Xcc="-fsanitize=fuzzer-no-link,address" \
|
|
-Xcxx="-fsanitize=fuzzer-no-link,address"
|
|
|
|
(
|
|
cd .build/debug/
|
|
find . -maxdepth 1 -type f -name "*Fuzzer" -executable | while read i; do cp $i $OUT/"$i"-debug; done
|
|
)
|
|
swift build -c release -Xswiftc -sanitize=fuzzer,address \
|
|
-Xswiftc -parse-as-library -Xswiftc -static-stdlib \
|
|
-Xswiftc -use-ld=/usr/bin/ld --static-swift-stdlib \
|
|
--sanitize=address -Xcc="-fsanitize=fuzzer-no-link,address" \
|
|
-Xcxx="-fsanitize=fuzzer-no-link,address"
|
|
(
|
|
cd .build/release/
|
|
find . -maxdepth 1 -type f -name "*Fuzzer" -executable | while read i; do cp $i $OUT/"$i"-release; done
|
|
)
|