Japt is is a shortened version of JavaScript. Online interpreter
"Hello, World!
In Japt, the last expression is automatically outputted. Also, when you have a string literal at the end of the program, you can leave out the ending quotation mark and it will be automatically inserted.
Even shorter:
`HÁM, W�ld!
(Note that the �
should be code point U+008E.)
Japt uses the shoco library for string compression. Wrapping your text in backticks `
instead of quotation marks "
tells the interpreter to automatically decompress the string. And like quotes, if you have a backtick at the end of a program, you can leave it off.
"Greetings, {U}!
Let's move on to input: the first few inputs (up to six) are stored in the variables U
, V
, W
, X
, Y
, and Z
. In case that's not enough, the entire input is stored as an array in N
.
Also shown here: curly braces inside the string tell the interpreter to evaluate the innards as Japt code. For example, "abc{U}xyz"
transpiles to "abc"+(U)+"xyz"
.
Again, with compression:
`GÎ>Ä�, {U}!
(Note that this time, the �
should be code point U+000F.)
N
Since all input is stored in N
, and output is implicit, all we have to do is call N
to output all of the input.
1
Taking advantage of Japt's automatic output, any single number is trivially a quine. But what fun is that? Let's try a better one:
"+Q ³s7J"+Q ³s7J
"+Q ³s7J" // Take this string,
+Q // add a quotation mark,
³ // repeat it 3 times,
s7J // and slice off the first 7 chars and last 1 char. (J = -1)
The syntax of Japt is much the same as JavaScript; in fact, after transpilation, it is evaluated as normal JS. Here's the specialties:
When transpiling, each right parenthesis )
is doubled ))
, then each space is replaced with )
. This helps to save space when nesting function calls.
Also, if you have extra parentheses next to semicolons or at the beginning or end of the program, you can leave them out. The interpreter will catch on and add them when transpiling.
All uppercase letters are pre-defined to different values. A-L
are numbers, M
is the Math
object, P-S
are text-related, and U-Z
are the first six inputs. Besides keeping variable-related things simple, this also allows us to shorten syntax even more with...
A variable or literal of any sort can be followed by a lowercase letter. This will automatically transpile to a function call. For example, "abc"q
becomes "abc".q(
, which functions as "abc".split(
. 23s2
transpiles to 23 .s(2)
, or 23 .toString(2)
; "asdf"s1,3
transpiles to "asdf".s(1,3)
, or "asdf".slice(1,3)
.
Since most of these functions return values, you can chain them: "abcdefghij"s2,6 n36
transpiles to "abcdefghij".s(2,6).n(36)
, or "abcdefghij".slice(2,6).toNumber(36)
.
You can also leave out commas between arguments, as long as they're not two literal numbers. UtV2
transpiles to U.t(V,2)
.
If you need a string made of a single char, you can type an apostrophe, then the char, like 'a
. This transpiles to "a"
, which can be used exactly the same as all other strings. Similarly, #a
transpiles to the character code of a
, or 97
. If you need a large number (>= 100
), this is probably the cheapest way to attain it.
Thanks to the power of the regex, you can use ES6's string interpolation in Japt! Anything inside curly braces in a string is evaluated as actual code. For example, "abc{U}xyz"
: transpiles to "abc"+(U)+"xyz"
. If you need to use actual curly braces in the string, just precede the left brace with a backslash, like so: "abc\{U}xyz"
Need to return one of two different strings, using a?b:c
syntax? No problem! You can omit the two middle quotation marks. E.g. U==1?"abc":"xyz"
can be shortened to U==1?"abc:xyz"
. But what's that? One of the strings already contains a colon? Well, there's a remedy for that, too! Just precede the colon with a backslash. U==1?"abc\:123:xyz"
transpiles to U==1?"abc:123":"xyz"
.
Oh, and one more thing: if you have a string literal at the end of a program, you can leave out the final quotation mark, and the interpreter will automatically insert it for you.
Japt uses the shoco library for string compression. You can access this in a few ways:
- Using
Oc"text to compress"
, you can compress the text to save bytes. - Using
Od"text to decompress"
, you can decompress the pre-compressed text. - Wrapping your text in backticks
`
instead of quotation marks"
tells the interpreter to automatically decompress the string.
Japt code can be compressed, similarly to its strings. The most commonly used runs of characters are mapped to Unicode points, starting at ¡
. A full list of these can be found at the online interpreter.
With ES6, we got the new fat arrow operator =>
, which quickly and concisely defines a function. In Japt, the equivalent is {
, with any number of uppercase letters preceding it as arguments. For example, XY{X+Y}
defines a function that takes in two arguments, and returns the result of adding them (or concatenating them, if one is a string).
There's also two shortcut operators:
@
, which stands in forXYZ{
.UrXY{X+Y}
can be reduced toUr@X+Y}
._
, which stands in forZ{Z
.UmX{Xc}
can be reduced toUm_c}
.
Also, when performing a single-char operation as a function, you can usually just reduce the function to one or two chars:
- When doing something like
UrXY{X+Y}
, you can simply use the operator:Ur+
- When the arguments are reversed, like with
UrXY{Y-X}
, just prefix the operator with an exclamation point:Ur!-
- When using a single prototype function, e.g.
UmX{Xc}
, just use the letter:Umc
- When you need to preform the operator or function with a fixed value or variable, e.g.
UmX{Xp2}
, use the value after the operator:Ump2
- When you need to switch the two values, e.g.
UmX{2pX}
, prefix the function with an exclamation point:Um!p2
Have a task that Japt just can't handle yet on its own? Well, the good news is, you can call pure JavaScript code inside a Japt program! Anything between dollar signs $...$
will be preserved through the compilation process. For example, Japt doesn't actually have for
loops yet, so you could use something similar to $for(Z=0;Z<A;Z++)$
instead.