prog8/il65/examples/test.ill

223 lines
4.3 KiB
Plaintext
Raw Normal View History

2018-08-16 21:10:28 +00:00
%output prg
%launcher basic
2018-09-02 16:32:48 +00:00
%import c64lib
~ not_main $d000 {
2018-09-11 22:51:48 +00:00
byte [100] array1 = 0
word [100] array2 = 1
byte [2,3] matrix1 = 2
byte [2,3] matrix2 = [1,2,3,4,5,6]
const byte [100] carray1 = 2
const word [100] carray2 = 1.w
2018-09-11 22:51:48 +00:00
const byte [2,3] cmatrix1 = [1,2,3,4,5,255]
const float len1 = len([1,2,3])
const float round1 = len([1,2,3])
const float sin1 = len([1,2,3])
float cos1 = len([1,2,3])
}
2018-08-16 21:10:28 +00:00
~ main $c003 {
word lsb1 = lsb($ea31)
word msb1 = msb($ea31)
byte lsb2 = lsb($ea31)
byte msb2 = msb($ea31)
word lsb3 = lsb($ea)
word msb3 = msb($ea)
const word len1 = len([1,2,3,wa1, wa2, ws1, all1])
const word wa1 = ceil(abs(-999.22))
const byte wa1b = abs(99)
const byte wa1c = -(1-99)
const byte wa1d = -0
const byte wa2 = abs(-99)
const byte wa2b= abs(-99.w)
const byte wa2c = abs(-99)
const word wa2d = abs(-999)
const float wa3 = abs(-1.23456)
const float wa4 = abs(-133)
const float avg1 = avg([-1.23456, 99999])
const float sum1 = sum([-1.23456, 99999])
const word ws1 = floor(sum([1,2,3,4.9]))
const word ws2 = ceil(avg([1,2,3,4.9]))
const word ws3 = round(sum([1,2,3,4.9]))
const word any1 = any([0,0,0,0,0,22,0,0])
const word any2 = any([2+sin(2.0), 2])
const word all1 = all([0,0,0,0,0,22,0,0])
const word all2 = all([0.0])
const word all3 = all([wa1, wa2, ws1, all1])
const word max1 = max([-1,-2,3.33,99+22])
const word min1 = min([1,2,3,99+22])
word dinges = round(not_main.len1)
2018-08-16 21:10:28 +00:00
A = X>2
X = Y>Y
byte myByteChar = "A"
word myWordChar = "B"
2018-08-14 14:46:34 +00:00
word[1000] ascending = 10 to 1009
2018-08-14 14:29:08 +00:00
str ascending3 = "a" to "z"
str ascending5 = "z" to "z"
const byte cc = 4 + (2==9)
byte cc2 = 4 - (2==10)
; memory byte derp = max([$ffdd]) ; @todo implement memory vars in stackvm
; memory byte derpA = abs(-20000)
; memory byte derpB = max([1, 2.2, 4.4, 100])
; memory byte cderp = min([$ffdd])+ (1/1)
; memory byte cderpA = min([$ffdd, 10, 20, 30])
; memory byte cderpB = min([1, 2.2, 4.4, 100])
; memory byte derp2 = 2+$ffdd+round(10*sin(3.1))
const byte hopla=55-33
2018-08-13 21:28:04 +00:00
const byte hopla3=100+(-hopla)
const byte hopla4 = 100-hopla
const byte hopla1=main.hopla
const float blerp1 = zwop / 2.22
const float zwop = -1.7014118345e+38
2018-08-13 21:28:04 +00:00
const float zwop2 = -1.7014118345e+38
const float blerp2 = zwop / 2.22
2018-08-14 12:33:36 +00:00
const byte equal = 4==4
const byte equal2 = (4+hopla)>0
; goto 64738
A++
; derp++
cc2--
goto mega
2018-09-02 16:32:48 +00:00
if_eq goto mega
if_eq {
A=99
} else {
A=100
}
2018-08-14 14:29:08 +00:00
byte equalQQ = 4==4
const byte equalQQ2 = (4+hopla)>0
const str string1 = "hallo"
str string2 = "doei"
2018-08-14 14:29:08 +00:00
equalQQ++
AX++
A=msb(X + round(sin(Y)+ 1111))
A=lsb(X + round(sin(Y)+1111))
equalQQ= X
equalQQ= len([X, Y, AX])
equalQQ= len("abcdef")
equalQQ= len([1,2,3])
equalQQ= len(string1)
equalQQ= len(string2) ; @todo len function call on str type ALSO ADD ALL THIS TO DOCS OF FUNCTION LEN!
P_carry(1)
P_irqd(0)
2018-09-01 17:28:11 +00:00
;equalQQ = foo(33)
;equalQQ = main.foo(33)
foo(33)
main.foo(33)
2018-08-13 21:28:04 +00:00
XY = hopla*2+hopla1
2018-08-14 14:29:08 +00:00
byte equalWW = 4==4
const byte equalWW2 = (4+hopla)>0
if (1==1) goto cool
2018-08-14 12:33:36 +00:00
if (1==2) return 44
if (2==2) A=4
if (3==3) X=5 else A=99
if (5==5) {
A=99
}
if(6==6) {
A=sin(X) ; @todo should give error of float loss of precision
X=max([1,2,Y]) ; @todo must be byte so should be ok
X=min([1,2,Y]) ; @todo must be byte so should be ok
X=lsl(12)
X=lsl(Y) ; @todo must be byte so should be ok
P_carry(0)
P_carry(1)
P_carry(1-1)
P_irqd(0)
P_irqd(1)
2018-08-14 12:33:36 +00:00
} else X=33
X= extra233.thingy()
2018-08-14 14:29:08 +00:00
if(6>36) {
2018-08-14 12:33:36 +00:00
A=99
} else {
X=33
}
2018-08-14 00:22:59 +00:00
main.foo(1,2,3)
return
2018-08-14 00:22:59 +00:00
2018-09-05 23:02:36 +00:00
sub start () -> () {
word dinges = 0
word blerp1 =999
word blerp3 = 1
byte blerp2 =99
float flob =1.1
dinges=blerp1
blerp3 = blerp2
A=blerp2
A=$02
A=$002
A=$00ff
A=%11001100
A=%0010011001
A=99.w
XY=blerp1
X=blerp2
2018-09-05 23:02:36 +00:00
return
}
2018-08-13 18:28:15 +00:00
mega:
2018-08-16 21:10:28 +00:00
X += 1
2018-08-13 18:28:15 +00:00
cool:
Y=2
goto start
2018-08-13 18:28:15 +00:00
2018-08-13 02:12:42 +00:00
sub foo () -> () {
2018-08-13 21:28:04 +00:00
byte blerp = 3
2018-08-13 02:12:42 +00:00
A=99
; return 33
return
ultrafoo()
2018-08-13 02:12:42 +00:00
X =33
2018-08-13 18:28:15 +00:00
mega:
cool:
return
sub ultrafoo() -> () {
X= extra233.thingy()
;return 33
return
goto main.mega
}
2018-08-13 18:28:15 +00:00
2018-08-13 02:12:42 +00:00
}
2018-08-13 18:28:15 +00:00
some_label_def: A=44
;return 1+999
return
}
%import imported
%import imported
%import imported2
2018-08-13 18:28:15 +00:00
%import imported2