2018-07-17 01:52:50 +01:00
|
|
|
const std = @import("std");
|
|
|
|
const mem = std.mem;
|
|
|
|
const assert = std.debug.assert;
|
|
|
|
const Buffer = std.Buffer;
|
|
|
|
|
2018-11-13 13:08:37 +00:00
|
|
|
pub const Package = struct {
|
2018-07-17 01:52:50 +01:00
|
|
|
root_src_dir: Buffer,
|
|
|
|
root_src_path: Buffer,
|
|
|
|
|
|
|
|
/// relative to root_src_dir
|
|
|
|
table: Table,
|
|
|
|
|
2019-09-03 22:53:05 +01:00
|
|
|
pub const Table = std.StringHashMap(*Package);
|
2018-07-17 01:52:50 +01:00
|
|
|
|
|
|
|
/// makes internal copies of root_src_dir and root_src_path
|
|
|
|
/// allocator should be an arena allocator because Package never frees anything
|
|
|
|
pub fn create(allocator: *mem.Allocator, root_src_dir: []const u8, root_src_path: []const u8) !*Package {
|
2019-02-03 21:13:28 +00:00
|
|
|
const ptr = try allocator.create(Package);
|
|
|
|
ptr.* = Package{
|
2018-07-17 01:52:50 +01:00
|
|
|
.root_src_dir = try Buffer.init(allocator, root_src_dir),
|
|
|
|
.root_src_path = try Buffer.init(allocator, root_src_path),
|
|
|
|
.table = Table.init(allocator),
|
2019-02-03 21:13:28 +00:00
|
|
|
};
|
|
|
|
return ptr;
|
2018-07-17 01:52:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn add(self: *Package, name: []const u8, package: *Package) !void {
|
|
|
|
const entry = try self.table.put(try mem.dupe(self.table.allocator, u8, name), package);
|
|
|
|
assert(entry == null);
|
|
|
|
}
|
|
|
|
};
|