Please link to <a href="https://book.jank-lang.org/" rel="nofollow">https://book.jank-lang.org/</a> for anything related to the jank alpha. I wasn't quite ready to announce the alpha, but I appreciate that folks are excited. :)<p>There's just a couple more compiler features I wanted to get merged, but everything should be in order for folks to follow the book and try jank out.
Hi! I'm excited about jank and so I'm excitedly reading through the book you just linked. I noticed some grammatical errors. Will you consider PRs to the `book` section of the code, or would you prefer feedback in some other format in order to better maintain your authorial voice?
big kudos to all involved
Do you envision the development to track clojure as much as is possible, similar to how cljs was conceived to be clojure in js and not just clojure-ish js, or do you think you'll eventually diverge? I made a language a while ago that was like 90% clojure but hesitated to call it that because I didn't want there to be an expectation that the same code would run as-is in both languages. Seems like from the landing page you're going for more of a drop in replacement. Look cool, good luck!
jank is Clojure and will track upstream Clojure development. I'm working closely with the Clojure team and other dialect devs to ensure this remains the case. I am leading a cross-dialect clojure-test-suite to help ensure parity across all dialects: <a href="https://github.com/jank-lang/clojure-test-suite" rel="nofollow">https://github.com/jank-lang/clojure-test-suite</a> We have support or work ongoing for Clojure JVM, ClojureScript, Clojure CLR, babashka, Basilisp, and jank.<p>With that said, jank will do some trail blazing down other paths (see my other comments here about Carp), but they will be optional modes which people can enable which are specific to jank. Clojure compatibility will remain constant.
> jank is a general purpose programming language. It’s a dialect of Clojure, which is itself a dialect of Lisp. jank is functional-first, but it supports adhoc mutations and effects. All data structures are persistent and immutable by default and jank, following Clojure’s design, provides mechanisms for safe mutations for easy concurrency.<p>> Beyond Clojure, jank is brethren to C++ and it can reach into C++ arbitrarily to both access and define new C++ types, functions, and templates, at runtime. This is done by JIT (just in time) compiling C++, using Clang and LLVM. The result is that you can write Clojure code which can access C and C++ libraries trivially.<p>From <a href="https://book.jank-lang.org" rel="nofollow">https://book.jank-lang.org</a>, for those of us who've never heard of this language
Interesting. The last time I used C++, it was so painful to compile. I love Clojure, though, and a native target is appealing. I wonder how slow the compile/ recompile cycle is in Jank.
JIT compiling C++ is definitely the slowest thing we do. However, we're working on two different codegen modes.<p>1. C++<p>2. LLVM IR<p>The IR is much faster to compile, but its perf isn't nearly as good. This is meant to be a nice trade off, during iteration, so that you can use C++ codegen for your release artifact, but stick with IR when you're REPLing. The IR gen is still unstable right now, for the alpha, but we'll have both solidified this year.
For a second, I misread and thought it was going to be about this guy <a href="https://en.wikipedia.org/wiki/Jack_Lang_(French_politician)" rel="nofollow">https://en.wikipedia.org/wiki/Jack_Lang_(French_politician)</a>
Accompanying book: <a href="https://book.jank-lang.org/" rel="nofollow">https://book.jank-lang.org/</a>
Congrats on the alpha release! I've been following the jank blog for a year now and it's great to see it reach this milestone. What is the current state of development tooling (such as CIDER support) for Emacs users?<p>Also I noticed a typo/broken link in the Welcome section: The link for "foreward" points to <a href="https://book.jank-lang.org/foreward.html" rel="nofollow">https://book.jank-lang.org/foreward.html</a>, but it should be <a href="https://book.jank-lang.org/foreword.html" rel="nofollow">https://book.jank-lang.org/foreword.html</a>
We have a working nREPL server, but it's not yet merged into the jank repo. <a href="https://github.com/kylc/try-jank" rel="nofollow">https://github.com/kylc/try-jank</a><p>There's a Clang bug getting in the way of the progress we want, so we'll need to work around. There's a lot I'm juggling, but this is high priority.<p>Thanks for the broken link report. That should be fixed now.
Is there a static type system included/inferred?<p>Couldn’t not find the answer
As a dialect of Clojure, it's a dynamically typed language. But its designer has expressed interest in eventually adding static type checks via a gradual typing system¹:<p>> I mentioned that a native Clojure is the first step toward my dream language. Indeed, it doesn't stop there. jank will always be a Clojure dialect, but it will also optionally support more. Features like gradual typing (maybe linear typing), more explicit memory management, value-based errors, and stronger pattern matching, to name a few, improve upon Clojure. This will allow another axis of control, where some parts of the program can remain entirely dynamic and garbage collected while others are thoroughly controlled and better optimized. That’s exactly the control I want when programming.<p>--<p>1: <a href="https://jank-lang.org/blog/2025-01-10-i-quit-my-job/" rel="nofollow">https://jank-lang.org/blog/2025-01-10-i-quit-my-job/</a>
No full-lang static type system. jank has seamless C++ interop and all interop is statically typed, but as soon as things get back into Clojure land, it's all dynamically typed and hella polymorphic.<p>I will be exploring optional static typing modes for jank in the future, a la Carp. That will not be this year, though.
It is implementing Clojure which does not have static typing so my strong assumption would be no
Would something like this then be able to interface with Rust codebases?
I thought someone named Jank Lang found investment alpha.