mirror of
https://github.com/ziglang/zig.git
synced 2025-12-07 23:03:08 +00:00
test/link: refactor common bits between ELF and MachO tests
This commit is contained in:
parent
7566a8fbd8
commit
17177727c0
@ -3480,109 +3480,25 @@ fn testZText(b: *Build, opts: Options) *Step {
|
|||||||
return test_step;
|
return test_step;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Options = struct {
|
|
||||||
target: CrossTarget = .{ .cpu_arch = .x86_64, .os_tag = .linux },
|
|
||||||
optimize: std.builtin.OptimizeMode = .Debug,
|
|
||||||
use_llvm: bool = true,
|
|
||||||
use_lld: bool = false,
|
|
||||||
};
|
|
||||||
|
|
||||||
fn addTestStep(b: *Build, comptime prefix: []const u8, opts: Options) *Step {
|
fn addTestStep(b: *Build, comptime prefix: []const u8, opts: Options) *Step {
|
||||||
const target = opts.target.zigTriple(b.allocator) catch @panic("OOM");
|
return link.addTestStep(b, "elf-" ++ prefix, opts);
|
||||||
const optimize = @tagName(opts.optimize);
|
|
||||||
const use_llvm = if (opts.use_llvm) "llvm" else "no-llvm";
|
|
||||||
const name = std.fmt.allocPrint(b.allocator, "test-elf-" ++ prefix ++ "-{s}-{s}-{s}", .{
|
|
||||||
target,
|
|
||||||
optimize,
|
|
||||||
use_llvm,
|
|
||||||
}) catch @panic("OOM");
|
|
||||||
return b.step(name, "");
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addExecutable(b: *Build, name: []const u8, opts: Options) *Compile {
|
|
||||||
return b.addExecutable(.{
|
|
||||||
.name = name,
|
|
||||||
.target = opts.target,
|
|
||||||
.optimize = opts.optimize,
|
|
||||||
.use_llvm = opts.use_llvm,
|
|
||||||
.use_lld = opts.use_lld,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addObject(b: *Build, name: []const u8, opts: Options) *Compile {
|
|
||||||
return b.addObject(.{
|
|
||||||
.name = name,
|
|
||||||
.target = opts.target,
|
|
||||||
.optimize = opts.optimize,
|
|
||||||
.use_llvm = opts.use_llvm,
|
|
||||||
.use_lld = opts.use_lld,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addStaticLibrary(b: *Build, name: []const u8, opts: Options) *Compile {
|
|
||||||
return b.addStaticLibrary(.{
|
|
||||||
.name = name,
|
|
||||||
.target = opts.target,
|
|
||||||
.optimize = opts.optimize,
|
|
||||||
.use_llvm = opts.use_llvm,
|
|
||||||
.use_lld = opts.use_lld,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addSharedLibrary(b: *Build, name: []const u8, opts: Options) *Compile {
|
|
||||||
return b.addSharedLibrary(.{
|
|
||||||
.name = name,
|
|
||||||
.target = opts.target,
|
|
||||||
.optimize = opts.optimize,
|
|
||||||
.use_llvm = opts.use_llvm,
|
|
||||||
.use_lld = opts.use_lld,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addRunArtifact(comp: *Compile) *Run {
|
|
||||||
const b = comp.step.owner;
|
|
||||||
const run = b.addRunArtifact(comp);
|
|
||||||
run.skip_foreign_checks = true;
|
|
||||||
return run;
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addZigSourceBytes(comp: *Compile, bytes: []const u8) void {
|
|
||||||
const b = comp.step.owner;
|
|
||||||
const file = WriteFile.create(b).add("a.zig", bytes);
|
|
||||||
file.addStepDependencies(&comp.step);
|
|
||||||
comp.root_src = file;
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addCSourceBytes(comp: *Compile, bytes: []const u8, flags: []const []const u8) void {
|
|
||||||
const b = comp.step.owner;
|
|
||||||
const file = WriteFile.create(b).add("a.c", bytes);
|
|
||||||
comp.addCSourceFile(.{ .file = file, .flags = flags });
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addCppSourceBytes(comp: *Compile, bytes: []const u8, flags: []const []const u8) void {
|
|
||||||
const b = comp.step.owner;
|
|
||||||
const file = WriteFile.create(b).add("a.cpp", bytes);
|
|
||||||
comp.addCSourceFile(.{ .file = file, .flags = flags });
|
|
||||||
}
|
|
||||||
|
|
||||||
fn addAsmSourceBytes(comp: *Compile, bytes: []const u8) void {
|
|
||||||
const b = comp.step.owner;
|
|
||||||
const actual_bytes = std.fmt.allocPrint(b.allocator, "{s}\n", .{bytes}) catch @panic("OOM");
|
|
||||||
const file = WriteFile.create(b).add("a.s", actual_bytes);
|
|
||||||
comp.addAssemblyFile(file);
|
|
||||||
}
|
|
||||||
|
|
||||||
fn expectLinkErrors(comp: *Compile, test_step: *Step, expected_errors: Compile.ExpectedCompileErrors) void {
|
|
||||||
comp.expect_errors = expected_errors;
|
|
||||||
const bin_file = comp.getEmittedBin();
|
|
||||||
bin_file.addStepDependencies(test_step);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const addAsmSourceBytes = link.addAsmSourceBytes;
|
||||||
|
const addCSourceBytes = link.addCSourceBytes;
|
||||||
|
const addCppSourceBytes = link.addCppSourceBytes;
|
||||||
|
const addExecutable = link.addExecutable;
|
||||||
|
const addObject = link.addObject;
|
||||||
|
const addRunArtifact = link.addRunArtifact;
|
||||||
|
const addSharedLibrary = link.addSharedLibrary;
|
||||||
|
const addStaticLibrary = link.addStaticLibrary;
|
||||||
|
const addZigSourceBytes = link.addZigSourceBytes;
|
||||||
|
const expectLinkErrors = link.expectLinkErrors;
|
||||||
|
const link = @import("link.zig");
|
||||||
const std = @import("std");
|
const std = @import("std");
|
||||||
|
|
||||||
const Build = std.Build;
|
const Build = std.Build;
|
||||||
const Compile = Step.Compile;
|
|
||||||
const CrossTarget = std.zig.CrossTarget;
|
const CrossTarget = std.zig.CrossTarget;
|
||||||
const Run = Step.Run;
|
const Options = link.Options;
|
||||||
const Step = Build.Step;
|
const Step = Build.Step;
|
||||||
const WriteFile = Step.WriteFile;
|
const WriteFile = Step.WriteFile;
|
||||||
|
|||||||
@ -77,11 +77,14 @@ fn testResolvingBoundarySymbols(b: *Build, opts: Options) *Step {
|
|||||||
return test_step;
|
return test_step;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn addTestStep(b: *Build, comptime prefix: []const u8, opts: Options) *Step {
|
||||||
|
return link.addTestStep(b, "macho-" ++ prefix, opts);
|
||||||
|
}
|
||||||
|
|
||||||
const addCppSourceBytes = link.addCppSourceBytes;
|
const addCppSourceBytes = link.addCppSourceBytes;
|
||||||
const addExecutable = link.addExecutable;
|
const addExecutable = link.addExecutable;
|
||||||
const addObject = link.addObject;
|
const addObject = link.addObject;
|
||||||
const addRunArtifact = link.addRunArtifact;
|
const addRunArtifact = link.addRunArtifact;
|
||||||
const addTestStep = link.addTestStep;
|
|
||||||
const addZigSourceBytes = link.addZigSourceBytes;
|
const addZigSourceBytes = link.addZigSourceBytes;
|
||||||
const expectLinkErrors = link.expectLinkErrors;
|
const expectLinkErrors = link.expectLinkErrors;
|
||||||
const link = @import("link.zig");
|
const link = @import("link.zig");
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user