Giter Site home page Giter Site logo

rhcarvalho / calva Goto Github PK

View Code? Open in Web Editor NEW

This project forked from betterthantomorrow/calva

0.0 1.0 0.0 452.85 MB

Clojure & ClojureScript Interactive Programming for VS Code

Home Page: https://marketplace.visualstudio.com/items?itemName=betterthantomorrow.calva

License: Other

TypeScript 65.28% HTML 0.27% JavaScript 0.42% Clojure 33.10% CSS 0.06% Shell 0.01% Dockerfile 0.01% SCSS 0.87%

calva's Introduction

Calva: Clojure & ClojureScript with Visual Studio Code

Calva logo

Distilled from CIDER*.

Welcome to Calva, an integrated REPL powered environment for enjoyable and productive Clojure and ClojureScript in Visual Studio Code. It includes inline code evaluation, Paredit, a Clojure formatter, a test runner, Clojure syntax highlighting, and more. Most of the REPL power is harvested from the produce of The Orchard.

(*) Calva is short for Calvados, a liquid gifted to humanity from God.

Users Like it 😍

Crispin Bennett's review:

This is great, and makes VS Code a truly viable IDE/editor for clojure development. It has great REPL support (including inline evaluation), an extensive Paredit implementation, and excellent linting (care of the bundled clj-kondo). Calva is being improved on at an impressive clip by maintainers who appear solidly committed to its ongoing development. It's well-documented, and manages to be both approachable and capable. A no-brainer if you're already a VS Code user, and well worth a look if you're not.

It's Easy to get Started

https://www.youtube.com/embed/O6GrXXhCzCc

There is Documentation

Head over to https://calva.io/ to learn more about how to use Calva. The most important stuff would be:

Why Calva?

From The Tao of Calva:

Calva's raison d´être is to provide Visual Studio Code users with an easy to use and productive environment for Clojure and ClojureScript development.

From the same page you can also learn that we want Calva to be a good choice for VS Code users asking:

How do I use my favorite code editor for Clojure development?

We also hope that Calva will contribute to making it easier to pick up Clojure as a new language.

Getting Started with Calva

Go to the documentation to find info on how to connect Calva to your project and start evaluating code and such. The documentation is built from this repository, and the source files are located in docs/site. So if you know about workarounds or gotchas or anything that is good to know about when using Calva, please edit the appropriate page (or create a new page) by PR.

