diff options
| author | Mitchell Hashimoto <mitchell.hashimoto@gmail.com> | 2022-02-27 17:30:15 -0800 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2022-02-28 20:42:13 -0700 |
| commit | bfada7c5144ce7f99ab92a76f65ca310440a2df9 (patch) | |
| tree | cbce207709d897d0a64583f40e33ea82d0c07fd0 /src/type.zig | |
| parent | d5131e91eba9324eda3a2ae47eb2aa4530c87e83 (diff) | |
| download | zig-bfada7c5144ce7f99ab92a76f65ca310440a2df9.tar.gz zig-bfada7c5144ce7f99ab92a76f65ca310440a2df9.zip | |
stage2: implement peer type resolution between error unions
Diffstat (limited to 'src/type.zig')
| -rw-r--r-- | src/type.zig | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/type.zig b/src/type.zig index dbb5eb4ba3..34a83999b3 100644 --- a/src/type.zig +++ b/src/type.zig @@ -4216,6 +4216,23 @@ pub const Type = extern union { }; } + /// Merge ty with ty2. + /// Asserts that ty and ty2 are both error sets and are resolved. + pub fn errorSetMerge(ty: Type, arena: Allocator, ty2: Type) !Type { + const lhs_names = ty.errorSetNames(); + const rhs_names = ty2.errorSetNames(); + var names = Module.ErrorSet.NameMap{}; + try names.ensureUnusedCapacity(arena, @intCast(u32, lhs_names.len + rhs_names.len)); + for (lhs_names) |name| { + names.putAssumeCapacityNoClobber(name, {}); + } + for (rhs_names) |name| { + names.putAssumeCapacity(name, {}); + } + + return try Tag.error_set_merged.create(arena, names); + } + pub fn enumFields(ty: Type) Module.EnumFull.NameMap { return switch (ty.tag()) { .enum_full, .enum_nonexhaustive => ty.cast(Payload.EnumFull).?.data.fields, |
