from Hacker News

TimL – Clojure like language which compiles down to VimL

by daGrevis on 4/1/14, 6:31 PM with 33 comments

  • by goldfeld on 4/1/14, 8:31 PM

    This is beyond my wildest wishes. Meaning I have wished, as a formerly active Vim plugin author now fully switched over to Emacs/evil, exactly for Clojure compiling down to VimL so that I could maintain my plugins as Clojure/Lisp code, compiling it to actual VimL for public consumption, as a preprocessor. I'd think that would mostly do away with runtime performance worries, and not require the plugin user to actually have TimL installed as a plugin. Which means it could ease the transition of plugin authors to TimL, until eventually it's ok (and perhaps performant) to have it as a runtime.

    Needless to say, I love the fact that Tim Pope has hopped on the Clojure bandwagon, that the community can enjoy well thought out tooling such as he did/does for Rails.

    That said, tpope is one of only a few driving forces over on the Vim side of Clojure, whereas most seem to flock to Emacs. So I see this as potentially a great opportunity to eventually have Clojure-ish compiling/running on both Vim and Emacs, so that plugin authors can literally write and keep a single codebase that maps into the respective editor APIs. Well, least common denominator I guess, with extras specific for each editor. And maybe, speaking from my experience developing Vim plugins and looking into Elisp code, we will need 'clojureditor' packages providing higher level functionality painstakingly implemented for both editors, since it would be plenty non-trivial code that probably doesn't belong in a core like TimL neither in a Clojure+elisp equivalent.

    Then you could see this actually taking off big time since the more voluminous Clojure+Emacs community would be writing a good deal of plugins which would also work on Vim for free (imagine that!), so that they could support both platforms because it wouldn't be much extra effort. Hats off to the Pope for actually taking on the arguably tougher half, since Elisp should hopefully be an easier target for a lisp like Clojure.

  • by skue on 4/2/14, 12:56 AM

    > Is this a joke? > > If you mean the 6,000 lines of working code, then no, I poured hundreds upon hundreds of very serious hours into that. But if you're referring to the fact it's woefully underdocumented, adds considerable overhead to an already slow host platform, and ultimately unlikely to gain any traction, then yeah, probably.

    This is the best sort of April 1 announcement - something ridiculously ironic and playful, yet incredibly useful long term. Thanks so much for creating this, along with all of your plugins.

  • by mikegerwitz on 4/1/14, 8:25 PM

    In the never-ending Emacs vs. Vim debate, as a long-time Vim user (with no intent on switching), I've always envied Elisp. tpope has once again delivered and maybe now I can stop shamefully eyeing up Emacs from a distance.

    I haven't given this a try yet, but I can expect that, if it works well, it will be worth even a modest performance hit.

  • by pi-rat on 4/1/14, 7:55 PM

    A lisp for vim - with months of commit history.. released on 1st of April.. awesome!
  • by rabino on 4/1/14, 8:27 PM

    Maybe the april fools' joke is that this is not a joke
  • by krick on 4/1/14, 8:12 PM

    It's so cool that I would be skeptic (real programming language that compiles into VimL? God, that must be buggy!) already if not the fact that it's written by tpope. That's totally awesome.
  • by aktau on 4/2/14, 2:23 PM

    Even though I like clojure and think it's cool, I don't think VimL needs another layer that slows it down. I'm putting my money on the VimL to Lua translator that's currently being worked on by ZyX-l (https://github.com/ZyX-I/neovim/tree/luaviml) for neovim. With that, we can run VimL as Lua code in LuaJIT, which will transform VimL from one of the slowest scripting languages to among the fastest.

    Note that I said among the fastest, because VimL uses native integers which Lua doesn't have. LuaJIT does have them but their conversion rules are different so there has to be some shim code (https://github.com/neovim/neovim/issues/392). There's also many other VimL -> Lua incompatibilities that will incur some slowdown but it should be wicked fast still.

    Of course, I expect that many people will start writing native lua plugins after a while, it is a far more pleasant language, after all.

  • by seth1010 on 4/1/14, 9:12 PM

    Oh, this is neat. (keeps reading...) HOLY SHIT TIM POPE
  • by Morgawr on 4/1/14, 9:25 PM

    At first I started reading and I was skeptical, there are so many abandoned/unused lisp dialects out there nowadays.. Then I checked the size of the project and at the first mention of actual clojure datatypes I was pleasantly surprised.

    Kudos tpope, this is freaking awesome!

  • by daGrevis on 4/2/14, 8:05 AM

  • by SmileyKeith on 4/1/14, 9:23 PM

    As someone who develops some plugins this looks freaking awesome. Think I'm past thinking this is a April fools joke, knowing his sense of humor, the number of lines of code and the commit history.
  • by jzelinskie on 4/1/14, 7:46 PM

    This could be totally awesome. Maybe with neovim's planned LuaJIT implementation of VimL this can actually run quick.
  • by kul_ on 4/2/14, 4:00 AM

    Can this be used to develop plugins for vim? I would love to see someone come up with a plugin in TimL or port one to it!
  • by tomphoolery on 4/1/14, 11:46 PM

    UGH! SO MONEY!!! <3 <3 <3