A set of host abstractions mimicking similar facilities available in Clojure for I/O, shell access, etc., along with mechanisms to bind the abstractions to host-specific implementations.
- Use a dynamic variable that is referenced throughout the library. This holds the host implementations and makes using them straightforward
- Define Protocols for Reading/Writing/Streaming
- Define a Bindings protocol for creating and interacting with the host implementation to construct the records that implement the R/W/S protocols from #2
- Define helper functions to tie into the host implementation
See the examples
directory in the Node bindings
implementation.
$ lumo -qc abio.jar:abio-node.jar
cljs.user=> (require 'abio.core '[abio.io :as io] 'abio.node)
nil
cljs.user=> (abio.core/set-bindings! (abio.node/bindings))
nil
cljs.user=> (def users-dir (io/as-file "/Users"))
#'cljs.user/users-dir
cljs.user=> users-dir
#abio.io.File{:path "/Users"}
cljs.user=> (io/directory? users-dir)
true
cljs.user=> (io/directory? "/etc/hosts")
false
cljs.user=> (def r (io/reader "/usr/share/dict/words" :encoding "UTF8"))
#'cljs.user/r
cljs.user=> (take 8 (io/line-seq r))
("A" "a" "aa" "aal" "aalii" "aam" "Aani" "aardvark")
Copyright © 2017 abiocljs and Contributors
Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.