matchWith

Chooses and executes a function for each variant in the Validation structure.

This feature is experimental!

This API is still experimental, so it may change or be removed in future versions. You should not rely on it for production applications.

Signature

matchWith(pattern)
('a is Variant).({ 'b: (Object Any) => 'c }) => 'c
where 'b = 'a[`@@folktale:adt:tag]

Documentation

Chooses and executes a function for each variant in the Validation structure.

Example:

const { Success, Failure } = require('folktale/validation');

Success('a').matchWith({
  Failure: ({ value }) => `Failure: ${value}`,
  Success: ({ value }) => `Success: ${value}`
});
// ==> 'Success: a'

Failure('a').matchWith({
  Failure: ({ value }) => `Failure: ${value}`,
  Success: ({ value }) => `Success: ${value}`
});
// ==> 'Failure: a'

Properties

Source Code

Defined in source/adt/union/union.js at line 55, column 42
matchWith(pattern) {
        return pattern[name](this);
      }
Stability
experimental
Licence
MIT
Authors
Copyright
(c) 2013-2017 Quildreen Motta, and CONTRIBUTORS
Authors
  • Quildreen Motta
Maintainers
  • Quildreen Motta <queen@robotlolita.me> (http://robotlolita.me/)