major_version: "local" minor_version: "" default_target_cpu: "same_as_host" default_toolchain { cpu: "k8" toolchain_identifier: "local_linux" } default_toolchain { cpu: "piii" toolchain_identifier: "local_linux" } default_toolchain { cpu: "darwin" toolchain_identifier: "local_darwin" } default_toolchain { cpu: "freebsd" toolchain_identifier: "local_freebsd" } default_toolchain { cpu: "armeabi-v7a" toolchain_identifier: "stub_armeabi-v7a" } default_toolchain { cpu: "arm" toolchain_identifier: "local_linux" } default_toolchain { cpu: "aarch64" toolchain_identifier: "local_linux" } default_toolchain { cpu: "x64_windows" toolchain_identifier: "local_windows_msys64" } default_toolchain { cpu: "x64_windows_msvc" toolchain_identifier: "vc_14_0_x64" } default_toolchain { cpu: "s390x" toolchain_identifier: "local_linux" } default_toolchain { cpu: "ppc" toolchain_identifier: "local_linux" } default_toolchain { cpu: "ppc64" toolchain_identifier: "local_linux" } toolchain { abi_version: "armeabi-v7a" abi_libc_version: "armeabi-v7a" builtin_sysroot: "" compiler: "compiler" host_system_name: "armeabi-v7a" needsPic: true supports_gold_linker: false supports_incremental_linker: false supports_fission: false supports_interface_shared_objects: false supports_normalizing_ar: false supports_start_end_lib: false target_libc: "armeabi-v7a" target_cpu: "armeabi-v7a" target_system_name: "armeabi-v7a" toolchain_identifier: "stub_armeabi-v7a" tool_path { name: "ar" path: "/bin/false" } tool_path { name: "compat-ld" path: "/bin/false" } tool_path { name: "cpp" path: "/bin/false" } tool_path { name: "dwp" path: "/bin/false" } tool_path { name: "gcc" path: "/bin/false" } tool_path { name: "gcov" path: "/bin/false" } tool_path { name: "ld" path: "/bin/false" } tool_path { name: "nm" path: "/bin/false" } tool_path { name: "objcopy" path: "/bin/false" } tool_path { name: "objdump" path: "/bin/false" } tool_path { name: "strip" path: "/bin/false" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "compiler" host_system_name: "local" needsPic: true supports_gold_linker: false supports_incremental_linker: false supports_fission: false supports_interface_shared_objects: false supports_normalizing_ar: false supports_start_end_lib: false target_libc: "local" target_cpu: "local" target_system_name: "local" toolchain_identifier: "local_linux" tool_path { name: "ar" path: "/usr/bin/ar" } tool_path { name: "compat-ld" path: "/usr/bin/ld" } tool_path { name: "cpp" path: "/usr/bin/cpp" } tool_path { name: "dwp" path: "/usr/bin/dwp" } tool_path { name: "gcc" path: "/usr/bin/gcc" } cxx_flag: "-std=c++0x" linker_flag: "-lstdc++" linker_flag: "-B/usr/bin/" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "/usr/lib/gcc/" cxx_builtin_include_directory: "/usr/local/include" cxx_builtin_include_directory: "/usr/include" tool_path { name: "gcov" path: "/usr/bin/gcov" } # C(++) compiles invoke the compiler (as that is the one knowing where # to find libraries), but we provide LD so other rules can invoke the linker. tool_path { name: "ld" path: "/usr/bin/ld" } tool_path { name: "nm" path: "/usr/bin/nm" } tool_path { name: "objcopy" path: "/usr/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "/usr/bin/objdump" } tool_path { name: "strip" path: "/usr/bin/strip" } # Anticipated future default. unfiltered_cxx_flag: "-no-canonical-prefixes" unfiltered_cxx_flag: "-fno-canonical-system-headers" # Make C++ compilation deterministic. Use linkstamping instead of these # compiler symbols. unfiltered_cxx_flag: "-Wno-builtin-macro-redefined" unfiltered_cxx_flag: "-D__DATE__=\"redacted\"" unfiltered_cxx_flag: "-D__TIMESTAMP__=\"redacted\"" unfiltered_cxx_flag: "-D__TIME__=\"redacted\"" # Security hardening on by default. # Conservative choice; -D_FORTIFY_SOURCE=2 may be unsafe in some cases. # We need to undef it before redefining it as some distributions now have # it enabled by default. compiler_flag: "-U_FORTIFY_SOURCE" compiler_flag: "-D_FORTIFY_SOURCE=1" compiler_flag: "-fstack-protector" linker_flag: "-Wl,-z,relro,-z,now" # Enable coloring even if there's no attached terminal. Bazel removes the # escape sequences if --nocolor is specified. This isn't supported by gcc # on Ubuntu 14.04. # compiler_flag: "-fcolor-diagnostics" # All warnings are enabled. Maybe enable -Werror as well? compiler_flag: "-Wall" # Enable a few more warnings that aren't part of -Wall. compiler_flag: "-Wunused-but-set-parameter" # But disable some that are problematic. compiler_flag: "-Wno-free-nonheap-object" # has false positives # Keep stack frames for debugging, even in opt mode. compiler_flag: "-fno-omit-frame-pointer" # Anticipated future default. linker_flag: "-no-canonical-prefixes" # Have gcc return the exit code from ld. linker_flag: "-pass-exit-codes" # Gold linker only? Can we enable this by default? # linker_flag: "-Wl,--warn-execstack" # linker_flag: "-Wl,--detect-odr-violations" compilation_mode_flags { mode: DBG # Enable debug symbols. compiler_flag: "-g" } compilation_mode_flags { mode: OPT # No debug symbols. # Maybe we should enable https://gcc.gnu.org/wiki/DebugFission for opt or # even generally? However, that can't happen here, as it requires special # handling in Bazel. compiler_flag: "-g0" # Conservative choice for -O # -O3 can increase binary size and even slow down the resulting binaries. # Profile first and / or use FDO if you need better performance than this. compiler_flag: "-O2" # Disable assertions compiler_flag: "-DNDEBUG" # Removal of unused code and data at link time (can this increase binary size in some cases?). compiler_flag: "-ffunction-sections" compiler_flag: "-fdata-sections" linker_flag: "-Wl,--gc-sections" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "compiler" host_system_name: "local" needsPic: true target_libc: "macosx" target_cpu: "darwin" target_system_name: "local" toolchain_identifier: "local_darwin" tool_path { name: "ar" path: "/usr/bin/libtool" } tool_path { name: "compat-ld" path: "/usr/bin/ld" } tool_path { name: "cpp" path: "/usr/bin/cpp" } tool_path { name: "dwp" path: "/usr/bin/dwp" } tool_path { name: "gcc" path: "osx_cc_wrapper.sh" } cxx_flag: "-std=c++0x" linker_flag: "-lstdc++" linker_flag: "-undefined" linker_flag: "dynamic_lookup" linker_flag: "-headerpad_max_install_names" # TODO(ulfjack): This is wrong on so many levels. Figure out a way to auto-detect the proper # setting from the local compiler, and also how to make incremental builds correct. cxx_builtin_include_directory: "/" tool_path { name: "gcov" path: "/usr/bin/gcov" } tool_path { name: "ld" path: "/usr/bin/ld" } tool_path { name: "nm" path: "/usr/bin/nm" } tool_path { name: "objcopy" path: "/usr/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "/usr/bin/objdump" } tool_path { name: "strip" path: "/usr/bin/strip" } # Anticipated future default. unfiltered_cxx_flag: "-no-canonical-prefixes" # Make C++ compilation deterministic. Use linkstamping instead of these # compiler symbols. unfiltered_cxx_flag: "-Wno-builtin-macro-redefined" unfiltered_cxx_flag: "-D__DATE__=\"redacted\"" unfiltered_cxx_flag: "-D__TIMESTAMP__=\"redacted\"" unfiltered_cxx_flag: "-D__TIME__=\"redacted\"" # Security hardening on by default. # Conservative choice; -D_FORTIFY_SOURCE=2 may be unsafe in some cases. compiler_flag: "-D_FORTIFY_SOURCE=1" compiler_flag: "-fstack-protector" # Enable coloring even if there's no attached terminal. Bazel removes the # escape sequences if --nocolor is specified. compiler_flag: "-fcolor-diagnostics" # All warnings are enabled. Maybe enable -Werror as well? compiler_flag: "-Wall" # Enable a few more warnings that aren't part of -Wall. compiler_flag: "-Wthread-safety" compiler_flag: "-Wself-assign" # Keep stack frames for debugging, even in opt mode. compiler_flag: "-fno-omit-frame-pointer" # Anticipated future default. linker_flag: "-no-canonical-prefixes" compilation_mode_flags { mode: DBG # Enable debug symbols. compiler_flag: "-g" } compilation_mode_flags { mode: OPT # No debug symbols. # Maybe we should enable https://gcc.gnu.org/wiki/DebugFission for opt or even generally? # However, that can't happen here, as it requires special handling in Bazel. compiler_flag: "-g0" # Conservative choice for -O # -O3 can increase binary size and even slow down the resulting binaries. # Profile first and / or use FDO if you need better performance than this. compiler_flag: "-O2" # Disable assertions compiler_flag: "-DNDEBUG" # Removal of unused code and data at link time (can this increase binary size in some cases?). compiler_flag: "-ffunction-sections" compiler_flag: "-fdata-sections" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "compiler" host_system_name: "local" needsPic: true supports_gold_linker: false supports_incremental_linker: false supports_fission: false supports_interface_shared_objects: false supports_normalizing_ar: false supports_start_end_lib: false target_libc: "local" target_cpu: "freebsd" target_system_name: "local" toolchain_identifier: "local_freebsd" tool_path { name: "ar" path: "/usr/bin/ar" } tool_path { name: "compat-ld" path: "/usr/bin/ld" } tool_path { name: "cpp" path: "/usr/bin/cpp" } tool_path { name: "dwp" path: "/usr/bin/dwp" } tool_path { name: "gcc" path: "/usr/bin/clang" } cxx_flag: "-std=c++0x" linker_flag: "-lstdc++" linker_flag: "-B/usr/bin/" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "/usr/lib/clang" cxx_builtin_include_directory: "/usr/local/include" cxx_builtin_include_directory: "/usr/include" tool_path { name: "gcov" path: "/usr/bin/gcov" } # C(++) compiles invoke the compiler (as that is the one knowing where # to find libraries), but we provide LD so other rules can invoke the linker. tool_path { name: "ld" path: "/usr/bin/ld" } tool_path { name: "nm" path: "/usr/bin/nm" } tool_path { name: "objcopy" path: "/usr/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "/usr/bin/objdump" } tool_path { name: "strip" path: "/usr/bin/strip" } # Anticipated future default. unfiltered_cxx_flag: "-no-canonical-prefixes" # Make C++ compilation deterministic. Use linkstamping instead of these # compiler symbols. unfiltered_cxx_flag: "-Wno-builtin-macro-redefined" unfiltered_cxx_flag: "-D__DATE__=\"redacted\"" unfiltered_cxx_flag: "-D__TIMESTAMP__=\"redacted\"" unfiltered_cxx_flag: "-D__TIME__=\"redacted\"" # Security hardening on by default. # Conservative choice; -D_FORTIFY_SOURCE=2 may be unsafe in some cases. # We need to undef it before redefining it as some distributions now have # it enabled by default. compiler_flag: "-U_FORTIFY_SOURCE" compiler_flag: "-D_FORTIFY_SOURCE=1" compiler_flag: "-fstack-protector" linker_flag: "-Wl,-z,relro,-z,now" # Enable coloring even if there's no attached terminal. Bazel removes the # escape sequences if --nocolor is specified. This isn't supported by gcc # on Ubuntu 14.04. # compiler_flag: "-fcolor-diagnostics" # All warnings are enabled. Maybe enable -Werror as well? compiler_flag: "-Wall" # Enable a few more warnings that aren't part of -Wall. #compiler_flag: "-Wunused-but-set-parameter" # But disable some that are problematic. #compiler_flag: "-Wno-free-nonheap-object" # has false positives # Keep stack frames for debugging, even in opt mode. compiler_flag: "-fno-omit-frame-pointer" # Anticipated future default. linker_flag: "-no-canonical-prefixes" # Have gcc return the exit code from ld. #linker_flag: "-pass-exit-codes" # Stamp the binary with a unique identifier. # Gold linker only? Can we enable this by default? # linker_flag: "-Wl,--warn-execstack" # linker_flag: "-Wl,--detect-odr-violations" compilation_mode_flags { mode: DBG # Enable debug symbols. compiler_flag: "-g" } compilation_mode_flags { mode: OPT # No debug symbols. # Maybe we should enable https://gcc.gnu.org/wiki/DebugFission for opt or # even generally? However, that can't happen here, as it requires special # handling in Bazel. compiler_flag: "-g0" # Conservative choice for -O # -O3 can increase binary size and even slow down the resulting binaries. # Profile first and / or use FDO if you need better performance than this. compiler_flag: "-O2" # Disable assertions compiler_flag: "-DNDEBUG" # Removal of unused code and data at link time (can this increase binary size in some cases?). compiler_flag: "-ffunction-sections" compiler_flag: "-fdata-sections" linker_flag: "-Wl,--gc-sections" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "windows_mingw" host_system_name: "local" needsPic: false target_libc: "local" target_cpu: "x64_windows" target_system_name: "local" toolchain_identifier: "local_windows_mingw" tool_path { name: "ar" path: "C:/mingw/bin/ar" } tool_path { name: "compat-ld" path: "C:/mingw/bin/ld" } tool_path { name: "cpp" path: "C:/mingw/bin/cpp" } tool_path { name: "dwp" path: "C:/mingw/bin/dwp" } tool_path { name: "gcc" path: "C:/mingw/bin/gcc" } cxx_flag: "-std=c++0x" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "C:/mingw/include" cxx_builtin_include_directory: "C:/mingw/lib/gcc" tool_path { name: "gcov" path: "C:/mingw/bin/gcov" } tool_path { name: "ld" path: "C:/mingw/bin/ld" } tool_path { name: "nm" path: "C:/mingw/bin/nm" } tool_path { name: "objcopy" path: "C:/mingw/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "C:/mingw/bin/objdump" } tool_path { name: "strip" path: "C:/mingw/bin/strip" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "windows_msys64_mingw64" host_system_name: "local" needsPic: false target_libc: "local" target_cpu: "x64_windows" target_system_name: "local" toolchain_identifier: "local_windows_msys64_mingw64" tool_path { name: "ar" path: "C:/tools/msys64/mingw64/bin/ar" } tool_path { name: "compat-ld" path: "C:/tools/msys64/mingw64/bin/ld" } tool_path { name: "cpp" path: "C:/tools/msys64/mingw64/bin/cpp" } tool_path { name: "dwp" path: "C:/tools/msys64/mingw64/bin/dwp" } tool_path { name: "gcc" path: "C:/tools/msys64/mingw64/bin/gcc" } cxx_flag: "-std=c++0x" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "C:/tools/msys64/mingw64/x86_64-w64-mingw32/include" tool_path { name: "gcov" path: "C:/tools/msys64/mingw64/bin/gcov" } tool_path { name: "ld" path: "C:/tools/msys64/mingw64/bin/ld" } tool_path { name: "nm" path: "C:/tools/msys64/mingw64/bin/nm" } tool_path { name: "objcopy" path: "C:/tools/msys64/mingw64/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "C:/tools/msys64/mingw64/bin/objdump" } tool_path { name: "strip" path: "C:/tools/msys64/mingw64/bin/strip" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "windows_clang" host_system_name: "local" needsPic: false target_libc: "local" target_cpu: "x64_windows" target_system_name: "local" toolchain_identifier: "local_windows_clang" tool_path { name: "ar" path: "C:/mingw/bin/ar" } tool_path { name: "compat-ld" path: "C:/Program Files (x86)/LLVM/bin/ld" } tool_path { name: "cpp" path: "C:/Program Files (x86)/LLVM/bin/cpp" } tool_path { name: "dwp" path: "C:/Program Files (x86)/LLVM/bin/dwp" } tool_path { name: "gcc" path: "C:/Program Files (x86)/LLVM/bin/clang" } cxx_flag: "-std=c++0x" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "/usr/lib/gcc/" cxx_builtin_include_directory: "/usr/local/include" cxx_builtin_include_directory: "/usr/include" tool_path { name: "gcov" path: "C:/Program Files (x86)/LLVM/bin/gcov" } tool_path { name: "ld" path: "C:/Program Files (x86)/LLVM/bin/ld" } tool_path { name: "nm" path: "C:/Program Files (x86)/LLVM/bin/nm" } tool_path { name: "objcopy" path: "C:/Program Files (x86)/LLVM/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "C:/Program Files (x86)/LLVM/bin/objdump" } tool_path { name: "strip" path: "C:/Program Files (x86)/LLVM/bin/strip" } linking_mode_flags { mode: DYNAMIC } } toolchain { abi_version: "local" abi_libc_version: "local" builtin_sysroot: "" compiler: "windows_msys64" host_system_name: "local" needsPic: false target_libc: "local" target_cpu: "x64_windows" target_system_name: "local" toolchain_identifier: "local_windows_msys64" tool_path { name: "ar" path: "C:/tools/msys64/usr/bin/ar" } tool_path { name: "compat-ld" path: "C:/tools/msys64/usr/bin/ld" } tool_path { name: "cpp" path: "C:/tools/msys64/usr/bin/cpp" } tool_path { name: "dwp" path: "C:/tools/msys64/usr/bin/dwp" } # Use gcc instead of g++ so that C will compile correctly. tool_path { name: "gcc" path: "C:/tools/msys64/usr/bin/gcc" } cxx_flag: "-std=gnu++0x" linker_flag: "-lstdc++" # TODO(bazel-team): In theory, the path here ought to exactly match the path # used by gcc. That works because bazel currently doesn't track files at # absolute locations and has no remote execution, yet. However, this will need # to be fixed, maybe with auto-detection? cxx_builtin_include_directory: "C:/tools/msys64/" cxx_builtin_include_directory: "/usr/" tool_path { name: "gcov" path: "C:/tools/msys64/usr/bin/gcov" } tool_path { name: "ld" path: "C:/tools/msys64/usr/bin/ld" } tool_path { name: "nm" path: "C:/tools/msys64/usr/bin/nm" } tool_path { name: "objcopy" path: "C:/tools/msys64/usr/bin/objcopy" } objcopy_embed_flag: "-I" objcopy_embed_flag: "binary" tool_path { name: "objdump" path: "C:/tools/msys64/usr/bin/objdump" } tool_path { name: "strip" path: "C:/tools/msys64/usr/bin/strip" } linking_mode_flags { mode: DYNAMIC } } toolchain { toolchain_identifier: "vc_14_0_x64" host_system_name: "local" target_system_name: "local" abi_version: "local" abi_libc_version: "local" target_cpu: "x64_windows_msvc" compiler: "cl" target_libc: "msvcrt140" default_python_version: "python2.7" cxx_builtin_include_directory: "C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/INCLUDE" cxx_builtin_include_directory: "C:/Program Files (x86)/Windows Kits/10/include/" cxx_builtin_include_directory: "C:/Program Files (x86)/Windows Kits/8.1/include/" cxx_builtin_include_directory: "C:/Program Files (x86)/GnuWin32/include/" cxx_builtin_include_directory: "C:/python_27_amd64/files/include" tool_path { name: "ar" path: "wrapper/bin/msvc_link.bat" } tool_path { name: "cpp" path: "wrapper/bin/msvc_cl.bat" } tool_path { name: "gcc" path: "wrapper/bin/msvc_cl.bat" } tool_path { name: "gcov" path: "wrapper/bin/msvc_nop.bat" } tool_path { name: "ld" path: "wrapper/bin/msvc_link.bat" } tool_path { name: "nm" path: "wrapper/bin/msvc_nop.bat" } tool_path { name: "objcopy" path: "wrapper/bin/msvc_nop.bat" } tool_path { name: "objdump" path: "wrapper/bin/msvc_nop.bat" } tool_path { name: "strip" path: "wrapper/bin/msvc_nop.bat" } supports_gold_linker: false supports_start_end_lib: false supports_interface_shared_objects: false supports_incremental_linker: false supports_normalizing_ar: true needsPic: false compiler_flag: "-m64" compiler_flag: "/D__inline__=__inline" # TODO(pcloudy): Review those flags below, they should be defined by cl.exe compiler_flag: "/DCOMPILER_MSVC" # Don't pollute with GDI macros in windows.h. compiler_flag: "/DNOGDI" # Don't define min/max macros in windows.h. compiler_flag: "/DNOMINMAX" compiler_flag: "/DPRAGMA_SUPPORTED" # Platform defines. compiler_flag: "/D_WIN32_WINNT=0x0600" # Turn off warning messages. compiler_flag: "/D_CRT_SECURE_NO_DEPRECATE" compiler_flag: "/D_CRT_SECURE_NO_WARNINGS" compiler_flag: "/D_SILENCE_STDEXT_HASH_DEPRECATION_WARNINGS" # Use math constants (M_PI, etc.) from the math library compiler_flag: "/D_USE_MATH_DEFINES" # Useful options to have on for compilation. # Suppress startup banner. compiler_flag: "/nologo" # Increase the capacity of object files to 2^32 sections. compiler_flag: "/bigobj" # Allocate 500MB for precomputed headers. compiler_flag: "/Zm500" # Use unsigned char by default. compiler_flag: "/J" # Use function level linking. compiler_flag: "/Gy" # Use string pooling. compiler_flag: "/GF" # Warning level 3 (could possibly go to 4 in the future). compiler_flag: "/W3" # Catch both asynchronous (structured) and synchronous (C++) exceptions. compiler_flag: "/EHsc" # Globally disabled warnings. # Don't warn about elements of array being be default initialized. compiler_flag: "/wd4351" # Don't warn about no matching delete found. compiler_flag: "/wd4291" # Don't warn about diamond inheritance patterns. compiler_flag: "/wd4250" # Don't warn about insecure functions (e.g. non _s functions). compiler_flag: "/wd4996" linker_flag: "-m64" # Stop passing -frandom-seed option feature { name: 'random_seed' } action_config { config_name: 'c-compile' action_name: 'c-compile' tool { tool_path: 'wrapper/bin/msvc_cl.bat' } implies: 'compiler_input_flags' implies: 'compiler_output_flags' implies: 'legacy_compile_flags' implies: 'user_compile_flags' implies: 'sysroot' implies: 'unfiltered_compile_flags' } action_config { config_name: 'c++-compile' action_name: 'c++-compile' tool { tool_path: 'wrapper/bin/msvc_cl.bat' } implies: 'compiler_input_flags' implies: 'compiler_output_flags' implies: 'legacy_compile_flags' implies: 'user_compile_flags' implies: 'sysroot' implies: 'unfiltered_compile_flags' } # TODO(b/65151735): Remove legacy_compile_flags feature when legacy fields are # not used in this crosstool feature { name: 'legacy_compile_flags' flag_set { expand_if_all_available: 'legacy_compile_flags' action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' flag_group { iterate_over: 'legacy_compile_flags' flag: '%{legacy_compile_flags}' } } } feature { name: 'include_paths' flag_set { action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' flag_group { iterate_over: 'quote_include_paths' flag: '/I%{quote_include_paths}' } flag_group { iterate_over: 'include_paths' flag: '/I%{include_paths}' } flag_group { iterate_over: 'system_include_paths' flag: '/I%{system_include_paths}' } } } feature { name: 'dependency_file' flag_set { action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-module-compile' action: 'c++-header-parsing' expand_if_all_available: 'dependency_file' flag_group { flag: '/DEPENDENCY_FILE' flag: '%{dependency_file}' } } } feature { name: 'user_compile_flags' flag_set { expand_if_all_available: 'user_compile_flags' action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' flag_group { iterate_over: 'user_compile_flags' flag: '%{user_compile_flags}' } } } feature { name: 'sysroot' flag_set { expand_if_all_available: 'sysroot' action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' action: 'c++-link-executable' action: 'c++-link-dynamic-library' action: 'c++-link-nodeps-dynamic-library' flag_group { iterate_over: 'sysroot' flag: '--sysroot=%{sysroot}' } } } feature { name: 'unfiltered_compile_flags' flag_set { expand_if_all_available: 'unfiltered_compile_flags' action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' flag_group { iterate_over: 'unfiltered_compile_flags' flag: '%{unfiltered_compile_flags}' } } } feature { name: 'compiler_output_flags' flag_set { action: 'assemble' flag_group { expand_if_all_available: 'output_file' expand_if_none_available: 'output_assembly_file' expand_if_none_available: 'output_preprocess_file' flag: '/Fo%{output_file}' flag: '/Zi' } } flag_set { action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' flag_group { expand_if_all_available: 'output_file' expand_if_none_available: 'output_assembly_file' expand_if_none_available: 'output_preprocess_file' flag: '/Fo%{output_file}' } flag_group { expand_if_all_available: 'output_file' expand_if_all_available: 'output_assembly_file' flag: '/Fa%{output_file}' } flag_group { expand_if_all_available: 'output_file' expand_if_all_available: 'output_preprocess_file' flag: '/P' flag: '/Fi%{output_file}' } } } feature { name: 'compiler_input_flags' flag_set { action: 'assemble' action: 'preprocess-assemble' action: 'c-compile' action: 'c++-compile' action: 'c++-header-parsing' action: 'c++-module-compile' action: 'c++-module-codegen' flag_group { expand_if_all_available: 'source_file' flag: '/c' flag: '%{source_file}' } } } compilation_mode_flags { mode: DBG compiler_flag: "/DDEBUG=1" # This will signal the wrapper that we are doing a debug build, which sets # some internal state of the toolchain wrapper. It is intentionally a "-" # flag to make this very obvious. compiler_flag: "-g" compiler_flag: "/Od" compiler_flag: "-Xcompilation-mode=dbg" } compilation_mode_flags { mode: FASTBUILD compiler_flag: "/DNDEBUG" compiler_flag: "/Od" compiler_flag: "-Xcompilation-mode=fastbuild" } compilation_mode_flags { mode: OPT compiler_flag: "/DNDEBUG" compiler_flag: "/O2" compiler_flag: "-Xcompilation-mode=opt" } }