mirror of
https://github.com/ziglang/zig.git
synced 2025-02-02 20:21:35 +00:00
parent
7322aa1183
commit
bbda053f9e
@ -105,7 +105,7 @@ pub fn build(b: *std.Build) !void {
|
|||||||
|
|
||||||
if (!skip_install_lib_files) {
|
if (!skip_install_lib_files) {
|
||||||
b.installDirectory(InstallDirectoryOptions{
|
b.installDirectory(InstallDirectoryOptions{
|
||||||
.source_dir = "lib",
|
.source_dir = .{ .path = "lib" },
|
||||||
.install_dir = .lib,
|
.install_dir = .lib,
|
||||||
.install_subdir = "zig",
|
.install_subdir = "zig",
|
||||||
.exclude_extensions = &[_][]const u8{
|
.exclude_extensions = &[_][]const u8{
|
||||||
|
@ -1317,9 +1317,7 @@ pub fn addInstallFileWithDir(
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn addInstallDirectory(self: *Build, options: InstallDirectoryOptions) *Step.InstallDir {
|
pub fn addInstallDirectory(self: *Build, options: InstallDirectoryOptions) *Step.InstallDir {
|
||||||
const install_step = self.allocator.create(Step.InstallDir) catch @panic("OOM");
|
return Step.InstallDir.create(self, options);
|
||||||
install_step.* = Step.InstallDir.init(self, options);
|
|
||||||
return install_step;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn addCheckFile(
|
pub fn addCheckFile(
|
||||||
|
@ -564,7 +564,7 @@ pub fn installHeadersDirectory(
|
|||||||
dest_rel_path: []const u8,
|
dest_rel_path: []const u8,
|
||||||
) void {
|
) void {
|
||||||
return installHeadersDirectoryOptions(a, .{
|
return installHeadersDirectoryOptions(a, .{
|
||||||
.source_dir = src_dir_path,
|
.source_dir = .{ .path = src_dir_path },
|
||||||
.install_dir = .header,
|
.install_dir = .header,
|
||||||
.install_subdir = dest_rel_path,
|
.install_subdir = dest_rel_path,
|
||||||
});
|
});
|
||||||
|
@ -2,6 +2,7 @@ const std = @import("std");
|
|||||||
const mem = std.mem;
|
const mem = std.mem;
|
||||||
const fs = std.fs;
|
const fs = std.fs;
|
||||||
const Step = std.Build.Step;
|
const Step = std.Build.Step;
|
||||||
|
const FileSource = std.Build.FileSource;
|
||||||
const InstallDir = std.Build.InstallDir;
|
const InstallDir = std.Build.InstallDir;
|
||||||
const InstallDirStep = @This();
|
const InstallDirStep = @This();
|
||||||
|
|
||||||
@ -14,7 +15,7 @@ dest_builder: *std.Build,
|
|||||||
pub const base_id = .install_dir;
|
pub const base_id = .install_dir;
|
||||||
|
|
||||||
pub const Options = struct {
|
pub const Options = struct {
|
||||||
source_dir: []const u8,
|
source_dir: FileSource,
|
||||||
install_dir: InstallDir,
|
install_dir: InstallDir,
|
||||||
install_subdir: []const u8,
|
install_subdir: []const u8,
|
||||||
/// File paths which end in any of these suffixes will be excluded
|
/// File paths which end in any of these suffixes will be excluded
|
||||||
@ -29,7 +30,7 @@ pub const Options = struct {
|
|||||||
|
|
||||||
fn dupe(self: Options, b: *std.Build) Options {
|
fn dupe(self: Options, b: *std.Build) Options {
|
||||||
return .{
|
return .{
|
||||||
.source_dir = b.dupe(self.source_dir),
|
.source_dir = self.source_dir.dupe(b),
|
||||||
.install_dir = self.install_dir.dupe(b),
|
.install_dir = self.install_dir.dupe(b),
|
||||||
.install_subdir = b.dupe(self.install_subdir),
|
.install_subdir = b.dupe(self.install_subdir),
|
||||||
.exclude_extensions = b.dupeStrings(self.exclude_extensions),
|
.exclude_extensions = b.dupeStrings(self.exclude_extensions),
|
||||||
@ -38,18 +39,21 @@ pub const Options = struct {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
pub fn init(owner: *std.Build, options: Options) InstallDirStep {
|
pub fn create(owner: *std.Build, options: Options) *InstallDirStep {
|
||||||
owner.pushInstalledFile(options.install_dir, options.install_subdir);
|
owner.pushInstalledFile(options.install_dir, options.install_subdir);
|
||||||
return .{
|
const self = owner.allocator.create(InstallDirStep) catch @panic("OOM");
|
||||||
|
self.* = .{
|
||||||
.step = Step.init(.{
|
.step = Step.init(.{
|
||||||
.id = .install_dir,
|
.id = .install_dir,
|
||||||
.name = owner.fmt("install {s}/", .{options.source_dir}),
|
.name = owner.fmt("install {s}/", .{options.source_dir.getDisplayName()}),
|
||||||
.owner = owner,
|
.owner = owner,
|
||||||
.makeFn = make,
|
.makeFn = make,
|
||||||
}),
|
}),
|
||||||
.options = options.dupe(owner),
|
.options = options.dupe(owner),
|
||||||
.dest_builder = owner,
|
.dest_builder = owner,
|
||||||
};
|
};
|
||||||
|
options.source_dir.addStepDependencies(&self.step);
|
||||||
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make(step: *Step, prog_node: *std.Progress.Node) !void {
|
fn make(step: *Step, prog_node: *std.Progress.Node) !void {
|
||||||
@ -59,9 +63,10 @@ fn make(step: *Step, prog_node: *std.Progress.Node) !void {
|
|||||||
const arena = dest_builder.allocator;
|
const arena = dest_builder.allocator;
|
||||||
const dest_prefix = dest_builder.getInstallPath(self.options.install_dir, self.options.install_subdir);
|
const dest_prefix = dest_builder.getInstallPath(self.options.install_dir, self.options.install_subdir);
|
||||||
const src_builder = self.step.owner;
|
const src_builder = self.step.owner;
|
||||||
var src_dir = src_builder.build_root.handle.openIterableDir(self.options.source_dir, .{}) catch |err| {
|
const src_dir_path = self.options.source_dir.getPath2(src_builder, step);
|
||||||
|
var src_dir = src_builder.build_root.handle.openIterableDir(src_dir_path, .{}) catch |err| {
|
||||||
return step.fail("unable to open source directory '{}{s}': {s}", .{
|
return step.fail("unable to open source directory '{}{s}': {s}", .{
|
||||||
src_builder.build_root, self.options.source_dir, @errorName(err),
|
src_builder.build_root, src_dir_path, @errorName(err),
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
defer src_dir.close();
|
defer src_dir.close();
|
||||||
@ -75,7 +80,7 @@ fn make(step: *Step, prog_node: *std.Progress.Node) !void {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// relative to src build root
|
// relative to src build root
|
||||||
const src_sub_path = try fs.path.join(arena, &.{ self.options.source_dir, entry.path });
|
const src_sub_path = try fs.path.join(arena, &.{ src_dir_path, entry.path });
|
||||||
const dest_path = try fs.path.join(arena, &.{ dest_prefix, entry.path });
|
const dest_path = try fs.path.join(arena, &.{ dest_prefix, entry.path });
|
||||||
const cwd = fs.cwd();
|
const cwd = fs.cwd();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user