summaryrefslogtreecommitdiff
path: root/doc.txt
blob: 0c84bcca63c739dfc31d63fe4dc61a203197b1e8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# types
	nil: nil. it's always nil
	bool: true, false. 
	num: 1234. -123.56. 64bit floating point number
	cfunc: pointer to native c function
	func: badthing function
	arr: [ 10 20 30 ] array of badthing values
		array indexing is the same as function calling: (a 1) -> 20
	string: "hii". 
		strings are interned: two strings with the same contents
			are always the same object in memory

# variables
	let, def, fn, defn introduce new locals
	locals are lexically scoped, and scopes can be nested
	closures and upvalues will work soon
	if a local is not found with a given name, the name is instead
		resolved as a global.
		this behaviour might change because it's not very good.
	def and defn are only allowed at top level
	
# builtin forms
	arithmetic: + - * / %     (+ 1 2)
	equality: (= (+ 2 2) 4)
	comparison: (< 0 1).  ">" omitted deliberately.
	let: unremarkable. (let (a 100  b 200) (+ a b))
	set!: mutates values. (set! x 10)
		arrays: (set! (a 1) 20) sets index 1 of a
		setting 1 past the end of an array will append
	if: (if cond true-expr false-expr)
	while: (while cond body...)  returns nil
	for: (for (i 10) body...)  numeric for loop, i=0,1,...,9 returns nil
	each: (each (x arr) body...)  array for-each loop. returns nil
	do: (do body...)  returns value of last expr in body
	def: (def foo 123)  creates new local in current scope
	fn: (fn (arg0 arg1 arg2) body...)  anonymous. for now.
	defn: (defn (f x) body...)  function's name bound as local within body
	
# builtin functions
	(clock): clock(3)
	(say x): print representation of x, followed by newline
	(write x): print representation of x, with no newline
	(writebytes a): a is a list of nums in [0,255]
	(arr): create new empty array
	(append! a x): appends to array a in place, returns a
	(# a): get length of array a
	(, ...): pend. concatenates arrays, promotes non-arrays to arrays
				(, [1 2 3] 4) -> [1 2 3 4]
				(, [1 2 3] [4 5]) -> [1 2 3 4 5]
				(, 10 20) -> [10 20]  etc
	(s, ...): spend. concatenates strings

# cmdline args
	bth [-Dl] [-Dt] filenames...
		-Dl: print bytecode listing before execution
		-Dt: trace each executed bytecode instruction
		-Ds: dump read s-expressions
		filename "-" can be provided to mean stdin.