37 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/bin/bash -eu
 | |
| # Copyright 2018 Google Inc.
 | |
| #
 | |
| # 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.
 | |
| #
 | |
| ################################################################################
 | |
| 
 | |
| cd $WORK
 | |
| 
 | |
| # Disable UBSan vptr since Firestore depends on other libraries that are built
 | |
| # with -fno-rtti.
 | |
| export CFLAGS="$CFLAGS -fno-sanitize=vptr"
 | |
| export CXXFLAGS="$CXXFLAGS -fno-sanitize=vptr"
 | |
| 
 | |
| # Build the project using cmake with FUZZING option enabled to link to OSS Fuzz
 | |
| # fuzzing library defined in ${LIB_FUZZING_ENGINE}.
 | |
| cd $SRC/firebase-ios-sdk
 | |
| mkdir build && cd build
 | |
| cmake -DFUZZING=ON ..
 | |
| make -j$(nproc)
 | |
| 
 | |
| # Copy fuzzing targets, dictionaries, and zipped corpora to $OUT.
 | |
| FUZZERS_DIR=Firestore/fuzzing
 | |
| find ${FUZZERS_DIR} -name '*_fuzzer' -exec cp -v '{}' $OUT ';'
 | |
| find ${FUZZERS_DIR} -name '*_fuzzer.dict' -exec cp -v '{}' $OUT ';'
 | |
| find ${FUZZERS_DIR} -name "*_fuzzer_seed_corpus" -type d -execdir zip -r ${OUT}/{}.zip {} ';'
 |