aboutsummaryrefslogtreecommitdiff
path: root/exercises
diff options
context:
space:
mode:
authorDave Gauer <dave@ratfactor.com>2022-03-19 20:00:10 -0400
committerDave Gauer <dave@ratfactor.com>2022-03-19 20:00:10 -0400
commitff50e76872ecc914fc21db0ee5d9b4f71ad8a30a (patch)
tree2e7b58482309d7ae5a06cca165306c4fec5195ad /exercises
parent8799c7a45ba34dce871aec36d9910cbfc319dace (diff)
downloadziglings-ff50e76872ecc914fc21db0ee5d9b4f71ad8a30a.tar.gz
ziglings-ff50e76872ecc914fc21db0ee5d9b4f71ad8a30a.tar.bz2
ziglings-ff50e76872ecc914fc21db0ee5d9b4f71ad8a30a.tar.xz
ziglings-ff50e76872ecc914fc21db0ee5d9b4f71ad8a30a.zip
Added comptime wizardry to 075 quiz8
Thanks to Helios on Discord for the wizardry!
Diffstat (limited to 'exercises')
-rw-r--r--exercises/075_quiz8.zig22
1 files changed, 15 insertions, 7 deletions
diff --git a/exercises/075_quiz8.zig b/exercises/075_quiz8.zig
index 1e026a4..e05830e 100644
--- a/exercises/075_quiz8.zig
+++ b/exercises/075_quiz8.zig
@@ -154,13 +154,21 @@ pub fn main() void {
const start = &a; // Archer's Point
const destination = &f; // Fox Pond
- // TODO: can we neaten this up????
- a.paths = a_paths[0..];
- b.paths = b_paths[0..];
- c.paths = c_paths[0..];
- d.paths = d_paths[0..];
- e.paths = e_paths[0..];
- f.paths = f_paths[0..];
+ // We could either have this:
+ //
+ // a.paths = a_paths[0..];
+ // b.paths = b_paths[0..];
+ // c.paths = c_paths[0..];
+ // d.paths = d_paths[0..];
+ // e.paths = e_paths[0..];
+ // f.paths = f_paths[0..];
+ //
+ // or this comptime wizardry:
+ //
+ const letters = [_][]const u8{ "a", "b", "c", "d", "e", "f" };
+ inline for (letters) |letter| {
+ @field(@This(), letter).paths = @field(@This(), letter ++ "_paths")[0..];
+ }
var notebook = HermitsNotebook{};
var working_note = NotebookEntry{