dotty-cps-async VS iron

Compare dotty-cps-async vs iron and see what are their differences.

Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
dotty-cps-async iron
10 20
170 407
- -
9.4 8.3
4 days ago 7 days ago
Scala Scala
Apache License 2.0 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.

dotty-cps-async

Posts with mentions or reviews of dotty-cps-async. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-01-29.
  • Help a Kotlin convert back into Scala world
    7 projects | /r/scala | 29 Jan 2023
    Now in scala we have direct mode transformers: dotty-cps-async [https://github.com/rssh/dotty-cps-async] with cps-async-connect [https://github.com/rssh/cps-async-connect ] supports all well-knowm monad stacks, for ZIO also exists ZIO-direct [https://github.com/zio/zio-direct ] , for IO - cats-effect-cps [https://github.com/typelevel/cats-effect-cps ], for kyo [https://github.com/fwbrasil/kyo ] - kyo-direct.
  • dotty-cps-async 0.9.12 is out
    3 projects | /r/scala | 8 Dec 2022
    dotty-cps-async: https://github.com/rssh/dotty-cps-async
  • The case against Effect Systems (e.g., the IO data type)
    2 projects | /r/scala | 18 Oct 2022
    Hmm, you can write direct-style code with monad: https://github.com/rssh/dotty-cps-async allows this, exists support libraries exist for near all well-known effect systems: https://github.com/rssh/cps-async-connect, so you can use async/await with IO/ZIO the same as with Future. Although in IO style, any operation that mutates state is async, it's hard to write code where you should place `await` near each line. And it looks like automatic coloring is a too radical change of concepts for most functional programmers. The option to allow using <- in the direct style may be more popular, but this requires changes to the scala core. Another question - are we need effective systems to be present in each program in industrial-style development? Here I agree that mostly no.
  • dotty-cps-async 0.9.11 is out. (bugfixes and experimental loom support)
    1 project | /r/scala | 18 Sep 2022
  • dotty-cps-async 0.9.9
    1 project | /r/scala | 5 Jun 2022
  • New Scala 3 Codebases
    6 projects | /r/scala | 17 Feb 2022
  • Also dotty-cps-async 0.9.8 with scala-native support
    1 project | /r/scala | 16 Feb 2022
  • dotty-cps-async 0.9.8 with scala-native support
    1 project | /r/scala | 16 Feb 2022
  • Dotty-cps-async 0.9.7 is released.
    4 projects | /r/scala | 26 Jan 2022
    This is a generic async/await transformer for scala3 which allows using effectful monads in the direct style. URL: (https://github.com/rssh/dotty-cps-async )
  • Language-assisted Flattening
    2 projects | /r/ProgrammingLanguages | 14 Jul 2021
    dotty-cps-async [rssh/dotty-cps-async ] with automatic coloring do something very similar in two steps. Automatic coloring defines implicit conversion F[A] => A as x => await(x)(m). The compiler inserts those awaits inside async blocks and then eliminates them later via cps-transform. Exists some limitations which we need to add for effect monads like IO (we don't want run effect twice and don't want to screw semantics of effects by extra memoizing). So, if your language has a possibility to implement effect monads, then you need a possibility to restrict using Flattenable.

iron

Posts with mentions or reviews of iron. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-02-02.
  • Make Invalid States Unrepresentable
    2 projects | dev.to | 2 Feb 2024
    Scala has quite good support for refined types across multiple libraries. A solution using the refined library might look something like
  • Y-at-il icy gens que creere son propre project open source?
    2 projects | /r/programmation | 5 Dec 2023
  • Effect of Perceptual Load on Performance Within IDE in People with ADHD Symptoms
    7 projects | news.ycombinator.com | 14 Jul 2023
    > The output you see is not generated by python.

    Obviously, as running the code generates a very different output…

    > It's generated by an external type checker.

    I know.

    But again, you didn't say that.

    You said the above code "generates" this…

    Maybe you've heard that by now somewhere: Words matter… ;-)

    > The context is python. We're talking about python. I'm making a statement about python.

    No, you made a statement about type checking. Here the full quote once again:

    > The contents of a string can't be type checked and if all methods are defined this way on a class none of it can be checked.

    Nothing in this statement is about Python.

    All I did was just proving your words once again to be nonsense: You can statically dispatch (which involves static type checking!) just fine on strings. My (Scala) code is prove of this fact.

    > There is literally nothing in my statement to indicate I'm making a general statement about type checking.

    LOL. Do you actually know what you're writing? Once more:

    > The contents of a string can't be type checked and if all methods are defined this way on a class none of it can be checked.

    That's a general statement… It couldn't be even more general, actually.

    > But I will say checking for the contents of a string is rare for a type checker to do. That is a general statement that is generally true.

    Once again complete nonsense.

    There are whole libraries doing more or less nothing else than handling singleton types.

    Whole software layers utilize that! But I guess you never heard of static data validation…

    https://github.com/Iltotore/iron

    You have so little clue, but such a big mouth… That's so embarrassing.

    A helpful tip: Stop spiting out maximally general claims (because these are almost always wrong!), and think about what you're actually writing.

    What's in your fantasy, or what you "may have meant" is irrelevant!

    > The guy made factually incorrect statements and so did you.

    That's exactly what I'm talking about: You're a severe DK victim as it seems…

    > It's just true that he's wrong.

    No, actually you are wrong with almost every claim, like I've proven now several times. And this nonsense still didn't stop… Oh, boy!

    > people shouldn't get worked up about someone else identifying a mistake.

    Think about that once again. Especially in the context that it's you who is wrong here with almost everything you say.

    And no, nobody is "pedantic". It only gets quite unrealistic that someone who doesn't even get banal prose straight would be able to write any code. Because the computer is actually very pedantic. And after production is on fire you can't just come to your boss and excuse yourself with "but I've meant this differently, just the stupid computer did again not understand what I've meant".

    But to be honest this would actually explain:

    > I've likely worked for more companies then you in the last 5 years or so due to my personality. I don't stay at one place for long.

    I have some suspicions to why you don't stay anywhere for long… And yes, that would be indeed related to personality…

  • Does the fthomas/refined library work differently in Scala 3?
    3 projects | /r/scala | 20 Jun 2023
    You might want to check out Iron.
  • Iron updates: turning opaque types into value objects
    2 projects | /r/scala | 6 Jun 2023
    And there is a beginner-friendly ticket: Add alias for True constraint and IronType[A, True]
  • Iron v2.1.0 is out!
    2 projects | /r/scala | 15 Apr 2023
  • Design by contract - Preconditions and Postconditions - I'm really amazed with Scala.
    4 projects | /r/scala | 2 Mar 2023
  • Restrict uses of annotation in Scala
    2 projects | /r/scala | 20 Feb 2023
    Annotation is not the only way (and probably not the best IMHO) to do refined types. You might be interested in Iron in Scala 3 or Refined in Scala 2/3.
  • Iron v2.0.0 Is Out
    1 project | news.ycombinator.com | 30 Jan 2023
  • Iron v2.0.0 is out 🎉
    1 project | /r/scala | 29 Jan 2023
    The second major version of Iron is out, featuring a complete rewrite on top of better foundations.

What are some alternatives?

When comparing dotty-cps-async and iron you can also consider the following projects:

scala3-example-project - An example sbt project that compiles using Dotty

scala-3-migration-guide - The Scala 3 migration guide for everyone.

cps-async-connect

Troy - Type-safe and Schema-safe Scala wrapper for Cassandra driver

iron-cats-example - An example project using Iron & Cats

Rx.NET - The Reactive Extensions for .NET

refined - Refinement types for Scala

scala-gopher - Implementation of CSP constructions (Communication Sequence Process, i.e. go-like channels) in scala

scala-redis - A scala library for connecting to a redis server, or a cluster of redis nodes using consistent hashing on the client side.

libretto - Declarative concurrency and stream processing library for Scala

longevity - A Persistence Framework for Scala and NoSQL