sweet.js VS proposal-pipeline-operator

Compare sweet.js vs proposal-pipeline-operator and see what are their differences.

SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
With SurveyJS form UI libraries, you can build and style forms in a fully-integrated drag & drop form builder, render them in your JS app, and store form submission data in any backend, inc. PHP, ASP.NET Core, and Node.js.
surveyjs.io
featured
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
sweet.js proposal-pipeline-operator
12 102
4,580 7,396
0.0% 0.9%
0.0 2.7
over 6 years ago 6 months ago
JavaScript HTML
BSD 2-clause "Simplified" License BSD 3-clause "New" or "Revised" 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.

sweet.js

Posts with mentions or reviews of sweet.js. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-30.
  • JavaScript Macros in Bun
    2 projects | news.ycombinator.com | 30 Jun 2023
    I was ready to be excited from the title, but was utterly disappointed :(

    IMO these aren’t macros in the Lisp-sense of the word (or Rust, or even C); yeah they run code at compile time, but that’s where the common ends.

    Macros should be able to apply syntactic transformation on the code. Lisp is famous for allowing that by representing code as lists. Rust has a compiler-level API to give tokens and run arbitrary code, then spit new tokens out. C macros operate on the tokens level, so with enough magic you can transform code to the shape you want.

    This… isn’t any of that.

    A pretty good example (and something I’m still sad that it didn’t take off) of macros in JS is Sweet.js[0]. Babel macros[1] are a bit higher level, where macros require the input to already be a valid AST, but that’s also cool.

    This… I’d say it’s more of a build-time code execution feature, not a macro feature.

    [0]: https://www.sweetjs.org/

    1 project | /r/node | 19 Jun 2023
    Macros I'd expect to be able to be able to expand at compile time to more code to reduce boilerplate, something like SweetJS.
  • Angular Signals: What? Why? and How? (Classy explanation of what we know as writables.)
    1 project | /r/sveltejs | 26 Jun 2023
    But yes, I'll tone down my appreciation for writables in this sub, I'll confine my tangents to svelte. A kind of a shame I'd love to talk about using https://www.sweetjs.org/ to make the $ autosubscription work outside of svelte, and the like. But holy off-topic Batman!
  • Sweet.js - Hygienic Macros for JavaScript (Macros allow you to sweeten the syntax of JavaScript and craft the language you always wanted)
    1 project | /r/javascript | 9 Feb 2023
  • Interesting... Macros for JavaScript?
    1 project | news.ycombinator.com | 9 Feb 2023
  • Pipe Operator (|>) For JavaScript
    9 projects | news.ycombinator.com | 20 Jan 2023
    Mozilla created SweetJS over a decade ago[0]. It added hygenic macros to JS and I'm sure everyone on the TC39 committee is familiar with it.

    There's a lot to like about it, but macros in such a complicated language as JS are hard to get right. They'd also potentially lead to huge fracturing in the JS ecosystem with different factions writing their own, incompatible macro-based languages.

    Look at JSX for an example. It's actually a subset of a real standard (E4X -- actually implemented in Firefox for a long time), but just one relatively small syntax addition has added complexity elsewhere.

    For example, `const foo = (x:T) => x` is valid Typescript for a generic arrow function, but is an error if your file is using JSX.

    I like the idea of macros, but I suspect they made the right call here.

    [0] https://www.sweetjs.org/

  • Ultra-minimal JSON schemas with TypeScript inference
    11 projects | news.ycombinator.com | 27 Jul 2022
    Sweetjs is unfortunately dead [0] for like 5 years now.

    It also doesn't have any typescript awareness which is required to build this kind of functionality - you want to have static type introspection available in macros so you can generate code based on provided types.

    [0] https://github.com/sweet-js/sweet-core/graphs/contributors

  • Equivalent to macros, ifdef and enums from other programming language?
    2 projects | /r/learnjavascript | 28 May 2022
    None of these are supported natively by JavaScript. Macros and ifdefs you could get with your own build step using things like sweetjs or ifdef-loader for webpack. Enums are in a similar boat with TypeScript supporting enums out of the box. But there's also a (very early) proposal to add enums natively to JavaScript as well.
  • What are some reasons to use metaprogramming?
    3 projects | /r/functionalprogramming | 16 May 2022
    TS doesn’t have monadic do notation, which is something that I want very badly. This would be easy to add to JavaScript with Sweet.js macros, but there’s no equivalent tool for TypeScript. I expect that extending this to TypeScript would be very difficult.
  • SICP: JavaScript Edition available for pre-order
    2 projects | news.ycombinator.com | 21 Jan 2022
    > If forEach is not to be used

    That source is simply incorrect. forEach is perfectly fine to use as long as you realize what is happening. It iterates an array where each thing is a function that returns a promise. Of course the results aren't what they expect.

    ES5 array additions suffer from being a little too early (though later stuff wouldn't exist otherwise, so...). They are designed to deal with holey arrays (arrays with indexes missing). This is extremely uncommon today, but was decently common once upon a time. They were also created before the iterator protocol.

    The real fix is to design iterator versions that can handle things like async generator functions.

    > it should be deprecated and removed from the language in a timely manner.

    NOTHING can be removed from the language once added. Doing that would break all the older websites that depend on it (technically, a few minor breaks happened after they tested millions of sites and couldn't find anything that was adversely affected). At best, they can block older features from newer features. For example, using class syntax or a bunch of other ES6 language structures automatically makes your code shift into "use strict" mode.

    I hope they introduce a "use strict 2" variant that strips away more of the undesirable features than the current "use strict" does.

    > Since Javascript is based on C syntax, it should have the preprocessor that the birthplace of C saw it fit for that language not to be without.

    That pre-processor was a source of untold nightmares. Direct injection leads to bugs. If someone is going that route, full-blown macros are the only answer. There is a full-blown macro system Mozilla created a few years ago, but it's not very popular.

    https://www.sweetjs.org/

    There also exist some C-style pre-processors for babel too, but they should be avoided because lisp's gensym is a critical feature that they and C both lack.

proposal-pipeline-operator

Posts with mentions or reviews of proposal-pipeline-operator. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-09-29.
  • Pipeline Operator great again!
    2 projects | dev.to | 29 Sep 2023
    Current Status: You'd have to check the TC39 proposals repository or the official proposal text for the most recent status. As of my last update, it had not yet reached Stage 4 (final stage) of the TC39 process, which means it wasn't part of the ECMAScript specification yet.
  • pipesAreFun
    3 projects | /r/ProgrammerHumor | 4 Jul 2023
    Javascript may get it https://github.com/tc39/proposal-pipeline-operator https://youtu.be/dQw4w9WgXcQ
  • JavaScript Gom Jabbar
    12 projects | news.ycombinator.com | 2 Jul 2023
    It can be further simplified. For example, you don't need two separate functions to extract the first chat completion message etc.

    This version:

    - uses existing language constructs

    - can be immediately understood even by the most junior devs

    - is likely to be 1000 times faster

    - does not rely on an external dependency that currently has 143 issues and every two weeks releases a new version adding dozens of new methods to things

    Note: one thing I do wish Javascript adopted is pipes: https://github.com/tc39/proposal-pipeline-operator

  • What's new in ES2023?
    2 projects | /r/javascript | 30 May 2023
    Still in stage 2 atm https://github.com/tc39/proposal-pipeline-operator
  • lizod - spiritual successor of zod less than 1kb
    2 projects | dev.to | 23 May 2023
  • Updates from the 96th TC39 meeting
    5 projects | /r/javascript | 19 May 2023
  • Mostly adequate guide to FP (in JavaScript)
    5 projects | news.ycombinator.com | 21 Mar 2023
    Both are active tc39 proposals :)

    https://github.com/tc39/proposal-pipeline-operator - Stage 2

    https://github.com/tc39/proposal-pattern-matching - Stage 1

    Hopefully we get both in the next couple of years.

  • Tipe - typed pipe
    2 projects | /r/Python | 6 Mar 2023
    Some time ago I saw how hyped JS community was about pipeline operator proposal. So I tried to make something similar in python. There is how tipe module was created. Check it out if you are interested: https://github.com/mishankov/tipe
  • CoffeeScript for TypeScript
    5 projects | news.ycombinator.com | 27 Feb 2023
    We often add promising TC39 proposals into Civet so people can experiment without waiting.

    We've added https://github.com/tc39/proposal-pipeline-operator, a variant of https://github.com/tc39/proposal-pattern-matching, a variant of https://github.com/tc39/proposal-string-dedent and others.

    Since our goal is to be 99% compatible with ES we'll need to accommodate any proposals that become standard and pick up anything TC39 leaves on the table (rest parameters in any position, etc.)

  • [AskJS] Is JavaScript missing some built-in methods?
    13 projects | /r/javascript | 23 Feb 2023
    The Proposal is for the Hack pipe, so your example would be

What are some alternatives?

When comparing sweet.js and proposal-pipeline-operator you can also consider the following projects:

Zepcode - ⚗️ Zeplin extension that generates Swift snippets from colors, fonts, and layers

ionide-vscode-fsharp - VS Code plugin for F# development

ts-morph - TypeScript Compiler API wrapper for static analysis and programmatic code changes.

content - The content behind MDN Web Docs

typescript-transformer-handbook - 📘 A comprehensive handbook on how to create transformers for TypeScript with code examples

ramda - :ram: Practical functional Javascript

medium-editor - Medium.com WYSIWYG editor clone. Uses contenteditable API to implement a rich text solution.

FiraCode - Free monospaced font with programming ligatures

ace - Ace (Ajax.org Cloud9 Editor)

Gigablast - Nov 20 2017 -- A distributed open source search engine and spider/crawler written in C/C++ for Linux on Intel/AMD. From gigablast dot com, which has binaries for download. See the README.md file at the very bottom of this page for instructions.

CodeMirror - In-browser code editor (version 5, legacy)

proposal-partial-application - Proposal to add partial application to ECMAScript