- 
                Notifications
    You must be signed in to change notification settings 
- Fork 471
Try to improve error message about inline record escaping scope #7808
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| rescript
 @rescript/darwin-arm64
 @rescript/darwin-x64
 @rescript/linux-arm64
 @rescript/linux-x64
 @rescript/runtime
 @rescript/win32-x64
 commit:  | 
| Makes me wonder why this limitation exists in the first place? | 
| Nested record types are actual record types, they get defined as a concrete type declaration behind the scenes, just that you don't see it. Inline record types in constructors have their definition inlined into the constructor definition itself, so they don't have an actual record type declaration anywhere outside of the constructor. | 
| Yes, but why can't inline record types be actual record types similar to nested records? | 
| They're different things and have different semantics. As an example, the runtime representation is different (notice the payload at runtime): https://rescript-lang.org/try?version=v12.0.0-beta.6&module=esmodule&code=C4TwDgpgBAHlC8UDeIBcUCWA7YBfAUKJJlgDbYQBKEAxgPYBOAJglAPJYQAUK62eASkLhoAQxrAArqNLV6zVh24wh+UhGBRRfMhTmMWiJTzRQAjLiHrNAI3TipM-QqOcT6C0KA | 
| I know they're different and that's probably for historical reasons, but should they be? What would be the downside of making this work like nested records? | 
| 
 It's not for historical reasons, it's two different concepts. They're part of different structures. We can't make it work like nested records here. Nested records is just a syntactical feature that makes defining records-in-records (and soon maybe records-in-externals) ergonomic. It's purely syntactical. If we were to make inline records work the same way then we'd loose the ability to define "these properties exist on the object with the discriminator at runtime", because a regular record (whether it's a nested record or not) passed to a constructor will at runtime end up on the payload prop ( With that said, it's an annoying error and potentially more confusing now that we have nested records. Still think the trade off is worth it. | 
| I'm happy with it 👍 | 
ee3c16a    to
    dab5526      
    Compare
  
    
An attempt to improve the (IMO quite cryptic) error message for inline records possibly escaping its scope. What do you think?