parlour VS Polyphony

Compare parlour vs Polyphony and see what are their differences.

parlour

A type signature generator, merger and parser system for Sorbet and Ruby 3/Steep (by AaronC81)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
parlour Polyphony
1 22
88 651
- 0.0%
2.3 8.3
about 8 hours ago about 1 month ago
Ruby C
MIT License MIT License
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.

parlour

Posts with mentions or reviews of parlour. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-07-30.
  • Sorbet Compiler: An experimental, ahead-of-time compiler for Ruby
    6 projects | news.ycombinator.com | 30 Jul 2021
    (disclaimer: I work on the Sorbet team)

    I think I understand GP's motivation: RBI files and RBS files are two different formats, and as a user of the language, people tend to want to use the officially blessed solution the language provides.

    In case you weren't aware, parlour[1] is a popular open source project for working with RBI files. I believe it supports transparently converting between RBI files (Sorbet) and RBS files (Ruby 3).

    There is also rbs_parser[2], a C++ parser for RBS files to convert them to RBI files, written by Shopify, a major user of Sorbet.

    Stepping back: I haven't personally read many complaints from Sorbet users describing how the current state of RBI/RBS interop gets in the way of what they can actually do with Sorbet. Almost all the feature requests we get about Sorbet (both inside Stripe and outside) are for fixing bugs or implementing new language-level features. RBI files as implemented seem to work.

    Sorbet already has an extensive set of RBI files covering the Ruby standard library (at least as good or better to my knowledge than any existing repository of types for RBS files), and there are plentiful tools for working with RBI files, listed here.[3]

    If lack of first-party RBS support in Sorbet is holding you back from trying Sorbet, I'd strongly encourage you to give Sorbet a try anyways! Many people have shared great experiences adopting Sorbet in their Ruby codebases.

    [1] https://github.com/AaronC81/parlour

    [2] https://github.com/Shopify/rbs_parser

    [3] https://sorbet.org/en/community

Polyphony

Posts with mentions or reviews of Polyphony. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-16.
  • Should You Be Scared of Unix Signals?
    8 projects | news.ycombinator.com | 16 Oct 2023
    When using green threads/fibers/coroutines, an interesting technique to make signal handling safer is to run the signal handler asynchronously on a separate fiber/green thread. That way most of the problems of dealing with signals go away, and there's basically no limitation on what you can do inside the signal handler.

    I've successfully used this technique in Polyphony [1], a fiber-based Ruby gem for writing concurrent programs. When a signal occurs, Polyphony creates a special-purpose fiber that runs the signal handling code. The fiber is put at the head of the run queue, and is resumed once the currently executed fiber yields control.

    [1] https://github.com/digital-fabric/polyphony

  • Polyphony 1.4 Released
    2 projects | /r/ruby | 2 Jul 2023
    Read the release notes here: https://github.com/orgs/digital-fabric/discussions/110 The Polyphony docs: https://www.rubydoc.info/gems/polyphony The Polyphony repository: https://github.com/digital-fabric/polyphony
  • Polyphony: Fine-Grained Concurrency for Ruby
    3 projects | news.ycombinator.com | 12 May 2023
  • Polyphony 0.99 released. Last release before 1.0!
    2 projects | /r/ruby | 9 Mar 2023
    Polyphony is a gem for building highly-concurrent Ruby programs. It utilizes Ruby fibers to provide a high-performance safe environment for launching any number of concurrent operations. Under the hood, Polyphony employs io_uring to maximize I/O performance (libev is used on platforms other than recent Linux kernels).
  • Polyphony – Fine-grained concurrency for Ruby
    1 project | news.ycombinator.com | 14 Nov 2021
  • About that monkey-patching business...
    1 project | dev.to | 4 Nov 2021
    Is monkey-patching inherently bad? Should its use make Polyphony illegitimate? These are the questions I'm exploring in my latest article.
  • Async Ruby
    7 projects | /r/ruby | 30 Oct 2021
    how is this diff from: https://github.com/digital-fabric/polyphony
  • Embracing Infinite Loops with Ruby and Polyphony
    1 project | dev.to | 13 Oct 2021
    Infinite loops are great for expressing long-running concurrent operations. In this article I’ll discuss the use of infinite loops as a major construct when writing concurrent apps in Ruby using Polyphony. I’ll show how infinite loops differ from normal, finite ones; how they can be used to express long-running tasks in a concurrent environment; and how they can be stopped. Read it now!
  • What's new in Polyphony and Tipi - August 2021 edition
    2 projects | dev.to | 27 Aug 2021
    Polyphony is a library for writing highly concurrent Ruby apps. Polyphony harnesses Ruby fibers and a powerful io_uring-based I/O runtime to provide a solid foundation for building high-performance concurrent Ruby apps.
  • Sorbet Compiler: An experimental, ahead-of-time compiler for Ruby
    6 projects | news.ycombinator.com | 30 Jul 2021
    > Curious if there’s anything public about improving ruby performance from the I/O angle mentioned in the post.

    I'm currently working on Polyphony [0], a Ruby gem for writing highly-concurrent Ruby apps. It uses Ruby fibers under the hood, and does I/O using io_uring (on Linux, there is also a libev-based backend).

    [0] https://github.com/digital-fabric/polyphony

What are some alternatives?

When comparing parlour and Polyphony you can also consider the following projects:

rbs_parser - Ruby RBS parsing and translation to Sorbet RBI

Async Ruby - An awesome asynchronous event-driven reactor for Ruby.

crystal - The Crystal Programming Language

Concurrent Ruby - Modern concurrency tools including agents, futures, promises, thread pools, supervisors, and more. Inspired by Erlang, Clojure, Scala, Go, Java, JavaScript, and classic concurrency patterns.

sorbet - A fast, powerful type checker designed for Ruby

EventMachine - EventMachine: fast, simple event-processing library for Ruby programs

value-object-in-ruby-benchmarks - A series of micro benchmarks about Data.define vs Struct vs OpenStruct in #Ruby

Celluloid - Actor-based concurrent object framework for Ruby

render_async - render_async lets you include pages asynchronously with AJAX

Opal-Async - Non-blocking tasks and enumerators for Opal.

tipi - Tipi - the All-in-one Web Server for Ruby Apps

ruby-netsnmp - SNMP library in ruby (v1, v2c, v3)