add ex081 anon structs 2
parent
ae0dc2b282
commit
c0bbbee176
@ -0,0 +1,47 @@
|
||||
//
|
||||
// An anonymous struct value LITERAL (not to be confused with a
|
||||
// struct TYPE) uses '.{}' syntax:
|
||||
//
|
||||
// .{
|
||||
// .center_x = 15,
|
||||
// .center_y = 12,
|
||||
// .radius = 6,
|
||||
// }
|
||||
//
|
||||
// These literals are always evaluated entirely at compile-time.
|
||||
// The example above could be coerced into the i32 variant of the
|
||||
// "circle struct" from the last exercise.
|
||||
//
|
||||
// Or you can let them remain entirely anonymous as in this
|
||||
// example:
|
||||
//
|
||||
// fn bar(foo: anytype) void {
|
||||
// print("a:{} b:{}\n", .{foo.a, foo.b});
|
||||
// }
|
||||
//
|
||||
// bar(.{
|
||||
// .a = true,
|
||||
// .b = false,
|
||||
// });
|
||||
//
|
||||
// The example above prints "a:true b:false".
|
||||
//
|
||||
const print = @import("std").debug.print;
|
||||
|
||||
pub fn main() void {
|
||||
printCircle(.{
|
||||
.center_x = @as(u32, 205),
|
||||
.center_y = @as(u32, 187),
|
||||
.radius = @as(u32, 12),
|
||||
});
|
||||
}
|
||||
|
||||
// Please complete this function which prints an anonymous struct
|
||||
// representing a circle.
|
||||
fn printCircle(???) void {
|
||||
print("x:{} y:{} radius:{}\n", .{
|
||||
circle.center_x,
|
||||
circle.centaur_y,
|
||||
circle.radius,
|
||||
});
|
||||
}
|
@ -0,0 +1,8 @@
|
||||
41c41
|
||||
< fn printCircle(???) void {
|
||||
---
|
||||
> fn printCircle(circle: anytype) void {
|
||||
44c44
|
||||
< circle.centaur_y,
|
||||
---
|
||||
> circle.center_y,
|
Loading…
Reference in New Issue