mirror of
https://github.com/luau-lang/rfcs.git
synced 2025-04-05 02:50:59 +01:00
Add examples for Tagged Enums, and cleanup examples
This commit is contained in:
parent
2646c27b4f
commit
f2e2cbcb10
1 changed files with 31 additions and 5 deletions
|
@ -112,22 +112,48 @@ This RFC proposes adding 4 new methods to the [`type`](./user-defined-type-funct
|
||||||
|
|
||||||
The `only` methods are diffrent with how they validate, as shown below.
|
The `only` methods are diffrent with how they validate, as shown below.
|
||||||
|
|
||||||
Example 1:
|
### String Enum Examples
|
||||||
```luau
|
```luau
|
||||||
type meow = number | "mrrp" | string
|
type meow = number | "mrrp" | string
|
||||||
|
|
||||||
print(meow:hasonlysubtypeof(types.string)) -- false, because theres a number in the union.
|
print(meow:hasonlysubtypeof(types.string)) -- false, because theres a number in the union.
|
||||||
print(meow:hassubtypeof(types.string)) -- true, because even though theres a number, theres also types with a subtype of string, and also string itself.
|
print(meow:hassubtypeof(types.string)) -- true, because even though theres a number, theres also types with a subtype of string, and also string itself.
|
||||||
```
|
|
||||||
|
|
||||||
Example 2:
|
|
||||||
```luau
|
|
||||||
type mrow = "purr" | "meow"
|
type mrow = "purr" | "meow"
|
||||||
|
|
||||||
print(meow:hasonlysubtypeof(types.string)) -- true, because despite the union being made up of singletons. Those singletons have the subtype of string, so it returns true.
|
print(meow:hasonlysubtypeof(types.string)) -- true, because despite the union being made up of singletons. Those singletons have the subtype of string, so it returns true.
|
||||||
print(meow:hassubtypeof(types.string)) -- true
|
print(meow:hassubtypeof(types.string)) -- true
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Tagged Enum Examples
|
||||||
|
```luau
|
||||||
|
type CatnipPurity = "90%" | "10%" | "11%"
|
||||||
|
|
||||||
|
type BaseCatnipInfo<P = CatnipPurity> = {
|
||||||
|
purity: P
|
||||||
|
}
|
||||||
|
|
||||||
|
type TwentyPercentPurityCatnip = {
|
||||||
|
purity: "20%"
|
||||||
|
name: "Average Catnip"
|
||||||
|
}
|
||||||
|
|
||||||
|
print(TwentyPercentPurityCatnip:hasonlysubtypeof(BaseCatnipInfo)) -- false, because "20%" is not an option in the string enum 'CatnipPurity'.
|
||||||
|
print(TwentyPercentPurityCatnip:hassubtypeof(BaseCatnipInfo)) -- also false for the same reason
|
||||||
|
|
||||||
|
type WeakCatnip = BaseCatnipInfo<"10%"> & {
|
||||||
|
name: "Weak Catnip"
|
||||||
|
}
|
||||||
|
|
||||||
|
print(WeakCatnip:hasonlysubtypeof(BaseCatnipInfo)) -- true, because unlike the previous example "10%" is an option in the string enum 'CatnipPurity'.
|
||||||
|
print(TwentyPercentPurityCatnip:hassubtypeof(BaseCatnipInfo)) -- also true
|
||||||
|
|
||||||
|
type FishyCatnipUnion = WeakCatnip | TwentyPercentPurityCatnip
|
||||||
|
|
||||||
|
print(FishyCatnipUnion:hasonlysubtypeof(BaseCatnipInfo)) -- false, because "20%" is not an option in the string enum 'CatnipPurity'.
|
||||||
|
print(TwentyPercentPurityCatnip:hassubtypeof(BaseCatnipInfo)) -- true, because atleast one of the components has the subtype of BaseCatnipInfo (WeakCatnip).
|
||||||
|
```
|
||||||
|
|
||||||
## Drawbacks
|
## Drawbacks
|
||||||
|
|
||||||
Adds extra methods to the type userdata in User-Defined type functions.
|
Adds extra methods to the type userdata in User-Defined type functions.
|
||||||
|
|
Loading…
Add table
Reference in a new issue