Formality VS monadless

Compare Formality vs monadless and see what are their differences.

monadless

Syntactic sugar for monad composition in Scala (by monadless)
Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
Formality monadless
29 4
2,014 275
- 0.4%
9.9 0.0
over 2 years ago about 2 months ago
JavaScript Scala
MIT License Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

Formality

Posts with mentions or reviews of Formality. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-10-01.

monadless

Posts with mentions or reviews of monadless. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-08-11.
  • "A New Library For Imperative ZIO Programming" by Alexander Ioffe at Functional Scala 2022
    1 project | /r/scala | 10 Jan 2023
  • Kind: A Modern Proof Language
    7 projects | news.ycombinator.com | 11 Aug 2021
    Well `RecordWildcards` has been around for 14 years... but even without it instead of `{..}` you'd just have `_`s. The main thing that is different is that your Kind example had nested case statements while your Haskell example tried to match everything on one shot, which makes for a non-equivalent comparison.

    > Not sure how that could work, though. Idris had an interesting syntax, but IIRC it wasn't general.

    I assume you're talking about idiom brackets for applicatives? The general syntax is given in something like https://github.com/monadless/monadless. The idea is to basically take async-await syntax and generalize it to any monad.

    So e.g. your `Maybe` example (using `!` for the equivalent of `await` for concision) would look like

      Maybe {
  • Why asynchronous Rust doesn't work
    10 projects | news.ycombinator.com | 9 Mar 2021
    > If anything, async-await feels like an extremely non-functional thing to begin with

    It, like many other things, forms a monad. In fact async-await is a specialization of various monad syntactic sugars that try to eliminate long callback chains.

    Hence things like Haskell's do-notation are direct precursors to async-await (some libraries such as Scala's monadless https://github.com/monadless/monadless make it even more explicit, there lift and unlift are exactly generalized versions of async and await).

What are some alternatives?

When comparing Formality and monadless you can also consider the following projects:

reach-lang - Reach: The Safest and Smartest DApp Programming Language

async-trait - Type erasure for async trait methods

elixir-maybe - A simple implementation of the Maybe type in Elixir, intended as an introduction to Functors, Applicative Functors and Monads

py2many - Transpiler of Python to many other languages

rado - Turing machine in Idris, with some cool types

blog-comments - Comments for the blog at theta.eu.org.

apalache - APALACHE: symbolic model checker for TLA+ and Quint

ureq - A simple, safe HTTP client

plutus - The Plutus language implementation and tools

rupy - HTTP App. Server and JSON DB - Shared Parallel (Atomic) & Distributed

FormCoreJS - A minimal pure functional language based on self dependent types.

reqwest - An easy and powerful Rust HTTP Client