Skip to main content

Functional library for Functors, Applicatives, and Monads in Python 3.12+

Project description

Functors, Applicatives, And Monads in Python

CI PyPI Python Version License

OSlash (Ø) is a library for learning and understanding functional programming in Python 3.12+. It re-implements concepts from Learn You a Haskell for Great Good! using Python with modern type annotations. OSlash unifies functional and object-oriented paradigms by grouping related functions within classes. Objects are never used for storing values or mutable data; data exists only within function closures.

✨ What's New in 1.0

OSlash 1.0 is a complete modernization for Python 3.12+:

  • Modern Type System: Fully type-checked with Pyright in strict mode
  • PEP 695 Syntax: Clean type parameters (class Maybe[T]: instead of Generic[T])
  • Modern Tooling: Built with uv, formatted with ruff, validated with pre-commit hooks
  • Production Status: Stable release ready for educational use

Type Safety: OSlash is fully type-checked with Pyright in strict mode, providing excellent IDE support and catching errors at development time. It leverages Python 3.12's PEP 695 type parameter syntax for clean, ergonomic generic types.

OSlash is intended to be a tutorial. For practical functional programming in Python in production environments you should use Expression instead.

Install

# Using pip
pip install oslash

# Or using uv (recommended)
uv add oslash

The project currently contains implementations for:

Abstract Base Classes

  • Functor, for stuff that can be mapped
  • Applicative, for callable stuff
  • Monoid, for associative stuff
  • Monad, for monadic stuff

And Some Monads

  • Identity, boxed stuff in its simplest form
  • Maybe (Just | Nothing), for optional stuff
  • Either (Right | Left), for possible failures
  • List, purely functional list of stuff
  • IO Action, for impure stuff
  • Writer, for logging stuff
  • Reader, for callable stuff
  • State, for stateful computations of stuff
  • Cont, for continuation of stuff

Monadic functions

  • >>, for sequencing monadic actions
  • lift, for mapping a function over monadic values
  • join, for removing one level of monadic structure
  • compose, for composing monadic functions

Utility functions

  • compose, for composing 0 to n functions

But why?

Yes, I know there are other projects out there like PyMonad, fn.py. I'm simply doing this in order to better understand the book. It's so much easier to learn when you implement things yourself. The code may be similar to PyMonad in structure, but is quite different in implementation.

Why is the project called OSlash? OSlash is the Norwegian character called Oslash. Initially I wanted to create a project that used Ø and ø (unicode) for the project name and modules. It didn't work out well, so I renamed it to OSlash.

Examples

Haskell:

> fmap (+3) (Just 2)
Just 5

> (+3) <$> (Just 2)
Just 5

Python:

>>> Just(2).map(lambda x: x+3)
Just 5

>>> (lambda x: x+3) % Just(2)
Just 5

IO Actions:

from oslash import put_line, get_line

main = put_line("What is your name?") | (lambda _:
    get_line() | (lambda name:
    put_line("What is your age?") | (lambda _:
    get_line() | (lambda age:
    put_line("Hello " + name + "!") | (lambda _:
    put_line("You are " + age + " years old"))))))

if __name__ == "__main__":
    main()

Tutorials

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

oslash-2.0.0.tar.gz (61.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

oslash-2.0.0-py3-none-any.whl (31.6 kB view details)

Uploaded Python 3

File details

Details for the file oslash-2.0.0.tar.gz.

File metadata

  • Download URL: oslash-2.0.0.tar.gz
  • Upload date:
  • Size: 61.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for oslash-2.0.0.tar.gz
Algorithm Hash digest
SHA256 c8090331973ccab85a5266bdb125d3547d0e1d27b0990bd3bc2de2e56bef4a8c
MD5 2b96c899de4e67ae5236193c63cac9f4
BLAKE2b-256 ceeb58b7e2b23050076eb54e63cfd16943cce70dc2c5e3a4921be7df9ba66185

See more details on using hashes here.

File details

Details for the file oslash-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: oslash-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 31.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for oslash-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fafb124f80cc757d62a9731f28f60f57479414c2463189f365bf6f55014a3aad
MD5 d4d797c33b006a1b51f942d9807ccd9f
BLAKE2b-256 1963d44b1af6e1a15d0dcaef0fa6e47e61159ef0afa451667909aef0fef89926

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page