nitin -
An experimental Nit interactive interpreter
This tool is outside src/ because:
- Is is greatly experimental
- It can depend on readline (GPL3) whereas the rest of nitc is Apache2. Both are compatible but the final binary result is GLP3.
Features
- use GNU readline to read lines
- use importation/refinement to handle incremental execution (so basically everything works out of the box)
- maintain an interpreter and live objects (the model grows but the interpreter and runtime data are reused)
- runtime errors/aborts return to the interactive loop
- top-level variables are preserved but are only visible at the top level
- Basic FFI
Main missing feature
- No model/object inspection
Examples
-->
is the prompt, ...
the continuation prompt. What follows is the user input.
The rest is the output.
Basic instructions
$ nitin
--> print 5+2
7
--> var a = 5
--> print a + 3
8
Complex and control statements
-->var sum=0
-->for i in [0..5[ do
...print i
...sum += i
...end
0
1
2
3
4
-->print sum
10
You can use do
blocks to delay the execution and control the scope of variables.
-->do
...var sum=0
...for i in [0..50[ do
...sum += i
...end
...print sum
...end
1225
Classes and methods
-->class A
...fun foo do
...print "hello"
...end
...end
-->(new A).foo
hello
Error management
In case of static errors, the history (up arrow) can be reused and updated.
-->class
...end
end
^: Syntax Error: unexpected keyword 'end'.
-->class A **up arrow and update, thanks readline**
end
1,7: Redef Error: `A` is an imported class. Add the `redef` keyword to refine it.
class A
^
-->redef class A **up arrow and update again, thanks readline**
redef fun foo do print "Bye"
end
-->(new A).foo
bye
Class refinement
Class refinement is available
-->redef class String
...fun foo: String do return self + "foo"
...end
-->print "hello".foo
hellofoo
Top-level methods automatically refine Sys.
-->foo
1,1--3: Error: method or variable `foo` unknown in `Sys`.
foo
^
-->fun foo do
...print "I'm sys"
...end
-->foo
I'm sys
Already instantiated objects gain the new methods, attributes and specializations.
-->class A
...end
-->var a = new A
-->print a
--><A:#561daea16660>
-->redef class A
...redef fun to_s do return "A"
...end
-->print a
A
However, the new attributes are left uninitialized (default values or init are not recomputed on existing objects)
-->redef class A
...var v = "foo"
...redef fun to_s do return "A:{v}"
...end
--->print a
Runtime error: Uninitialized attribute _v
redef fun to_s do return "A:{v}"
^
,---- Stack trace -- - - -
| input-6$A$to_s (13,30)
| file$Sys$print (lib/core/file.nit:1694,19--29)
| input-7$Sys$main (15,1--7)
`------------------- - - -
-->a.v = "bar"
-->print a
A:bar
Dynamic importation
-->print([0..10[.to_a.to_json)
1,20--26: Error: method `to_json` does not exists in `Array[Int]`.
print([0..10[.to_a.to_json)
^
-->import json
-->print([0..10[.to_a.to_json)
[0,1,2,3,4,5,6,7,8,9]
FFI
The FFI is handled as with the non-interactive interpreter.
-->fun hello `{
...puts("Hello, world");
...`}
-->hello
Hello, world
Content
- nitin: An experimental Nit interactive interpreter (contrib/nitin)
- nitin: The Nit interactive interpreter (contrib/nitin/nitin.nit)