JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 4
  • Score
    100M100P100Q40743F
  • License MIT

Cross-platform embedded representation for algebraic data types, values, and common operations.

Package Exports

  • uxadt

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (uxadt) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

uxadt

Cross-platform embedded representation for algebraic data types, values, and common operations.

npm version and link.

This family of libraries supports a cross-platform embedded representation for algebraic data type (ADT) values, and platform-specific embedded programming abstractions for common operations (such as pattern matching) on algebraic data type values.

Package Installation and Usage

It is possible to use the library within a Node.js module in the following way:

var uxadt = require("./uxadt.js");

It is possible to use the library within an HTML page in the following way:

<script src="uxadt.js"></script>

You may want to define _ for the sake of concision:

var _ = null;

It does not matter what is assigned to _, as long as it is not a uxadt value.

Examples

The following is a simple algebraic data type definition:

uxadt._({
    Node: [_, _],
    Leaf: []
  });

To better document the implicit constraints associated with the definition, it is possible to provide an explicit name for the algebraic data type and the types of the constructor arguments (no static or dynamic checking of the constraints implied by this information is currently supported by the library itself):

uxadt._('Tree', {
    Node: ['Tree', 'Tree'],
    Leaf: []
  });

An individual value can then be built up as an expression in the following way:

Node(Node(Leaf(), Leaf()), Leaf())

Below is a simple recursive function that counts the number of nodes in a tree value (i.e., a value that corresponds to the algebraic data type definition in the above example):

function size(t) {
  return t
    ._(Leaf(),     function()    { return 1; })
    ._(Node(_, _), function(x, y){ return 1 + size(x) + size(y); })
    .end;
}

The library provides an alternate interface for using pattern matching that follows a more imperative paradigm:

function size(t) {
  if (t._(Leaf())) {
    return 1;
  } else if (t._(Node(_, _))) {
    [x, y] = t.matched();
    return 1 + size(x) + size(y);
  }
}