|
1 | 1 | const std = @import("std");
|
| 2 | +const ArrayList = std.ArrayListUnmanaged; // this should be deleted when zig 0.14 support is no longer necessary |
| 3 | +const StringHashMap = std.StringHashMapUnmanaged; // this should be deleted when zig 0.14 support is no longer necessary |
2 | 4 |
|
3 |
| -const String = std.ArrayList(u8); |
4 |
| -const Database = std.StringHashMap(void); |
| 5 | +const String = ArrayList(u8); |
| 6 | +const Database = StringHashMap(void); |
5 | 7 |
|
6 | 8 | pub const DefineState = struct {
|
7 |
| - allocator: std.mem.Allocator, |
8 | 9 | database: Database,
|
9 |
| - definitions: std.ArrayList(String), |
10 |
| - |
11 |
| - pub fn init(alloc: std.mem.Allocator) DefineState { |
12 |
| - return DefineState{ |
13 |
| - .allocator = alloc, |
14 |
| - .database = .init(alloc), |
15 |
| - .definitions = .init(alloc), |
16 |
| - }; |
17 |
| - } |
| 10 | + definitions: ArrayList(String), |
| 11 | + |
| 12 | + pub const empty: DefineState = .{ |
| 13 | + .database = .empty, |
| 14 | + .definitions = .empty, |
| 15 | + }; |
18 | 16 |
|
19 |
| - pub fn deinit(self: *@This()) void { |
20 |
| - for (self.definitions.items) |def| { |
21 |
| - def.deinit(); |
| 17 | + pub fn deinit(self: *DefineState, gpa: std.mem.Allocator) void { |
| 18 | + for (self.definitions.items) |*def| { |
| 19 | + def.deinit(gpa); |
22 | 20 | }
|
23 |
| - defer self.database.deinit(); |
24 |
| - defer self.definitions.deinit(); |
| 21 | + self.database.deinit(gpa); |
| 22 | + self.definitions.deinit(gpa); |
| 23 | + self.* = undefined; |
25 | 24 | }
|
26 | 25 | };
|
27 | 26 |
|
28 | 27 | pub fn define(
|
29 |
| - alloc: std.mem.Allocator, |
| 28 | + gpa: std.mem.Allocator, |
30 | 29 | absolute_output_path: []const u8,
|
31 | 30 | comptime to_define: []const type,
|
32 | 31 | ) !void {
|
33 |
| - var state: DefineState = .init(alloc); |
34 |
| - defer state.deinit(); |
| 32 | + var state: DefineState = .empty; |
| 33 | + defer state.deinit(gpa); |
35 | 34 |
|
36 | 35 | inline for (to_define) |T| {
|
37 | 36 | _ = try addClass(&state, T);
|
@@ -66,100 +65,104 @@ fn name(comptime T: type) []const u8 {
|
66 | 65 |
|
67 | 66 | fn addEnum(
|
68 | 67 | state: *DefineState,
|
| 68 | + gpa: std.mem.Allocator, |
69 | 69 | comptime T: type,
|
70 | 70 | ) !void {
|
71 | 71 | if (state.database.contains(@typeName(T)) == false) {
|
72 |
| - try state.database.put(@typeName(T), {}); |
73 |
| - try state.definitions.append(String.init(state.allocator)); |
74 |
| - const index = state.definitions.items.len - 1; |
| 72 | + try state.database.put(gpa, @typeName(T), {}); |
| 73 | + const item = try state.definitions.addOne(gpa); |
| 74 | + item.* = .empty; |
75 | 75 |
|
76 |
| - try state.definitions.items[index].appendSlice("---@alias "); |
77 |
| - try state.definitions.items[index].appendSlice(name(T)); |
78 |
| - try state.definitions.items[index].appendSlice("\n"); |
| 76 | + try item.appendSlice(gpa, "---@alias "); |
| 77 | + try item.appendSlice(gpa, name(T)); |
| 78 | + try item.appendSlice(gpa, "\n"); |
79 | 79 |
|
80 | 80 | inline for (@typeInfo(T).@"enum".fields) |field| {
|
81 |
| - try state.definitions.items[index].appendSlice("---|\' \""); |
82 |
| - try state.definitions.items[index].appendSlice(field.name); |
83 |
| - try state.definitions.items[index].appendSlice("\" \'\n"); |
| 81 | + try item.appendSlice(gpa, "---|\' \""); |
| 82 | + try item.appendSlice(gpa, field.name); |
| 83 | + try item.appendSlice(gpa, "\" \'\n"); |
84 | 84 | }
|
85 | 85 | }
|
86 | 86 | }
|
87 | 87 |
|
88 | 88 | pub fn addClass(
|
89 | 89 | state: *DefineState,
|
| 90 | + gpa: std.mem.Allocator, |
90 | 91 | comptime T: type,
|
91 | 92 | ) !void {
|
92 | 93 | if (state.database.contains(@typeName(T)) == false) {
|
93 |
| - try state.database.put(@typeName(T), {}); |
94 |
| - try state.definitions.append(String.init(state.allocator)); |
95 |
| - const index = state.definitions.items.len - 1; |
| 94 | + try state.database.put(gpa, @typeName(T), {}); |
| 95 | + const item = try state.definitions.addOne(gpa); |
| 96 | + const idx = state.definitions.items.len - 1; |
| 97 | + item.* = .empty; |
96 | 98 |
|
97 |
| - try state.definitions.items[index].appendSlice("---@class (exact) "); |
98 |
| - try state.definitions.items[index].appendSlice(name(T)); |
99 |
| - try state.definitions.items[index].appendSlice("\n"); |
| 99 | + try item.appendSlice(gpa, "---@class (exact) "); |
| 100 | + try item.appendSlice(gpa, name(T)); |
| 101 | + try item.appendSlice(gpa, "\n"); |
100 | 102 |
|
101 | 103 | inline for (@typeInfo(T).@"struct".fields) |field| {
|
102 |
| - try state.definitions.items[index].appendSlice("---@field "); |
103 |
| - try state.definitions.items[index].appendSlice(field.name); |
| 104 | + try item.appendSlice(gpa, "---@field "); |
| 105 | + try item.appendSlice(gpa, field.name); |
104 | 106 |
|
105 | 107 | if (field.defaultValue() != null) {
|
106 |
| - try state.definitions.items[index].appendSlice("?"); |
| 108 | + try item.appendSlice(gpa, "?"); |
107 | 109 | }
|
108 |
| - try state.definitions.items[index].appendSlice(" "); |
109 |
| - try luaTypeName(state, index, field.type); |
110 |
| - try state.definitions.items[index].appendSlice("\n"); |
| 110 | + try item.appendSlice(gpa, " "); |
| 111 | + try luaTypeName(state, gpa, idx, field.type); |
| 112 | + try state.definitions.items[idx].appendSlice(gpa, "\n"); |
111 | 113 | }
|
112 | 114 | }
|
113 | 115 | }
|
114 | 116 |
|
115 | 117 | fn luaTypeName(
|
116 | 118 | state: *DefineState,
|
| 119 | + gpa: std.mem.Allocator, |
117 | 120 | index: usize,
|
118 | 121 | comptime T: type,
|
119 | 122 | ) !void {
|
120 | 123 | switch (@typeInfo(T)) {
|
121 | 124 | .@"struct" => {
|
122 |
| - try state.definitions.items[index].appendSlice(name(T)); |
123 |
| - try addClass(state, T); |
| 125 | + try state.definitions.items[index].appendSlice(gpa, name(T)); |
| 126 | + try addClass(state, gpa, T); |
124 | 127 | },
|
125 | 128 | .pointer => |info| {
|
126 | 129 | if (info.child == u8 and info.size == .slice) {
|
127 |
| - try state.definitions.items[index].appendSlice("string"); |
| 130 | + try state.definitions.items[index].appendSlice(gpa, "string"); |
128 | 131 | } else switch (info.size) {
|
129 | 132 | .one => {
|
130 |
| - try state.definitions.items[index].appendSlice("lightuserdata"); |
| 133 | + try state.definitions.items[index].appendSlice(gpa, "lightuserdata"); |
131 | 134 | },
|
132 | 135 | .c, .many, .slice => {
|
133 |
| - try luaTypeName(state, index, info.child); |
134 |
| - try state.definitions.items[index].appendSlice("[]"); |
| 136 | + try luaTypeName(state, gpa, index, info.child); |
| 137 | + try state.definitions.items[index].appendSlice(gpa, "[]"); |
135 | 138 | },
|
136 | 139 | }
|
137 | 140 | },
|
138 | 141 | .array => |info| {
|
139 |
| - try luaTypeName(state, index, info.child); |
140 |
| - try state.definitions.items[index].appendSlice("[]"); |
| 142 | + try luaTypeName(state, gpa, index, info.child); |
| 143 | + try state.definitions.items[index].appendSlice(gpa, "[]"); |
141 | 144 | },
|
142 | 145 |
|
143 | 146 | .vector => |info| {
|
144 |
| - try luaTypeName(state, index, info.child); |
145 |
| - try state.definitions.items[index].appendSlice("[]"); |
| 147 | + try luaTypeName(state, gpa, index, info.child); |
| 148 | + try state.definitions.items[index].appendSlice(gpa, "[]"); |
146 | 149 | },
|
147 | 150 | .optional => |info| {
|
148 |
| - try luaTypeName(state, index, info.child); |
149 |
| - try state.definitions.items[index].appendSlice(" | nil"); |
| 151 | + try luaTypeName(state, gpa, index, info.child); |
| 152 | + try state.definitions.items[index].appendSlice(gpa, " | nil"); |
150 | 153 | },
|
151 | 154 | .@"enum" => {
|
152 |
| - try state.definitions.items[index].appendSlice(name(T)); |
153 |
| - try addEnum(state, T); |
| 155 | + try state.definitions.items[index].appendSlice(gpa, name(T)); |
| 156 | + try addEnum(state, gpa, T); |
154 | 157 | },
|
155 | 158 | .int => {
|
156 |
| - try state.definitions.items[index].appendSlice("integer"); |
| 159 | + try state.definitions.items[index].appendSlice(gpa, "integer"); |
157 | 160 | },
|
158 | 161 | .float => {
|
159 |
| - try state.definitions.items[index].appendSlice("number"); |
| 162 | + try state.definitions.items[index].appendSlice(gpa, "number"); |
160 | 163 | },
|
161 | 164 | .bool => {
|
162 |
| - try state.definitions.items[index].appendSlice("boolean"); |
| 165 | + try state.definitions.items[index].appendSlice(gpa, "boolean"); |
163 | 166 | },
|
164 | 167 | else => {
|
165 | 168 | @compileLog(T);
|
|
0 commit comments