A collection of ready to be used SCI configs.
This repository provides SCI configurations on the classpath. See the :dev
alias to check against which version of the libraries the configurations are
tested. You should bring in the dependency of targeted libraries yourself.
In general, a configuration can be enabled as in the following example for applied-science.js-interop:
(ns example
(:require [sci.configs.applied-science.js-interop :as j]
[sci.core :as sci]))
(def sci-ctx (doto (sci/init {}) ;; your initial config here
(sci/merge-opts j/config)))
(sci/eval-string* sci-ctx
"(require '[applied-science.js-interop :as j]) (j/assoc! #js {} :foo 1)")
;;=> #js {:foo 1}or if you like to include the config without calling sci/merge-opts (e.g. for
performance reasons), use the per-namespace values directly:
(ns example
(:require [sci.configs.applied-science.js-interop :as j]
[sci.core :as sci]))
(def sci-ctx (sci/init {:namespaces {'applied-science.js-interop j/js-interop-namespace}}))In general, only library/*-namespace and library/config vars are intented as the
public API. The rest is subject to breakage, even when vars are public. For
convenience, we list the public API for each library here.
Namespace: sci.configs.applied-science.js-interop
Public API:
configjs-interop-namespacenamespaces
Namespace: sci.configs.funcool.promesa
Public API:
configpromesa-namespacepromesa-protocols-namespacenamespaces
Namespace: sci.configs.reagent.reagent
Public API:
configreagent-namespacereagent-ratom-namespacereagent-debug-namespacenamespaces
The configuration for reagent.dom.server is available seperately via:
Namespace: sci.configs.reagent.reagent-dom-server
Public API:
configreagent-dom-server-namespace
Namespace: sci.configs.re-frame.re-frame
Public API:
configre-frame-namespacenamespaces
Namespace: sci.configs.mfikes.cljs-bean
Public API:
confignamespacescljs-bean-namespace
Namespace sci.configs.cljs.test
Public API:
confignamespacescljs-test-namespace
Public API:
confignamespacescljs-pprint-namespace
npm install and bb test
The configurations are licensed under the same licenses as the libraries they target. You are free to take the configs from this repository and adapt them as necessary for your projects. See LICENSE for additional info.