mirror of
https://github.com/ziglang/zig.git
synced 2025-12-06 06:13:07 +00:00
compiler: Recognize -fno-sanitize=<...> in addition to -fsanitize=<...>.
This commit is contained in:
parent
7c5412c7a4
commit
c3e88a21fb
@ -7043,7 +7043,7 @@ joinpd1("fmsc-version="),
|
||||
.{
|
||||
.name = "fno-sanitize=",
|
||||
.syntax = .comma_joined,
|
||||
.zig_equivalent = .other,
|
||||
.zig_equivalent = .no_sanitize,
|
||||
.pd1 = true,
|
||||
.pd2 = false,
|
||||
.psl = false,
|
||||
|
||||
10
src/main.zig
10
src/main.zig
@ -2217,18 +2217,19 @@ fn buildOutputType(
|
||||
mod_opts.strip = false;
|
||||
create_module.opts.debug_format = .{ .dwarf = .@"64" };
|
||||
},
|
||||
.sanitize => {
|
||||
.sanitize, .no_sanitize => |t| {
|
||||
const enable = t == .sanitize;
|
||||
var san_it = std.mem.splitScalar(u8, it.only_arg, ',');
|
||||
var recognized_any = false;
|
||||
while (san_it.next()) |sub_arg| {
|
||||
if (mem.eql(u8, sub_arg, "undefined")) {
|
||||
mod_opts.sanitize_c = true;
|
||||
mod_opts.sanitize_c = enable;
|
||||
recognized_any = true;
|
||||
} else if (mem.eql(u8, sub_arg, "thread")) {
|
||||
mod_opts.sanitize_thread = true;
|
||||
mod_opts.sanitize_thread = enable;
|
||||
recognized_any = true;
|
||||
} else if (mem.eql(u8, sub_arg, "fuzzer") or mem.eql(u8, sub_arg, "fuzzer-no-link")) {
|
||||
mod_opts.fuzz = true;
|
||||
mod_opts.fuzz = enable;
|
||||
recognized_any = true;
|
||||
}
|
||||
}
|
||||
@ -5904,6 +5905,7 @@ pub const ClangArgIterator = struct {
|
||||
gdwarf32,
|
||||
gdwarf64,
|
||||
sanitize,
|
||||
no_sanitize,
|
||||
linker_script,
|
||||
dry_run,
|
||||
verbose,
|
||||
|
||||
@ -284,6 +284,10 @@ const known_options = [_]KnownOpt{
|
||||
.name = "fsanitize",
|
||||
.ident = "sanitize",
|
||||
},
|
||||
.{
|
||||
.name = "fno-sanitize",
|
||||
.ident = "no_sanitize",
|
||||
},
|
||||
.{
|
||||
.name = "T",
|
||||
.ident = "linker_script",
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user