Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vlaaad/reveal
Read Eval Visualize Loop for Clojure
https://github.com/vlaaad/reveal
clojure repl tool visualization
Last synced: 4 days ago
JSON representation
Read Eval Visualize Loop for Clojure
- Host: GitHub
- URL: https://github.com/vlaaad/reveal
- Owner: vlaaad
- License: mit
- Created: 2020-02-17T20:46:21.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-26T19:25:12.000Z (16 days ago)
- Last Synced: 2024-12-31T21:05:24.455Z (11 days ago)
- Topics: clojure, repl, tool, visualization
- Language: Clojure
- Homepage: https://vlaaad.github.io/reveal/
- Size: 8.16 MB
- Stars: 605
- Watchers: 26
- Forks: 21
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-articles - Reveal: Read Eval Visualize Loop for Clojure
- awesome-clojure-repl - reveal
README
# ![logo](src/vlaaad/reveal/logo-32.png) Reveal: Read Eval Visualize Loop for Clojure
![demo](https://vlaaad.github.io/assets/reveal/demo.gif)
[![Clojars Project](https://img.shields.io/clojars/v/vlaaad/reveal.svg?logo=clojure&logoColor=white&style=for-the-badge)](https://clojars.org/vlaaad/reveal)
[![Slack Channel](https://img.shields.io/badge/slack-clojurians%20%23reveal-blue.svg?logo=slack&style=for-the-badge)](https://clojurians.slack.com/messages/reveal/)## Rationale
Repl is a great window into a running program, but the textual nature of its
output limits developer's ability to inspect the program: a text is not an
object, and we are dealing with objects in the VM.Reveal aims to solve this problem by creating an in-process repl output pane
that makes inspecting values as easy as selecting an interesting datum. It
recognizes the value of text as a universal interface, that's why its output
looks like a text: you can select it, copy it, save it into a file. Unlike text,
reveal output holds references to printed values, making inspecting selected
value a matter of opening a context menu.Unlike datafy/nav based tools, Reveal does not enforce a particular data
representation for any given object, making it an open set — that includes
datafy/nav as one of the available options. It does not use datafy/nav by
default because in the absence of inter-process communication to datafy is
to lose.Not being limited to text, Reveal uses judicious syntax highlighting to aid
in differentiating various objects: text `java.lang.Integer` looks differently
depending on whether it was produced from a symbol or a class.## Reveal Pro
Reveal aims to be an extensible tool suitable for helping with development of
any Clojure program. [Reveal Pro](https://vlaaad.github.io/reveal-pro) provides
a set of extensions that improve developer experience by providing more tools,
so you can focus on your problem with data and knowledge you need, available
as soon as you need it.## Documentation
You can find overview, setup instructions and more at
[vlaaad.github.io/reveal](https://vlaaad.github.io/reveal/).## Versioning, stability, public and internal code
Reveal uses `1.MAJOR.REVISION` versioning where:
- `1` is a static prefix for compatibility with semantic versioning. Reveal
should never introduce breaking changes, so if an update broke something,
please file a bug report;
- `MAJOR` is a number that is incremented when there are significant changes or
improvements to Reveal;
- `REVISION` is a commit number from the beginning of a history.Reveal's compatibility promise applies to its public API: `vlaaad.reveal` ns,
everything else is implementation detail that is subject to change. Reveal's UI
and controls might change in the future.