fix: make modules depend on codegen
This commit is contained in:
parent
8c68dd6902
commit
303af8661c
2 changed files with 75 additions and 66 deletions
139
build.zig
139
build.zig
|
@ -64,17 +64,6 @@ pub fn build(b: *Builder) !void {
|
||||||
const smithy_module = smithy_dep.module("smithy");
|
const smithy_module = smithy_dep.module("smithy");
|
||||||
exe.root_module.addImport("smithy", smithy_module); // not sure this should be here...
|
exe.root_module.addImport("smithy", smithy_module); // not sure this should be here...
|
||||||
|
|
||||||
// Expose module to others
|
|
||||||
_ = b.addModule("aws", .{
|
|
||||||
.root_source_file = b.path("src/aws.zig"),
|
|
||||||
.imports = &.{.{ .name = "smithy", .module = smithy_module }},
|
|
||||||
});
|
|
||||||
|
|
||||||
// Expose module to others
|
|
||||||
_ = b.addModule("aws-signing", .{
|
|
||||||
.root_source_file = b.path("src/aws_signing.zig"),
|
|
||||||
.imports = &.{.{ .name = "smithy", .module = smithy_module }},
|
|
||||||
});
|
|
||||||
// TODO: This does not work correctly due to https://github.com/ziglang/zig/issues/16354
|
// TODO: This does not work correctly due to https://github.com/ziglang/zig/issues/16354
|
||||||
//
|
//
|
||||||
// We are working here with kind of a weird dependency though. So we can do this
|
// We are working here with kind of a weird dependency though. So we can do this
|
||||||
|
@ -97,61 +86,81 @@ pub fn build(b: *Builder) !void {
|
||||||
const run_step = b.step("run", "Run the app");
|
const run_step = b.step("run", "Run the app");
|
||||||
run_step.dependOn(&run_cmd.step);
|
run_step.dependOn(&run_cmd.step);
|
||||||
|
|
||||||
const gen_step = blk: {
|
const cg = b.step("gen", "Generate zig service code from smithy models");
|
||||||
const cg = b.step("gen", "Generate zig service code from smithy models");
|
|
||||||
|
|
||||||
const cg_exe = b.addExecutable(.{
|
const cg_exe = b.addExecutable(.{
|
||||||
.name = "codegen",
|
.name = "codegen",
|
||||||
.root_source_file = b.path("codegen/src/main.zig"),
|
.root_source_file = b.path("codegen/src/main.zig"),
|
||||||
// We need this generated for the host, not the real target
|
// We need this generated for the host, not the real target
|
||||||
.target = b.graph.host,
|
.target = b.graph.host,
|
||||||
.optimize = if (b.verbose) .Debug else .ReleaseSafe,
|
.optimize = if (b.verbose) .Debug else .ReleaseSafe,
|
||||||
});
|
});
|
||||||
cg_exe.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
cg_exe.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
||||||
var cg_cmd = b.addRunArtifact(cg_exe);
|
var cg_cmd = b.addRunArtifact(cg_exe);
|
||||||
cg_cmd.addArg("--models");
|
cg_cmd.addArg("--models");
|
||||||
const hash = hash_blk: {
|
const hash = hash_blk: {
|
||||||
for (b.available_deps) |dep| {
|
for (b.available_deps) |dep| {
|
||||||
const dep_name = dep.@"0";
|
const dep_name = dep.@"0";
|
||||||
const dep_hash = dep.@"1";
|
const dep_hash = dep.@"1";
|
||||||
if (std.mem.eql(u8, dep_name, "models"))
|
if (std.mem.eql(u8, dep_name, "models"))
|
||||||
break :hash_blk dep_hash;
|
break :hash_blk dep_hash;
|
||||||
}
|
}
|
||||||
return error.DependencyNamedModelsNotFoundInBuildZigZon;
|
return error.DependencyNamedModelsNotFoundInBuildZigZon;
|
||||||
};
|
|
||||||
cg_cmd.addArg(try std.fs.path.join(
|
|
||||||
b.allocator,
|
|
||||||
&[_][]const u8{
|
|
||||||
b.graph.global_cache_root.path.?,
|
|
||||||
"p",
|
|
||||||
hash,
|
|
||||||
models_subdir,
|
|
||||||
},
|
|
||||||
));
|
|
||||||
cg_cmd.addArg("--output");
|
|
||||||
cg_cmd.addDirectoryArg(b.path("src/models"));
|
|
||||||
if (b.verbose)
|
|
||||||
cg_cmd.addArg("--verbose");
|
|
||||||
// cg_cmd.step.dependOn(&fetch_step.step);
|
|
||||||
// TODO: this should use zig_exe from std.Build
|
|
||||||
// codegen should store a hash in a comment
|
|
||||||
// this would be hash of the exe that created the file
|
|
||||||
// concatenated with hash of input json. this would
|
|
||||||
// allow skipping generated files. May not include hash
|
|
||||||
// of contents of output file as maybe we want to tweak
|
|
||||||
// manually??
|
|
||||||
//
|
|
||||||
// All the hashes can be in service_manifest.zig, which
|
|
||||||
// could be fun to just parse and go nuts. Top of
|
|
||||||
// file, generator exe hash. Each import has comment
|
|
||||||
// with both input and output hash and we can decide
|
|
||||||
// later about warning on manual changes...
|
|
||||||
|
|
||||||
cg.dependOn(&cg_cmd.step);
|
|
||||||
break :blk cg;
|
|
||||||
};
|
};
|
||||||
|
cg_cmd.addArg(try std.fs.path.join(
|
||||||
|
b.allocator,
|
||||||
|
&[_][]const u8{
|
||||||
|
b.graph.global_cache_root.path.?,
|
||||||
|
"p",
|
||||||
|
hash,
|
||||||
|
models_subdir,
|
||||||
|
},
|
||||||
|
));
|
||||||
|
cg_cmd.addArg("--output");
|
||||||
|
const cg_output_dir = cg_cmd.addOutputDirectoryArg("src/models");
|
||||||
|
if (b.verbose)
|
||||||
|
cg_cmd.addArg("--verbose");
|
||||||
|
// cg_cmd.step.dependOn(&fetch_step.step);
|
||||||
|
// TODO: this should use zig_exe from std.Build
|
||||||
|
// codegen should store a hash in a comment
|
||||||
|
// this would be hash of the exe that created the file
|
||||||
|
// concatenated with hash of input json. this would
|
||||||
|
// allow skipping generated files. May not include hash
|
||||||
|
// of contents of output file as maybe we want to tweak
|
||||||
|
// manually??
|
||||||
|
//
|
||||||
|
// All the hashes can be in service_manifest.zig, which
|
||||||
|
// could be fun to just parse and go nuts. Top of
|
||||||
|
// file, generator exe hash. Each import has comment
|
||||||
|
// with both input and output hash and we can decide
|
||||||
|
// later about warning on manual changes...
|
||||||
|
|
||||||
exe.step.dependOn(gen_step);
|
cg.dependOn(&cg_cmd.step);
|
||||||
|
|
||||||
|
exe.step.dependOn(cg);
|
||||||
|
|
||||||
|
// This allows us to have each module depend on the
|
||||||
|
// generated service manifest.
|
||||||
|
const service_manifest_module = b.createModule(.{
|
||||||
|
.root_source_file = cg_output_dir.path(b, "service_manifest.zig"),
|
||||||
|
.target = target,
|
||||||
|
.optimize = optimize,
|
||||||
|
});
|
||||||
|
|
||||||
|
// Expose module to others
|
||||||
|
_ = b.addModule("aws", .{
|
||||||
|
.root_source_file = b.path("src/aws.zig"),
|
||||||
|
.imports = &.{
|
||||||
|
.{ .name = "smithy", .module = smithy_module },
|
||||||
|
.{ .name = "service_manifest", .module = service_manifest_module },
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
// Expose module to others
|
||||||
|
_ = b.addModule("aws-signing", .{
|
||||||
|
.root_source_file = b.path("src/aws_signing.zig"),
|
||||||
|
.imports = &.{.{ .name = "smithy", .module = smithy_module }},
|
||||||
|
});
|
||||||
|
|
||||||
// Similar to creating the run step earlier, this exposes a `test` step to
|
// Similar to creating the run step earlier, this exposes a `test` step to
|
||||||
// the `zig build --help` menu, providing a way for the user to request
|
// the `zig build --help` menu, providing a way for the user to request
|
||||||
|
@ -182,7 +191,7 @@ pub fn build(b: *Builder) !void {
|
||||||
.optimize = optimize,
|
.optimize = optimize,
|
||||||
});
|
});
|
||||||
unit_tests.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
unit_tests.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
||||||
unit_tests.step.dependOn(gen_step);
|
unit_tests.step.dependOn(cg);
|
||||||
|
|
||||||
const run_unit_tests = b.addRunArtifact(unit_tests);
|
const run_unit_tests = b.addRunArtifact(unit_tests);
|
||||||
run_unit_tests.skip_foreign_checks = true;
|
run_unit_tests.skip_foreign_checks = true;
|
||||||
|
@ -205,7 +214,7 @@ pub fn build(b: *Builder) !void {
|
||||||
.optimize = optimize,
|
.optimize = optimize,
|
||||||
});
|
});
|
||||||
smoke_test.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
smoke_test.root_module.addImport("smithy", smithy_dep.module("smithy"));
|
||||||
smoke_test.step.dependOn(gen_step);
|
smoke_test.step.dependOn(cg);
|
||||||
|
|
||||||
const run_smoke_test = b.addRunArtifact(smoke_test);
|
const run_smoke_test = b.addRunArtifact(smoke_test);
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
const std = @import("std");
|
const std = @import("std");
|
||||||
const service_list = @import("models/service_manifest.zig");
|
const service_list = @import("service_manifest");
|
||||||
const expectEqualStrings = std.testing.expectEqualStrings;
|
const expectEqualStrings = std.testing.expectEqualStrings;
|
||||||
|
|
||||||
pub fn Services(comptime service_imports: anytype) type {
|
pub fn Services(comptime service_imports: anytype) type {
|
||||||
|
|
Loading…
Add table
Reference in a new issue