- v0.0.52Latest
- v0.0.51
- v0.0.50
- v0.0.49
- v0.0.48
- v0.0.47
- v0.0.46
- v0.0.45
- v0.0.44
- v0.0.43
- v0.0.42
- v0.0.41
- v0.0.39
- v0.0.38
- v0.0.37
- v0.0.36
- v0.0.35
- v0.0.34
- v0.0.33
- v0.0.32
- v0.0.31
- v0.0.30
- v0.0.29
- v0.0.28
- v0.0.27
- v0.0.26
- v0.0.25
- v0.0.24
- v0.0.23
- v0.0.22
- v0.0.21
- v0.0.20
- v0.0.19
- v0.0.18
- v0.0.17
- v0.0.16
- v0.0.15
- v0.0.14
- v0.0.13
- v0.0.12
- v0.0.11
- v0.0.10
- v0.0.9
- v0.0.8
- v0.0.7
- v0.0.6
- v0.0.5
- v0.0.4
- v0.0.3
- v0.0.2
- v0.0.1
DEPRECATED
This repository has been replaced by functional!
It will be kept alive as a historical reference and as a deno target in the event that someone is relying on its existence.
hkts
Higher kinded types for Deno. As an avid user of fp-ts I wanted to have a similarly full featured environment in Deno. Unfortunately, the fp-ts port to Deno is clunky to use with other functional libraries like @nll/datum, io-ts, and monocle-ts. While I could have ported fp-ts directly, I’ve come to like the exploratory work done by pelotom in the original hkts. Thus, I’ve decided to port the functionality of fp-ts, io-ts, and monocle-ts to Deno using the HKT substitution developed by pelotom.
This library is primarily an exercise, but I intend to maintain 100% test coverage. Instead of breaking out the clones of io-ts, monocle-ts, and datum into other Deno modules they will all be landed here. There will be no barrel exports as importing in Deno is much cleaner without them. Contributions are welcome.
Installation
This library is meant to be used with Deno, thus it follows the Deno imports syntax.
Conventions
This library focuses first on implementing
static-land type classes for a
given Algebraic Data Type (ie. Either or Option). These type class modules are
then exported from the ADT’s namespace (eg.
import { Monad } from 'https://deno.land/x/hkts/option.ts'
).
With the exception of instance constructors (ie. getShow or getSemigroup) other
ADT functions should all be pipeable. For functions that derive from type class
modules, like chain
or map
, there are helpers in derivations.ts
that will
generate the pipeable versions for you.
For good examples of the above conventions look at the either.ts
or
option.ts
.
Documentation
For the foreseeable future this library will not focus on documentation.
Questions are welcome via
github issues but I can’t guaruntee
speedy responses. Once a decent collection of ADTs and other utilities are
ported and all the pre-1.0.0 todo items in TODO.md
are complete I’ll shift to
documentation. Even then it’s likely that I’ll auto-generate the raw docs from
exported function and statement types and will devote any time to building an
example library that doubles as extra tests.