mirror of
https://codeberg.org/ziglings/exercises.git
synced 2025-01-13 10:16:30 +00:00
Merge pull request 'attempt at implementing #113 "Add a way to do one random exercise"' (#117) from hippietrail/exercises:random-exercise into main
Reviewed-on: https://codeberg.org/ziglings/exercises/pulls/117
This commit is contained in:
commit
94fe012c77
1 changed files with 31 additions and 0 deletions
31
build.zig
31
build.zig
|
@ -103,6 +103,8 @@ const Mode = enum {
|
||||||
normal,
|
normal,
|
||||||
/// Named build mode: `zig build -Dn=n`
|
/// Named build mode: `zig build -Dn=n`
|
||||||
named,
|
named,
|
||||||
|
/// Random build mode: `zig build -Drandom`
|
||||||
|
random,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub const logo =
|
pub const logo =
|
||||||
|
@ -158,6 +160,7 @@ pub fn build(b: *Build) !void {
|
||||||
false;
|
false;
|
||||||
const override_healed_path = b.option([]const u8, "healed-path", "Override healed path");
|
const override_healed_path = b.option([]const u8, "healed-path", "Override healed path");
|
||||||
const exno: ?usize = b.option(usize, "n", "Select exercise");
|
const exno: ?usize = b.option(usize, "n", "Select exercise");
|
||||||
|
const rand: ?bool = b.option(bool, "random", "Select random exercise");
|
||||||
|
|
||||||
const sep = std.fs.path.sep_str;
|
const sep = std.fs.path.sep_str;
|
||||||
const healed_path = if (override_healed_path) |path|
|
const healed_path = if (override_healed_path) |path|
|
||||||
|
@ -191,6 +194,33 @@ pub fn build(b: *Build) !void {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (rand) |_| {
|
||||||
|
// Random build mode: verifies one random exercise.
|
||||||
|
// like for 'exno' but chooses a random exersise number.
|
||||||
|
print("work in progress: check a random exercise\n", .{});
|
||||||
|
|
||||||
|
var prng = std.rand.DefaultPrng.init(blk: {
|
||||||
|
var seed: u64 = undefined;
|
||||||
|
try std.posix.getrandom(std.mem.asBytes(&seed));
|
||||||
|
break :blk seed;
|
||||||
|
});
|
||||||
|
const rnd = prng.random();
|
||||||
|
const ex = exercises[rnd.intRangeLessThan(usize, 0, exercises.len)];
|
||||||
|
|
||||||
|
print("random exercise: {s}\n", .{ex.main_file});
|
||||||
|
|
||||||
|
const zigling_step = b.step(
|
||||||
|
"random",
|
||||||
|
b.fmt("Check the solution of {s}", .{ex.main_file}),
|
||||||
|
);
|
||||||
|
b.default_step = zigling_step;
|
||||||
|
zigling_step.dependOn(&header_step.step);
|
||||||
|
const verify_step = ZiglingStep.create(b, ex, work_path, .random);
|
||||||
|
verify_step.step.dependOn(&header_step.step);
|
||||||
|
zigling_step.dependOn(&verify_step.step);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Normal build mode: verifies all exercises according to the recommended
|
// Normal build mode: verifies all exercises according to the recommended
|
||||||
// order.
|
// order.
|
||||||
const ziglings_step = b.step("ziglings", "Check all ziglings");
|
const ziglings_step = b.step("ziglings", "Check all ziglings");
|
||||||
|
@ -417,6 +447,7 @@ const ZiglingStep = struct {
|
||||||
const cmd = switch (self.mode) {
|
const cmd = switch (self.mode) {
|
||||||
.normal => "zig build",
|
.normal => "zig build",
|
||||||
.named => b.fmt("zig build -Dn={s}", .{key}),
|
.named => b.fmt("zig build -Dn={s}", .{key}),
|
||||||
|
.random => "zig build -Drandom",
|
||||||
};
|
};
|
||||||
|
|
||||||
print("\n{s}Edit exercises/{s} and run '{s}' again.{s}\n", .{
|
print("\n{s}Edit exercises/{s} and run '{s}' again.{s}\n", .{
|
||||||
|
|
Loading…
Reference in a new issue