package ppx_optional

  1. Overview
  2. Docs
Pattern matching on flat options

Install

Dune Dependency

Authors

Maintainers

Sources

ppx_optional-v0.9.0.tar.gz
sha256=0c4f54f42075c0f337bbf12e89d74c29cc68fa285ba3fc6fbf4a37c1c6f2aa4e
md5=84dfad9aa7e326f00d12101c8c353e2b

README.md.html

title: ppx_optional - match statements for zero-alloc options parent: ../README.md

A ppx rewriter that rewrites simple match statements with an if then else expression.

Syntax

ppx_optional rewrites the extension match%optional in expressions. It requires that a module Optional_syntax is in scope, and that it has is_none and unchecked_value values.

For instance:

match%optional e with
| None -> none_expression
| Some x -> some_expression

becomes:

if Optional_syntax.is_none e then begin
   none_expression
end else begin
   let x = Optional_syntax.unchecked_value e in
   some_expression
end

Usage

This is normally used to safely access an optional value while avoiding allocation for immediate values (e.g. Immediate.{Char,Bool,Int}.Option, Fixed.Option, Price.Fixed.Option, etc...).

OCaml

Innovation. Community. Security.