Features

  • Syntax highlighting, plus:
    • Rainbow parens
    • Rainbow indent guides
    • Highlight active indent guide
    • Highlights misplaced brackets
    • LISP friendly bracket matching
    • Ignore form (#_) dimming and (comment) form highlighting
  • Code formatting and autoindent according to https://github.com/bbatsov/clojure-style-guide
  • Structural Editing (via Paredit)
  • Linting
  • Intellisense
  • Go to / peek at definition
  • Find all references
  • Rename symbol
  • Change all occurrences
  • References code lens (enable in settings)
  • Outline view
  • View doc strings on hover
  • View function signatures on hover, including help with knowing which argument you are typing
  • Debugger
  • Support for Clojure tools/deps, Leiningen, shadow-cljs, Figwheel Main, lein-figwheel, and the built-in ClojureScript browser/node repls. (For Boot, only Connect scenarios work, there is no Jack-in there.)
  • Your Custom Connect Sequences, including fully customized ClojureScript REPLs.
  • Switch the ClojureScript REPL connection between your different builds at will.
  • When editing cljc files, easily choose if REPL commands should go to the clj or cljs REPL by clicking the cljc/clj[s] indicator in the status bar.
  • And more

Powered in Part by Clojure-lsp

Calva uses a mix of static and dynamic analysis to power the experience. A lot of the static abilities come from clojure-lsp, and you can read more about Calva's integration of clojure-lsp in the documentation.

Demo: Evaluate top level forms inside (comment...)

Top level comment eval

The gif demos several more features, apart from the in-comment evaluation, like:

  • Signature help while typing function calls
  • Evaluation result display is a bit sticky (so you can examine several evaluations at once)
  • There is a richer display of results in the hover of the evaluated expression. (From where you can also copy the results to the clipboard)
    • Edit: This feature has been removed in favor of using peek definition. See here. This decision was made due to high memory usage from storing results, but may be added back at some point if it's desired by many users over the peek definition feature. Please let us know here if you'd like this added back.
  • Some structural editing

Demo: Signature Help, while Typing

It is pretty educational using the signature help hover to see which argument you are typing when the argument list is using destructuring, or when an argument is threaded in first before the arguments you provide inside the form.

Signature Help

Demo: Syntax highlighting, rainbow parens and guides

Dimming ignored forms

Demo: Syntax highlighting, dimming ignored forms

Dimming ignored forms

Demo: Peek at definitions, etcetera

Features

Demo: switch between clj and cljs repl sessions for cljc files

CLJC repl switching

Demo: References code lens (enable in settings)

References code lens

Demo: Outline

Outline view

How to contribute

I'm glad you are reading this section! There are many ways and you are welcome to combine them at will. Be creative 😄:

  • Give us feedback.
    • Via #calva at the Clojurians Slack.
    • Via filing issues.
  • Fix issues. PRs welcome! Calva is built using a combination of TypeScript and ClojureScript. The ClojureScript part uses the shadow-cljs tool chain. See the How to Contribute page on the wiki for instructions on how to hack on Calva. TL;DR It is super easy to get started!
  • Fix typos in the UI and in the docs. It might seem like a small enough thing to not bother about it, but really, typos get in the way of comprehension. Typos are bad, uhm?
  • Become a GitHub sponsor. Read on.

Calva Sponsors ❤️

A considerable amount of time, creativity, energy, worries, sweat, and tears (well, no tears, but anyway 😄), is being spent on Calva. Please consider sponsoring us to show us that extra level of appreciation. Here are the ways you can do it:

Please see this statement from Cognitect about the importance of supporting open source developers.

The following people are helping to keep Calva maintained and improved by sponsoring with their hard earned money. It is fantastic. Thank you!

Patrons, Gold, and Silver sponsors are also displayed here: https://calva.io/#sponsors.

Calva Patrons

Agical

Calva Gold Sponsors

Liftoff     Cognitect

Calva Silver Sponsors

pitch.io

Calva Super Fans

Aram Zadikian

Calva Fans

Bozhidar Batsov Clay Hopperdietzel Matthew Lyon Brian Scaturro Jochen Bedersdorfer Janne Sauvala ajoberstar glebovmaksim Chris Smothers

Calva Friends

Martin Klepsch Pedro Girardi Terje Scott Archer Norman Eckstein Sergei Udris Filipe Silva Snorre Magnus Davøen Nick A Nichols Ryan Jerue Tim Zöller Kailashnath Russell Matney Bertrand Cachet José Diaz Seng Nick Cernis Steve Ashton

The Calva Team

We are Clojure and Visual Studio Code fans who care about the ergonomics of using our favorite programming language with our editor of choice.

Current Maintainers

Soon? returning

Alumni

Code Contributors

Calva is a quite young open source project, with surprisingly many code contributors. We take great care to keep it easy and fun to contribute. See the Calva Development Wiki for more on this.

Happy Coding

We hope you will find good use for Calva. Please let us know what you think. PRs welcome, file an issue or chat us up in the #calva channel in the Clojurians Slack.

calva's People

Contributors

agoldhammer avatar andresrgz avatar bpringe avatar brdloush avatar cfehse avatar crispinb avatar dependabot[bot] avatar diegovdc avatar dr0i avatar ericdallo avatar holyjak avatar kstehn avatar marcomorain avatar mseddon avatar nbardiuk avatar nickcernis avatar pedrorgirardi avatar pez avatar pratik97 avatar rjerue avatar rogererens avatar sashton avatar sivertsenstian avatar stefan-toubia avatar svdo avatar teves-castro avatar tonsky avatar trevor-brandt avatar xfthhxk avatar zelark avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.