|
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