Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Welcome to Software Development on Codidact!

Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.

Post History

50%
+0 −0
Q&A What is a "sealed" type in F# and why doesn't the type test pattern operator (:?) work on it out of the `box`?

The F# language guide (see Signatures article) has a very sparse definition of what a "sealed" type is: Attribute Description [<Sealed>] For a type that has no abstract me...

0 answers  ·  posted 12mo ago by toraritte‭  ·  edited 12mo ago by toraritte‭

Question f#
#4: Nominated for promotion by user avatar Alexei‭ · 2024-01-28T12:53:01Z (11 months ago)
#3: Post edited by user avatar toraritte‭ · 2024-01-16T15:27:10Z (12 months ago)
  • The [F# language guide][1] (see [Signatures][2] article) has a very sparse definition of what a "sealed" type is:
  • > |Attribute|Description|
  • > |--- |--- |
  • > |`[<Sealed>]`|For a type that has no abstract members, or that should not be extended.|
  • > |`[<Interface>]`|For a type that is an interface.|
  • I searched the entire [PDF version of the language guide][3] using the term `seal`, and this was the most informative (out of all 8 results).
  • ### Context: `:?` fails on "simple types" with `error FS0016`
  • For example, I was playing with type abbreviations when both matches failed
  • type Lofa = | A | B
  • type Miez = Lofa
  • let (a: Miez) = A
  • match a with | :? Miez
  • match a with | :? Lofa
  • with
  • error FS0016: The type 'Miez' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • error FS0016: The type 'Lofa' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • The SO thread [F# Why can't I use the :? operator in F# interactive?][4] provides an answer (i.e., to use `box`, hence the mnemonic pun in the title),
  • match (box a) with | :? Miez
  • match (box a) with | :? Lofa
  • but it doesn't explain why it works or what "sealed" types are, and also raises questions:
  • * Does this mean that "sealed" types are "simple" F# types (i.e., not defined as "class types")?
  • Found the [issue #1320: Allow types to be Sealed by default][5], but I think that it only proposes "class" types to be "sealed" by default (as the "simple" types already are). Then again, this may be a misinterpretation.
  • * [I thought I understood what the `box` operator does][6] (even mentioned the same scenario there), but just realized that I don't know what "_`box` a returns value a wrapped in a .NET `System.Object` instance_" means.
  • Does "wrapping" mean that a `box`ed "simple" F# type is redefined the same way as the original input, but as a "class type", inheriting everything from `System.Object`?
  • ---
  • ### Please read before considering to close this question
  • <sup>This was intended for the trigger happy SO audience, but doesn't hurt to include it here:)</sup>
  • Yes, there are two questions in the title, but before closing this question, please consider my reasoning: I tried to separate and link the questions bi-directionally, but
  • + an abstract answer to the first one (similar to the guide's) without examples would probably just as unhelpful without context, and
  • + asking the 2nd question would inevitable duplicate efforts to define what a "sealed" type is.
  • Thank you!
  • [1]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/
  • [2]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/signature-files
  • [3]: https://learn.microsoft.com/pdf?url=https%3A%2F%2Flearn.microsoft.com%2Fen-us%2Fdotnet%2Ffsharp%2Ftoc.json
  • [4]: https://stackoverflow.com/questions/39452303/f-why-cant-i-use-the-operator-in-f-interactive
  • [5]: https://github.com/fsharp/fslang-suggestions/issues/1320
  • [6]: https://software.codidact.com/posts/290496
  • The [F# language guide][1] (see [Signatures][2] article) has a very sparse definition of what a "sealed" type is:
  • > |Attribute|Description|
  • > |--- |--- |
  • > |`[<Sealed>]`|For a type that has no abstract members, or that should not be extended.|
  • > |`[<Interface>]`|For a type that is an interface.|
  • I searched the entire [PDF version of the language guide][3] using the term `seal`, and this was the most informative (out of all 8 results).
  • ### Context: `:?` fails on "simple types" with `error FS0016`
  • For example, I was playing with type abbreviations when both matches failed
  • type Lofa = | A | B
  • type Miez = Lofa
  • let (a: Miez) = A
  • match a with | :? Miez -> a
  • match a with | :? Lofa -> a
  • with
  • error FS0016: The type 'Miez' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • error FS0016: The type 'Lofa' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • The SO thread [F# Why can't I use the :? operator in F# interactive?][4] provides an answer (i.e., to use `box`, hence the mnemonic pun in the title),
  • match (box a) with | :? Miez -> a
  • match (box a) with | :? Lofa -> a
  • but it doesn't explain why it works or what "sealed" types are, and also raises questions:
  • * Does this mean that "sealed" types are "simple" F# types (i.e., not defined as "class types")?
  • Found the [issue #1320: Allow types to be Sealed by default][5], but I think that it only proposes "class" types to be "sealed" by default (as the "simple" types already are). Then again, this may be a misinterpretation.
  • * [I thought I understood what the `box` operator does][6] (even mentioned the same scenario there), but just realized that I don't know what "_`box` a returns value a wrapped in a .NET `System.Object` instance_" means.
  • Does "wrapping" mean that a `box`ed "simple" F# type is redefined the same way as the original input, but as a "class type", inheriting everything from `System.Object`?
  • ---
  • ### Please read before considering to close this question
  • <sup>This was intended for the trigger happy SO audience, but doesn't hurt to include it here:)</sup>
  • Yes, there are two questions in the title, but before closing this question, please consider my reasoning: I tried to separate and link the questions bi-directionally, but
  • + an abstract answer to the first one (similar to the guide's) without examples would probably just as unhelpful without context, and
  • + asking the 2nd question would inevitable duplicate efforts to define what a "sealed" type is.
  • Thank you!
  • [1]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/
  • [2]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/signature-files
  • [3]: https://learn.microsoft.com/pdf?url=https%3A%2F%2Flearn.microsoft.com%2Fen-us%2Fdotnet%2Ffsharp%2Ftoc.json
  • [4]: https://stackoverflow.com/questions/39452303/f-why-cant-i-use-the-operator-in-f-interactive
  • [5]: https://github.com/fsharp/fslang-suggestions/issues/1320
  • [6]: https://software.codidact.com/posts/290496
#2: Post edited by user avatar toraritte‭ · 2024-01-14T18:20:44Z (12 months ago)
  • The [F# language guide][1] (see [Signatures][2] article) has a very sparse definition of what a "sealed" type is:
  • > |Attribute|Description|
  • > |--- |--- |
  • > |`[<Sealed>]`|For a type that has no abstract members, or that should not be extended.|
  • > |`[<Interface>]`|For a type that is an interface.|
  • I searched the entire [PDF version of the language guide][3] using the term `seal`, and this was the most informative (out of all 8 results).
  • ### Context: `:?` fails on "simple types" with `error FS0016`
  • For example, I was playing with type abbreviations when both matches failed
  • type Lofa = | A | B
  • type Miez = Lofa
  • let (a: Miez) = A
  • match a with | :? Miez
  • match a with | :? Lofa
  • with
  • error FS0016: The type 'Miez' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • error FS0016: The type 'Lofa' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • The SO thread [F# Why can't I use the :? operator in F# interactive?][4] provides an answer (i.e., to use `box`, hence the mnemonic pun in the title),
  • match (box a) with | :? Miez
  • match (box a) with | :? Lofa
  • but it doesn't explain why it works or what "sealed" types are, and also raises questions:
  • * Does this mean that "sealed" types are "simple" F# types (i.e., not defined as "class types")?
  • Found the [issue #1320: Allow types to be Sealed by default][5], but I think that it only proposes "class" types to be "sealed" by default (as the "simple" types already are). Then again, this may be a misinterpretation.
  • * [I thought I understood what the `box` operator does][6] (even mentioned the same scenario there), but just realized that I don't know what "_`box` a returns value a wrapped in a .NET `System.Object` instance_" means.
  • Does "wrapping" mean that a `box`ed "simple" F# type is redefined the same way as the original input, but as a "class type", inheriting everything from `System.Object`?
  • ---
  • ### Please read before considering to close this question
  • Yes, there are two questions in the title, but before closing this question, please consider my reasoning: I tried to separate and link the questions bi-directionally, but
  • + an abstract answer to the first one (similar to the guide's) without examples would probably just as unhelpful without context, and
  • + asking the 2nd question would inevitable duplicate efforts to define what a "sealed" type is.
  • Thank you!
  • [1]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/
  • [2]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/signature-files
  • [3]: https://learn.microsoft.com/pdf?url=https%3A%2F%2Flearn.microsoft.com%2Fen-us%2Fdotnet%2Ffsharp%2Ftoc.json
  • [4]: https://stackoverflow.com/questions/39452303/f-why-cant-i-use-the-operator-in-f-interactive
  • [5]: https://github.com/fsharp/fslang-suggestions/issues/1320
  • [6]: https://software.codidact.com/posts/290496
  • The [F# language guide][1] (see [Signatures][2] article) has a very sparse definition of what a "sealed" type is:
  • > |Attribute|Description|
  • > |--- |--- |
  • > |`[<Sealed>]`|For a type that has no abstract members, or that should not be extended.|
  • > |`[<Interface>]`|For a type that is an interface.|
  • I searched the entire [PDF version of the language guide][3] using the term `seal`, and this was the most informative (out of all 8 results).
  • ### Context: `:?` fails on "simple types" with `error FS0016`
  • For example, I was playing with type abbreviations when both matches failed
  • type Lofa = | A | B
  • type Miez = Lofa
  • let (a: Miez) = A
  • match a with | :? Miez
  • match a with | :? Lofa
  • with
  • error FS0016: The type 'Miez' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • error FS0016: The type 'Lofa' does not have any
  • proper subtypes and cannot be used as the source
  • of a type test or runtime coercion.
  • The SO thread [F# Why can't I use the :? operator in F# interactive?][4] provides an answer (i.e., to use `box`, hence the mnemonic pun in the title),
  • match (box a) with | :? Miez
  • match (box a) with | :? Lofa
  • but it doesn't explain why it works or what "sealed" types are, and also raises questions:
  • * Does this mean that "sealed" types are "simple" F# types (i.e., not defined as "class types")?
  • Found the [issue #1320: Allow types to be Sealed by default][5], but I think that it only proposes "class" types to be "sealed" by default (as the "simple" types already are). Then again, this may be a misinterpretation.
  • * [I thought I understood what the `box` operator does][6] (even mentioned the same scenario there), but just realized that I don't know what "_`box` a returns value a wrapped in a .NET `System.Object` instance_" means.
  • Does "wrapping" mean that a `box`ed "simple" F# type is redefined the same way as the original input, but as a "class type", inheriting everything from `System.Object`?
  • ---
  • ### Please read before considering to close this question
  • <sup>This was intended for the trigger happy SO audience, but doesn't hurt to include it here:)</sup>
  • Yes, there are two questions in the title, but before closing this question, please consider my reasoning: I tried to separate and link the questions bi-directionally, but
  • + an abstract answer to the first one (similar to the guide's) without examples would probably just as unhelpful without context, and
  • + asking the 2nd question would inevitable duplicate efforts to define what a "sealed" type is.
  • Thank you!
  • [1]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/
  • [2]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/signature-files
  • [3]: https://learn.microsoft.com/pdf?url=https%3A%2F%2Flearn.microsoft.com%2Fen-us%2Fdotnet%2Ffsharp%2Ftoc.json
  • [4]: https://stackoverflow.com/questions/39452303/f-why-cant-i-use-the-operator-in-f-interactive
  • [5]: https://github.com/fsharp/fslang-suggestions/issues/1320
  • [6]: https://software.codidact.com/posts/290496
#1: Initial revision by user avatar toraritte‭ · 2024-01-14T18:18:17Z (12 months ago)
What is a "sealed" type in F# and why doesn't the type test pattern operator (:?) work on it out of the `box`?
The [F# language guide][1] (see [Signatures][2] article) has a very sparse definition of what a "sealed" type is:

> |Attribute|Description|
> |--- |--- |
> |`[<Sealed>]`|For a type that has no abstract members, or that should not be extended.|
> |`[<Interface>]`|For a type that is an interface.|

I searched the entire [PDF version of the language guide][3] using the term `seal`, and this was the most informative (out of all 8 results).

### Context: `:?` fails on "simple types" with `error FS0016`

For example, I was playing with type abbreviations when both matches failed

    type Lofa = | A | B
    type Miez = Lofa
    
    let (a: Miez) = A
    
    match a with | :? Miez
    match a with | :? Lofa

with

    error FS0016: The type 'Miez' does not  have any
    proper subtypes and cannot be used as the source
    of a type test or runtime coercion.
    
    error FS0016: The type 'Lofa' does not  have any
    proper subtypes and cannot be used as the source
    of a type test or runtime coercion.

The SO thread [F# Why can't I use the :? operator in F# interactive?][4] provides an answer (i.e., to use `box`, hence the mnemonic pun in the title),

    match (box a) with | :? Miez
    match (box a) with | :? Lofa

but it doesn't explain why it works or what "sealed" types are, and also raises questions:

* Does this mean that "sealed" types are "simple" F# types (i.e., not defined as "class types")?

  Found the [issue #1320: Allow types to be Sealed by default][5], but I think that it only proposes "class" types to be "sealed" by default (as the  "simple" types already are). Then again, this may be a misinterpretation.

* [I thought I understood what the `box` operator does][6] (even mentioned the same scenario there), but just realized that I don't know what "_`box` a returns value a wrapped in a .NET `System.Object` instance_" means.

  Does "wrapping" mean that a `box`ed "simple" F# type is redefined the same way as the original input, but as a "class type", inheriting everything from `System.Object`?

---

### Please read before considering to close this question

Yes, there are two questions in the title, but before closing this question, please consider my reasoning: I tried to separate and link the questions bi-directionally, but

+ an abstract answer to the first one (similar to the guide's) without examples would probably just as unhelpful without context, and

+ asking the 2nd question would inevitable duplicate efforts to define what a "sealed" type is.

Thank you!


  [1]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/
  [2]: https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/signature-files
  [3]: https://learn.microsoft.com/pdf?url=https%3A%2F%2Flearn.microsoft.com%2Fen-us%2Fdotnet%2Ffsharp%2Ftoc.json
  [4]: https://stackoverflow.com/questions/39452303/f-why-cant-i-use-the-operator-in-f-interactive
  [5]: https://github.com/fsharp/fslang-suggestions/issues/1320
  [6]: https://software.codidact.com/posts/290496
f#