Function fmtId [src]

Return a Formatter for a Zig identifier, escaping it with @"" syntax if needed. An empty {} format specifier escapes invalid identifiers, identifiers that shadow primitives and the reserved _ identifier. Add p to the specifier to render identifiers that shadow primitives unescaped. Add _ to the specifier to render the reserved _ identifier unescaped. p and _ can be combined, e.g. {p_}.

Prototype

pub fn fmtId(bytes: []const u8) std.fmt.Formatter(formatId)

Parameters

bytes: []const u8

Example

test fmtId { const expectFmt = std.testing.expectFmt; try expectFmt("@\"while\"", "{}", .{fmtId("while")}); try expectFmt("@\"while\"", "{p}", .{fmtId("while")}); try expectFmt("@\"while\"", "{_}", .{fmtId("while")}); try expectFmt("@\"while\"", "{p_}", .{fmtId("while")}); try expectFmt("@\"while\"", "{_p}", .{fmtId("while")}); try expectFmt("hello", "{}", .{fmtId("hello")}); try expectFmt("hello", "{p}", .{fmtId("hello")}); try expectFmt("hello", "{_}", .{fmtId("hello")}); try expectFmt("hello", "{p_}", .{fmtId("hello")}); try expectFmt("hello", "{_p}", .{fmtId("hello")}); try expectFmt("@\"type\"", "{}", .{fmtId("type")}); try expectFmt("type", "{p}", .{fmtId("type")}); try expectFmt("@\"type\"", "{_}", .{fmtId("type")}); try expectFmt("type", "{p_}", .{fmtId("type")}); try expectFmt("type", "{_p}", .{fmtId("type")}); try expectFmt("@\"_\"", "{}", .{fmtId("_")}); try expectFmt("@\"_\"", "{p}", .{fmtId("_")}); try expectFmt("_", "{_}", .{fmtId("_")}); try expectFmt("_", "{p_}", .{fmtId("_")}); try expectFmt("_", "{_p}", .{fmtId("_")}); try expectFmt("@\"i123\"", "{}", .{fmtId("i123")}); try expectFmt("i123", "{p}", .{fmtId("i123")}); try expectFmt("@\"4four\"", "{}", .{fmtId("4four")}); try expectFmt("_underscore", "{}", .{fmtId("_underscore")}); try expectFmt("@\"11\\\"23\"", "{}", .{fmtId("11\"23")}); try expectFmt("@\"11\\x0f23\"", "{}", .{fmtId("11\x0F23")}); // These are technically not currently legal in Zig. try expectFmt("@\"\"", "{}", .{fmtId("")}); try expectFmt("@\"\\x00\"", "{}", .{fmtId("\x00")}); }

Source

pub fn fmtId(bytes: []const u8) std.fmt.Formatter(formatId) { return .{ .data = bytes }; }