Fluture type definitions for Sanctuary.
$ npm install --save fluture-sanctuary-types
Note that you also need Fluture and sanctuary-def installed.
Sanctuary-def comes preinstalled with Sanctuary, so you could install
either one. Fluture has to be installed separately. See package.json
for compatible versions (defined in peerDependencies
).
On Node 12 and up, this module can be loaded directly with import
or
require
. On Node versions below 12, require
or the esm-loader can
be used.
import $ from 'sanctuary-def';
import sanctuary from 'sanctuary';
import {env, FutureType} from 'fluture-sanctuary-types/index.js';
import {resolve} from 'fluture/index.js';
const S = sanctuary.create ({
checkTypes: process.env.NODE_ENV !== 'production',
env: sanctuary.env.concat (env)
});
S.is (FutureType ($.String) ($.Number)) (resolve (42));
You can load the EcmaScript module from various content delivery networks:
There's a UMD file included in the NPM package, also available via jsDelivr: https://cdn.jsdelivr.net/npm/[email protected]/dist/umd.js
This file adds flutureSanctuaryTypes
to the global scope, or use
CommonJS/AMD when available.
const $ = require ('sanctuary-def');
const sanctuary = require ('sanctuary');
const {env, FutureType} = require ('fluture-sanctuary-types');
const {resolve} = require ('fluture');
const S = sanctuary.create ({
checkTypes: process.env.NODE_ENV !== 'production',
env: sanctuary.env.concat (env)
});
S.is (FutureType ($.String) ($.Number)) (resolve (42));
The binary type constructor for members of Future.
> $.test (env)
. (FutureType ($.String) ($.Number))
. (Future['fantasy-land/of'] (1));
true
The binary type constructor for members of ConcurrentFuture.
> $.test (env)
. (ConcurrentFutureType ($.String) ($.Number))
. (Par['fantasy-land/of'] (1));
true
An Array containing all types applied to $.Unknown
for
direct use as a Sanctuary environment, as shown in Usage.