# Copyright (C) 2017 The Android Open Source Project
#
# 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.

declare_args() {
  # Address Sanitizer: memory bugs (e.g., UAF).
  is_asan = false

  # Leak Sanitizer: memory leaks.
  is_lsan = false

  # Memory Sanitizer: uninitialized reads.
  is_msan = false

  # Thread Sanitizer: threading bugs.
  is_tsan = false

  # Undefined Behaviour Sanitizer.
  is_ubsan = false

  # Compile for fuzzing.
  is_fuzzer = false

  # When enabled, only relevant sanitizer defines are set, but compilation
  # happens with no extra flags. This is useful when in component build
  # enabling sanitizers only in some of the components.
  use_sanitizer_configs_without_instrumentation = false
}

declare_args() {
  # Link in LLVM LibFuzzer.
  use_libfuzzer = is_fuzzer

  # If is_fuzzer=true and use_libfuzzer=false, add this flag to ldflags when
  # linking fuzzer executables.
  link_fuzzer = ""
}

declare_args() {
  using_sanitizer =
      is_asan || is_lsan || is_tsan || is_msan || is_ubsan || use_libfuzzer
}

assert(!using_sanitizer || is_clang || is_system_compiler,
       "is_*san requires is_clang=true'")
assert(!is_msan || is_linux, "msan only supported on linux")
assert(!is_tsan || (is_linux || is_mac), "tsan only supported on linux and mac")
assert(!is_fuzzer || use_libfuzzer || link_fuzzer != "")