MCPcopy
hub / github.com/gcanti/fp-ts

github.com/gcanti/fp-ts @2.16.9 sqlite

repository ↗ · DeepWiki ↗ · release 2.16.9 ↗
2,586 symbols 5,609 edges 271 files 13 documented · 1%
README

Functional programming in TypeScript

build status npm downloads

📢 Important Announcement: fp-ts is Joining the Effect-TS Ecosystem!

We are excited to announce that the fp-ts project is officially merging with the Effect-TS ecosystem. This is a significant step forward in the functional programming landscape, bringing together two powerful libraries under one roof. Giulio Canti, the author of fp-ts, is being welcomed into the Effect organization, promising an exciting future with enhanced capabilities and support.

What This Means for New Users:

Effect-TS can be regarded as the successor to fp-ts v2 and embodies what would be considered fp-ts v3. This merger marks a significant evolution in the library's capabilities, integrating more features and functionalities tailored towards robust, type-safe, and scalable functional programming.

For more details on this merger and what it entails, please refer to the official announcement here. Additionally, you can explore more about Effect-TS and its offerings on our website and documentation.

Introduction

fp-ts is a library for typed functional programming in TypeScript.

fp-ts aims to allow developers to use popular patterns and abstractions that are available in most functional languages. For this, it includes the most popular data types, type classes and abstractions such as Option, Either, IO, Task, Functor, Applicative, Monad to empower users to write pure FP apps and libraries built atop higher order abstractions.

A distinctive feature of fp-ts with respect to other functional libraries is its implementation of Higher Kinded Types, which TypeScript doesn't support natively.

Inspired by

Sponsors

Unsplash Unsplash https://unsplash.com/ The internet’s source for visuals. Powered by creators everywhere.

Installation

To install the stable version:

npm install fp-ts

Make sure to always have a single version of fp-ts installed in your project. Multiple versions are known to cause tsc to hang during compilation. You can check the versions currently installed using npm ls fp-ts (make sure there's a single version and all the others are marked as deduped).

TypeScript compatibility

Strictness – This library is conceived, tested and is supposed to be consumed by TypeScript with the strict flag turned on.

fp-ts version required typescript version
2.0.x+ 3.5+
1.15.x+ 3.1+
<= 1.14.4 2.8+ (*)

(*) If you are running < typescript@3.0.1 you have to polyfill the unknown type. You can use unknown-ts as a polyfill.

Documentation

Disclaimer. Teaching functional programming is out of scope of this project, so the documentation assumes you already know what FP is.

Help

If you need help with fp-ts check out:

Development

License

The MIT License (MIT)

Extension points exported contracts — how you extend this code

ReaderIOTypeLambda (Interface)
@internal
src/ReaderIO.ts
ReaderEitherTypeLambda (Interface)
@internal
src/ReaderEither.ts
IOEitherTypeLambda (Interface)
@internal
src/IOEither.ts
TaskEitherTypeLambda (Interface)
@internal
src/TaskEither.ts
TaskOptionTypeLambda (Interface)
@internal
src/TaskOption.ts
StateReaderTaskEitherTypeLambda (Interface)
@internal
src/StateReaderTaskEither.ts
ReaderTaskTypeLambda (Interface)
@internal
src/ReaderTask.ts
EitherTypeLambda (Interface)
@internal
src/Either.ts

Core symbols most depended-on inside this repo

pipe
called by 2164
src/function.ts
f
called by 394
src/Field.ts
separated
called by 159
src/Separated.ts
flow
called by 85
src/function.ts
isLeft
called by 68
src/These.ts
right
called by 65
src/Separated.ts
concat
called by 59
src/NonEmptyArray.ts
flatMap
called by 57
src/StateT.ts

Shape

Function 1,853
Interface 722
Method 7
Class 4

Languages

TypeScript100%

Modules by API surface

src/pipeable.ts154 symbols
src/ReadonlyArray.ts130 symbols
src/Array.ts105 symbols
src/ReadonlyNonEmptyArray.ts83 symbols
src/ReadonlyRecord.ts81 symbols
src/NonEmptyArray.ts74 symbols
src/ReadonlyMap.ts70 symbols
src/Either.ts58 symbols
src/Option.ts55 symbols
src/Map.ts53 symbols
src/These.ts45 symbols
scripts/linter.ts40 symbols

Dependencies from manifests, versioned

@effect/dtslint0.1.0 · 1×
@effect/language-service0.0.19 · 1×
@types/benchmark1.0.31 · 1×
@types/chai3.5.2 · 1×
@types/glob7.1.3 · 1×
@types/node20.14.10 · 1×
@typescript-eslint/eslint-plugin5.59.0 · 1×
@typescript-eslint/parser5.59.0 · 1×
@vitest/coverage-istanbul1.6.0 · 1×
benchmark2.1.4 · 1×
docs-ts0.8.0 · 1×
eslint8.38.0 · 1×

For agents

$ claude mcp add fp-ts \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact