forked from MightyPork/crsn
parent
c28fee88fe
commit
9254635fd7
@ -0,0 +1,50 @@ |
||||
( |
||||
; Perform frequency analysis of the input stream. Pipe a file to this program. |
||||
(def MINCH 33) ; lowest counted char |
||||
(def MAXCH 126) ; highest counted char |
||||
|
||||
(sym tab r7) |
||||
(mkbf tab 128) |
||||
|
||||
(sym ch r6) |
||||
(sym sum r1) |
||||
(sym max r2) |
||||
(:rch) |
||||
(ld ch @cin (eof? (j :rch_end))) |
||||
(rcmp ch MINCH MAXCH (ne? (j :rch))) |
||||
(bfrd r0 @tab ch) |
||||
(inc r0) (inc sum) |
||||
(cmp r0 max (>? (ld max r0))) |
||||
(bfwr @tab ch r0) |
||||
(j :rch) |
||||
(:rch_end) |
||||
|
||||
(sym fac r3) |
||||
(div fac 100_000 max) |
||||
|
||||
(ld ch MINCH) |
||||
(:print) |
||||
(bfrd r0 @tab ch) |
||||
(cmp r0 max |
||||
(eq? |
||||
(ld @cout 27) (ld @cout '[') (ld @cout '3') (ld @cout '2') (ld @cout 'm')) |
||||
) |
||||
(tst r0 (z? (j :print_next))) |
||||
(mul r0 fac) |
||||
(div r0 1000) |
||||
(ld @cout ch) |
||||
(ld @cout ' ') |
||||
(call bar r0) |
||||
(:print_next) |
||||
(ld @cout 27) (ld @cout '[') (ld @cout 'm') |
||||
(inc ch) |
||||
(cmp ch MAXCH (le? (j :print))) |
||||
(proc bar/1 |
||||
(ld r0 arg0) |
||||
(:bar) |
||||
(ld @cout '#') |
||||
(dec r0 (nz? (j :bar))) |
||||
(ld @cout '\n') |
||||
(ret) |
||||
) |
||||
) |
@ -0,0 +1,39 @@ |
||||
( |
||||
; This program asks for a name and prints a greeting |
||||
|
||||
(sym name r7) |
||||
|
||||
(mkbf r0 "Your name: ") |
||||
(call prompt r0) (del @r0) |
||||
(ld name res0) |
||||
|
||||
(ld @cout '\n') |
||||
|
||||
(mkbf r1 "Hello, ") |
||||
(call print r1) (del @r1) |
||||
(call print name) (del @name) |
||||
(ld @cout '!') |
||||
(ld @cout '\n') |
||||
(halt) |
||||
|
||||
(proc print buf |
||||
(bfsz r1 @buf) |
||||
(:next) |
||||
(cmp r0 r1 (eq? (ret))) |
||||
(bfrd @cout @buf r0) |
||||
(inc r0) |
||||
(j :next) |
||||
) |
||||
|
||||
(proc prompt msg |
||||
(call print msg) |
||||
(sym dest r7) |
||||
(mkbf dest) |
||||
(:char) |
||||
(ld r0 @cin (eof? (ret dest))) |
||||
(cmp r0 '\n' (eq? (ret dest))) |
||||
(ld @cout r0) |
||||
(bfpush @dest r0) |
||||
(j :char) |
||||
) |
||||
) |
@ -0,0 +1,24 @@ |
||||
( |
||||
; This is an example implementation of itoa using a buffer of characters |
||||
(ld r0 -123456789) |
||||
|
||||
(mkbf r1) |
||||
(call itoa r1 r0) |
||||
|
||||
; print it |
||||
(:pn) (bfrpop @cout @r1 (em? (ld @cout '\n') (halt))) (j :pn) |
||||
(halt) |
||||
|
||||
(proc itoa buf num |
||||
(ld r1 num) |
||||
(tst r1 (<0? (mul r1 -1))) |
||||
(:next) |
||||
(mod r0 r1 10) |
||||
(add r0 '0') |
||||
(bfrpush @buf r0) |
||||
(div r1 10 (z? |
||||
(tst num (<0? (bfrpush @buf '-'))) |
||||
(ret))) |
||||
(j :next) |
||||
) |
||||
) |
Loading…
Reference in new issue