Patterns.TryWith Active Pattern (F#)
Recognizes expressions that represent a try...with construct for exception filtering and catching.
Namespace/Module Path: Microsoft.FSharp.Quotations.Patterns
Assembly: FSharp.Core (in FSharp.Core.dll)
// Signature:
( |TryWith|_| ) : (input:Expr) -> (Expr * Var * Expr * Var * Expr) option
Parameters
input
Type: ExprThe input expression to match against.
Return Value
The formal return type is (Expr * Var * Expr * Var * Expr) option. The option indicates whether a successful match is made. In a pattern matching expression, upon a successful match, the input expression is decomposed into a tuple of five elements. The first element is an expression that represents the body of the try...with expression. The second element is the filter value, which is the value that is used to compare against the patterns. The third element is an expression that represents the filtering and assignment of any values set in the pattern matching, for example, by using the as keyword. The fourth element is the catch value, which is usually the same as the filter value and is used to determine which branch is taken. The final element is the catch expression, which includes the branching code. The tuple elements correspond to the arguments of the Expr.TryWith method.
Remarks
This function is named TryWithPattern in the .NET Framework assembly. If you are accessing the member from a .NET Framework language other than F#, or through reflection, use this name.
Example
The following example shows how a simple try ... with expression is decomposed.
open Microsoft.FSharp.Quotations.Patterns
module TryWithPattern =
let f x =
if (x = 0) then
raise (new System.DivideByZeroException())
else
100 / x
let expr =
<@
try
f 20
with
| :? System.DivideByZeroException as exn ->
-1
| exn -> -2 @>
match expr with
| TryWith(tryExpr, filterValue, filterExpr, catchValue, catchExpr) ->
printfn "Try Expression: %s\n" (tryExpr.ToString())
printfn "Filter value: %s\n" (filterValue.Name)
printfn "Filter expression: %s\n" (filterExpr.ToString())
printfn "Catch value: %s\n" (catchValue.Name)
printfn "Catch expression: %s\n" (catchExpr.ToString())
| _ -> printfn "Unrecognized expression."
The output shows how the expressions are decomposed.
Try Expression: Call (None, Int32 f(Int32), [Value (20)]) Filter value: matchValue Filter expression: IfThenElse (TypeTest (System.DivideByZeroException, matchValue), Let (exn, Call (None, System.DivideByZeroException UnboxGeneric[DivideByZeroException](System.Object), [matchValue]), Value (1)), Let (exn, matchValue, Value (1))) Catch value: matchValue Catch expression: IfThenElse (TypeTest (System.DivideByZeroException, matchValue), Let (exn, Call (None, System.DivideByZeroException UnboxGeneric[DivideByZeroException](System.Object), [matchValue]), Value (-1)), Let (exn, matchValue, Value (-2)))
Platforms
Windows 7, Windows Vista SP2, Windows XP SP3, Windows XP x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2
Version Information
F# Runtime
Supported in: 2.0, 4.0
Silverlight
Supported in: 3