mirror of
https://codeberg.org/ziglings/exercises.git
synced 2026-06-08 07:50:00 +00:00
The first exercise introduces the `packed` keyword as an alternative for bitwise operations. Its main goals are establishing a solid understanding of field order and conveying the fact that packed containers are basically integers. It introduces the concept of container layouts and briefly explains the default `auto` layout before introducing the `packed` layout (but doesn't touch `extern` at all). The exercise also presents a real-world use case for packed containers, namely LZ4 frame descriptors. Furthermore it covers equality comparisons between packed containers. The second exercise talks about switch statements with packed containers and goes into some more detail on packed unions.
33 lines
998 B
Diff
33 lines
998 B
Diff
--- exercises/112_packed2.zig 2026-03-13 11:14:08
|
|
+++ answers/112_packed2.zig 2026-03-13 11:14:16
|
|
@@ -13,9 +13,9 @@
|
|
const s: S = .{ .a = true, .b = -1 };
|
|
switch (s) {
|
|
.{ .a = true, .b = -1 } => {}, // ok!
|
|
- .{ .a = true, .b = ??? },
|
|
- .{ .a = ???, .b = 0 },
|
|
- .{ .a = ???, .b = ??? },
|
|
+ .{ .a = true, .b = 0 },
|
|
+ .{ .a = false, .b = 0 },
|
|
+ .{ .a = false, .b = -1 },
|
|
=> @compileError("We don't want to end up here!"),
|
|
}
|
|
}
|
|
@@ -39,7 +39,6 @@
|
|
.{ .a = 3 } => {}, // ok!
|
|
.{ .a = 2 },
|
|
.{ .b = 1 },
|
|
- .{ .b = -1 },
|
|
.{ .a = 0 },
|
|
=> @compileError("We don't want to end up here!"),
|
|
}
|
|
@@ -65,7 +64,7 @@
|
|
// Reminder: if the sign bit of a float is set, the number is negative!
|
|
|
|
var number: Float = .{ .value = 2.34 };
|
|
- number.bits.??? = ???;
|
|
+ number.bits.sign = 1;
|
|
if (number.value != -2.34) {
|
|
std.debug.print("Make it negative!\n", .{});
|
|
}
|