./oceani --noexec --print .tmp.code1a >> .tmp.code2a || exit 1;\
if ! cmp -s .tmp.code1 .tmp.code2a; then \
echo " Failed"; diff -u .tmp.code1 .tmp.code2a; exit 1; fi ; \
+ echo -n "brackets.. "; \
+ echo '``````' > .tmp.code2b ; echo '``````' > .tmp.code2c ;\
+ ./oceani --noexec --print --brackets .tmp.code1 >> .tmp.code2b || exit 1; \
+ ./oceani -npb .tmp.code2b >> .tmp.code2c || exit 1 ; \
+ if ! cmp -s .tmp.code2b .tmp.code2c; then \
+ echo " Failed"; diff -u .tmp.code2b .tmp.code2c; exit 1; fi; \
echo -n "exec-after-print.. "; \
./oceani .tmp.code1 $${1+"$$@"} > .tmp.have ; \
if ! cmp -s .tmp.want .tmp.have; then \
## valgrind test code
@[ -n "$$SKIP_COVERAGE_CHECK" ] || awk '/NOTEST/ { next } /^ *[1-9]/ {ran+=1} /^ *###/ {skip+=1} \
END {printf "coverage: %6.2f%%\n", ran * 100 / (ran + skip); \
- if (ran < (ran + skip) *0.972) exit(1) }' \
+ if (ran < (ran + skip) *0.99) exit(1) }' \
coverage/oceani.mdc.gcov
coverage_oceani: oceani.c
print "z??False", z??False, "w??False", w??False
if ?w:
print "Weird?"
+ print $"-34.56", $"not-a-number"
+ print $"4i"
+ if True { pass; pass }
###### output: valvar
w??z True
z??w True
z??False True w??False False
+ -34.56 0
+ Unsupported suffix: 4i
+ 4
Next we change the value of variables
print
for i:=0; then i=i+1; while i < 5:
- switch i:
- case 0: num:="zero"
- case 1: num:="one"
- case 2: num:="two"
- case 3: num:="three"
- else num:="many"
+ switch { use i }
+ case 0: num:="zero" ;
+ case 1: num:="one" ;
+ case 2 { num:="two" } case 3 { num:="three" }
+ else num:="many"
// re-declare a CondScope variable
num := i*i
print num,", ",
print "error is ", target - guess * guess
for j:=0; then j = j+3 ; while j < 10:
- if j != 0 and then 20 / j > 3:
+ if j != 0 and 20 / j > 3:
print "20 /", j," =", 20 / j
else
print "I won't calculate 20 /", j
pi ::= 3.1415926535897
- if 355/113 == pi or else +(pi - 355/113) < 0.001:
+ if 355/113 == pi or +(pi - 355/113) < 0.001:
print "Close enough"
print "lower" if 355/113 < pi else "higher"
+ print "higher" if 355/113 > pi else "lower"
if pi > 3 then print "pi exceeds three"; else print "need more pie"
if (pi < 3) { print "not enough pi" } else { print "pi sufficient" }
else
print 'larger'
+ // different parsing options
+ for {
+ x:=1; sum := 0
+ } then {
+ x = x + 1
+ } while {
+ use x < 10
+ } do {
+ sum = sum + x
+ } case 1 {
+ print "impossible"
+ }
+
###### output: cond_loop
Success
1 2 4 8 16 32 64
I won't calculate 20 / 9
Close enough
higher
+ higher
pi exceeds three
pi sufficient
sum 1..10 is 55
const three ::= 3
struct foo
size:[three]number
- name:string
+ name:string = "Hello"
thing:baz
active:Boolean = True
struct baz { a:number; b:Boolean; }
+ struct bat {
+ a:string
+ b:Boolean
+ }
+ struct bat2 a:string; b:Boolean
func main
do
for i:=0; then i=i+1; while i < 4:
print info[i].name, info[i].active, info[i].size[0]
info[0].thing.b = True
+ x:bat
+ x.a = "Hello"
###### output: structs
angular := to_polar(32, 23)
print angular.rho, angular.theta
+ func test2(n:number; s:string;) : (ret:number)
+ ret = n + $s
+
+ func random
+ return
+ n:number
+ do
+ n = 4 // xkcd:221
+
+ // exercise the parsing options
+ func t1 (a:number) {
+ print "t1"
+ }
+ func t2 (a:string) {print "string"}
+ func t3() print "t3"
+
###### output: functions
done
1 done
func insert(list:@linkage; new:string)
p:=list
- while ?p.next and then p.next.this < new:
+ while ?p.next and p.next.this < new:
p = p.next.list
t:@node = @new()
t.list.next = p.next
func main()
print "hello" ++ 5, 5 ++ "hello"
-
+ hello := "there"; print 4+hello
b ::= 3
b = b + 1
###### output: type_err1
.tmp.code:3:25: error: expected string found number
.tmp.code:3:28: error: expected string found number
+ .tmp.code:4:34: error: expected number but variable 'hello' is string
+ .tmp.code:4:8: info: this is where 'hello' was set to string
.tmp.code:6:8: error: Cannot assign to a constant: b
.tmp.code:5:8: info: name was defined as a constant here
.tmp.code:8:11: error: Arithmetic returns number but Boolean expected
a:number = 4
a ::number = 5
c:
+ d:number = 02
###### output: type_err2
.tmp.code:4:8: error: variable 'a' redeclared
.tmp.code:7:8: error: variable 'a' redeclared
.tmp.code:3:8: info: this is where 'a' was first declared
.tmp.code:8:8: Variable declared with no type or value: c
+ .tmp.code:9:19: error: unsupported number format: 02
###### test: type_err3
struct foo
a: number
- b:string = "hello"
+ b:string = "hello"; d:Boolean
func main()
c := "hello"
case 2: print "two"
print "one" ++ a4[], c[]
+ x:Boolean = $"42"
+
+ five ::= 5
+ four ::= 4
+ x1:[five]number
+ x2:[four]number
+ x1 = x2
+
###### output: type_err3
.tmp.code:8:12: error: expected number but variable 'c' is string
.tmp.code:7:8: info: this is where 'c' was set to string
.tmp.code:38:29: error: expected number found Boolean
.tmp.code:41:23: error: have number but need string
.tmp.code:41:29: error: string cannot provide length
+ .tmp.code:43:21: error: Can only convert string to number, not Boolean
+ .tmp.code:43:8: info: variable 'x' was set as Boolean here.
+ .tmp.code:49:13: error: expected [five]number but variable 'x2' is [four]number
+ .tmp.code:48:8: info: this is where 'x2' was set to [four]number
+ .tmp.code:49:8: error: cannot assign value of type [five]number
+ .tmp.code:47:8: info: variable 'x1' was set as [five]number here.
oceani: type error in program - not running.
###### test: type_err4
b:string
struct foo
c:number
+ x:[5]:string
###### output: type_err5
.tmp.code:8:7: error: type already declared: foo
- .tmp.code:2:7: info: this is location of declartion: foo
+ .tmp.code:2:7: info: this is location of declaration: foo
+ .tmp.code:10:13: Syntax error in struct field: :
.tmp.code:5:7: error: type has recursive definition: baz
.tmp.code:2:7: error: type has recursive definition: foo