Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
cherry-cljs
Advanced tools
Experimental ClojureScript to ES6 module compiler.
Reducing friction between ClojureScript and JS tooling.
:warning: This project is an experiment and not recommended to be used in production. It currently has many bugs and will undergo many breaking changes.
Although it's early days and far from complete, you're welcome to try out cherry and submit issues.
$ mkdir cherry-test && cd cherry-test
$ npm init -y
$ npm install cherry-cljs@latest
Create a .cljs
file, e.g. example.cljs
:
(ns example
(:require ["fs" :as fs]
["url" :refer [fileURLToPath]]))
(prn (fs/existsSync (fileURLToPath js/import.meta.url)))
(defn foo [{:keys [a b c]}]
(+ a b c))
(js/console.log (foo {:a 1 :b 2 :c 3}))
Then compile and run (run
does both):
$ npx cherry run example.cljs
true
6
Run npx cherry --help
to see all command line options.
A few examples of currenly working projects compiled by cherry:
See the examples directory for more.
Goals of cherry:
.cljs
files on the fly into ES6-compatible .mjs
files."cherry-cljs"
which
contains cljs.core.js
, cljs.string
, etc. such that libraries written in
cherry can be compiled and hosted on NPM, while all sharing the same
standard library and data structures. See this
tweet on how that
looks.goog.*
stuff.[^:js {:keys [a b]} #js {:a 1 :b 2}]
Cherry may introduce new constructs such as js/await
which won't be compatible
with current CLJS. Also it might not support all features that CLJS offers. As
such, using existing libraries from the CLJS ecosystem or compiling Cherry CLJS
code with the CLJS compiler may become challenging. However, some results of
this experiment may end up as improvements in the CLJS compiler if they turn out
to be of value.
Depending on interest both from people working on this and the broader community, the above goals may or may not be pursued. If you are interested in maturing cherry, please submit issues for bug reports or share your thoughts on Github Discussions.
Cherry started out as a fork of Scriptjure. Currently it's being reworked to meet the above goals.
Cherry is licensed under the EPL, the same as Clojure core and Scriptjure. See epl-v10.html in the root directory for more information.
FAQs
Experimental ClojureScript to ES6 module compiler.
The npm package cherry-cljs receives a total of 36 weekly downloads. As such, cherry-cljs popularity was classified as not popular.
We found that cherry-cljs demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.