zig/lib/std/os/uefi/protocol/shell_parameters.zig
Andrew Kelley a31748b29e std.os.uefi: reorganize namespaces
This is a breaking change.

This commit applies the following rules to std.os.uefi:
* avoid redundant names in the namespace such as "protocol.FooProtocol"
* don't initialize struct field to undefined. do that at the
  initialization site if you want that, or create a named constant that
  sets all the fields to undefined.
* avoid the word "data", "info", "context", "state", "details", or
  "config" in the type name, especially if a word from that category is
  already in the type name.
* embrace tree structure

After following these rules, `usingnamespace` disappeared naturally.
This commit eliminates 26/53 (49%) instances of `usingnamespace` in the
standard library. All these uses were due to not understanding how
to properly use namespaces.

I did not test this commit. The standard library UEFI code is
experimental and pull requests have been accepted with minimal vetting.
Users of std.os.uefi will need to submit follow-up pull requests to fix
up whatever regressions this commit introduces, this time without
abusing namespaces (pun intended).
2023-08-24 22:38:47 -07:00

20 lines
544 B
Zig

const uefi = @import("std").os.uefi;
const Guid = uefi.Guid;
const FileHandle = uefi.FileHandle;
pub const ShellParameters = extern struct {
argv: [*][*:0]const u16,
argc: usize,
stdin: FileHandle,
stdout: FileHandle,
stderr: FileHandle,
pub const guid align(8) = Guid{
.time_low = 0x752f3136,
.time_mid = 0x4e16,
.time_high_and_version = 0x4fdc,
.clock_seq_high_and_reserved = 0xa2,
.clock_seq_low = 0x2a,
.node = [_]u8{ 0xe5, 0xf4, 0x68, 0x12, 0xf4, 0xca },
};
};