RPN Calculator in Chicken Scheme
up vote
0
down vote
favorite
My first attempt at Scheme (Chicken Scheme) - a simple RPN calculator. Please comment on exception handling as well as the general coding style. Here is the code:
(use stack)
(use srfi-69)
(use simple-exceptions)
(define prompt "> ")
(define stack (make-stack))
(define words (make-hash-table))
(define (init-words)
(hash-table-set! words "bye" '(quit))
(hash-table-set! words ".s" '(stack-print))
(hash-table-set! words "+" '(add))
(hash-table-set! words "-" '(subtract))
(hash-table-set! words "*" '(multiply))
(hash-table-set! words "/" '(divide))
(hash-table-set! words "." '(pop-print))
(hash-table-set! words "dup" '(dup))
(hash-table-set! words "drop" '(drop))
(hash-table-set! words "swap" '(swap)))
(define (stack-print)
(display (stack->list stack))
(newline))
(define (pop-print)
(display (stack-pop! stack))
(newline))
(define (add)
(stack-push! stack
(+ (stack-pop! stack)
(stack-pop! stack))))
(define (subtract)
(swap)
(stack-push! stack
(- (stack-pop! stack)
(stack-pop! stack))))
(define (multiply)
(stack-push! stack
(* (stack-pop! stack)
(stack-pop! stack))))
(define (divide)
(swap)
(stack-push! stack
(/ (stack-pop! stack)
(stack-pop! stack))))
(define (dup)
(let ((first (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack first)))
(define (drop)
(stack-pop! stack))
(define (swap)
(let ((first (stack-pop! stack))
(second (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack second)))
(define (f-read)
(display prompt)
(flush-output)
(read-line))
(define (f-parse line)
(string-split line))
(define (process word)
(cond
((hash-table-exists? words word)
(eval (hash-table-ref words word)))
((string->number word)
(stack-push! stack (string->number word)))))
(define (f-eval words)
(cond
((null? words) "")
(else (process (car words))
(f-eval (cdr words)))))
(define (f-print line)
(display line))
;; user-interrupt ?
(define (repl)
(guard
(exn (((exception-of? 'user-interrupt) exn)
(quit))
((exception? exn)
(display (message exn))
(newline)
(repl))
(else
(display (arguments exn))
(newline)
(repl)))
(init-words)
(f-print (f-eval (f-parse (f-read))))
(repl)))
scheme
New contributor
add a comment |
up vote
0
down vote
favorite
My first attempt at Scheme (Chicken Scheme) - a simple RPN calculator. Please comment on exception handling as well as the general coding style. Here is the code:
(use stack)
(use srfi-69)
(use simple-exceptions)
(define prompt "> ")
(define stack (make-stack))
(define words (make-hash-table))
(define (init-words)
(hash-table-set! words "bye" '(quit))
(hash-table-set! words ".s" '(stack-print))
(hash-table-set! words "+" '(add))
(hash-table-set! words "-" '(subtract))
(hash-table-set! words "*" '(multiply))
(hash-table-set! words "/" '(divide))
(hash-table-set! words "." '(pop-print))
(hash-table-set! words "dup" '(dup))
(hash-table-set! words "drop" '(drop))
(hash-table-set! words "swap" '(swap)))
(define (stack-print)
(display (stack->list stack))
(newline))
(define (pop-print)
(display (stack-pop! stack))
(newline))
(define (add)
(stack-push! stack
(+ (stack-pop! stack)
(stack-pop! stack))))
(define (subtract)
(swap)
(stack-push! stack
(- (stack-pop! stack)
(stack-pop! stack))))
(define (multiply)
(stack-push! stack
(* (stack-pop! stack)
(stack-pop! stack))))
(define (divide)
(swap)
(stack-push! stack
(/ (stack-pop! stack)
(stack-pop! stack))))
(define (dup)
(let ((first (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack first)))
(define (drop)
(stack-pop! stack))
(define (swap)
(let ((first (stack-pop! stack))
(second (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack second)))
(define (f-read)
(display prompt)
(flush-output)
(read-line))
(define (f-parse line)
(string-split line))
(define (process word)
(cond
((hash-table-exists? words word)
(eval (hash-table-ref words word)))
((string->number word)
(stack-push! stack (string->number word)))))
(define (f-eval words)
(cond
((null? words) "")
(else (process (car words))
(f-eval (cdr words)))))
(define (f-print line)
(display line))
;; user-interrupt ?
(define (repl)
(guard
(exn (((exception-of? 'user-interrupt) exn)
(quit))
((exception? exn)
(display (message exn))
(newline)
(repl))
(else
(display (arguments exn))
(newline)
(repl)))
(init-words)
(f-print (f-eval (f-parse (f-read))))
(repl)))
scheme
New contributor
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
My first attempt at Scheme (Chicken Scheme) - a simple RPN calculator. Please comment on exception handling as well as the general coding style. Here is the code:
(use stack)
(use srfi-69)
(use simple-exceptions)
(define prompt "> ")
(define stack (make-stack))
(define words (make-hash-table))
(define (init-words)
(hash-table-set! words "bye" '(quit))
(hash-table-set! words ".s" '(stack-print))
(hash-table-set! words "+" '(add))
(hash-table-set! words "-" '(subtract))
(hash-table-set! words "*" '(multiply))
(hash-table-set! words "/" '(divide))
(hash-table-set! words "." '(pop-print))
(hash-table-set! words "dup" '(dup))
(hash-table-set! words "drop" '(drop))
(hash-table-set! words "swap" '(swap)))
(define (stack-print)
(display (stack->list stack))
(newline))
(define (pop-print)
(display (stack-pop! stack))
(newline))
(define (add)
(stack-push! stack
(+ (stack-pop! stack)
(stack-pop! stack))))
(define (subtract)
(swap)
(stack-push! stack
(- (stack-pop! stack)
(stack-pop! stack))))
(define (multiply)
(stack-push! stack
(* (stack-pop! stack)
(stack-pop! stack))))
(define (divide)
(swap)
(stack-push! stack
(/ (stack-pop! stack)
(stack-pop! stack))))
(define (dup)
(let ((first (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack first)))
(define (drop)
(stack-pop! stack))
(define (swap)
(let ((first (stack-pop! stack))
(second (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack second)))
(define (f-read)
(display prompt)
(flush-output)
(read-line))
(define (f-parse line)
(string-split line))
(define (process word)
(cond
((hash-table-exists? words word)
(eval (hash-table-ref words word)))
((string->number word)
(stack-push! stack (string->number word)))))
(define (f-eval words)
(cond
((null? words) "")
(else (process (car words))
(f-eval (cdr words)))))
(define (f-print line)
(display line))
;; user-interrupt ?
(define (repl)
(guard
(exn (((exception-of? 'user-interrupt) exn)
(quit))
((exception? exn)
(display (message exn))
(newline)
(repl))
(else
(display (arguments exn))
(newline)
(repl)))
(init-words)
(f-print (f-eval (f-parse (f-read))))
(repl)))
scheme
New contributor
My first attempt at Scheme (Chicken Scheme) - a simple RPN calculator. Please comment on exception handling as well as the general coding style. Here is the code:
(use stack)
(use srfi-69)
(use simple-exceptions)
(define prompt "> ")
(define stack (make-stack))
(define words (make-hash-table))
(define (init-words)
(hash-table-set! words "bye" '(quit))
(hash-table-set! words ".s" '(stack-print))
(hash-table-set! words "+" '(add))
(hash-table-set! words "-" '(subtract))
(hash-table-set! words "*" '(multiply))
(hash-table-set! words "/" '(divide))
(hash-table-set! words "." '(pop-print))
(hash-table-set! words "dup" '(dup))
(hash-table-set! words "drop" '(drop))
(hash-table-set! words "swap" '(swap)))
(define (stack-print)
(display (stack->list stack))
(newline))
(define (pop-print)
(display (stack-pop! stack))
(newline))
(define (add)
(stack-push! stack
(+ (stack-pop! stack)
(stack-pop! stack))))
(define (subtract)
(swap)
(stack-push! stack
(- (stack-pop! stack)
(stack-pop! stack))))
(define (multiply)
(stack-push! stack
(* (stack-pop! stack)
(stack-pop! stack))))
(define (divide)
(swap)
(stack-push! stack
(/ (stack-pop! stack)
(stack-pop! stack))))
(define (dup)
(let ((first (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack first)))
(define (drop)
(stack-pop! stack))
(define (swap)
(let ((first (stack-pop! stack))
(second (stack-pop! stack)))
(stack-push! stack first)
(stack-push! stack second)))
(define (f-read)
(display prompt)
(flush-output)
(read-line))
(define (f-parse line)
(string-split line))
(define (process word)
(cond
((hash-table-exists? words word)
(eval (hash-table-ref words word)))
((string->number word)
(stack-push! stack (string->number word)))))
(define (f-eval words)
(cond
((null? words) "")
(else (process (car words))
(f-eval (cdr words)))))
(define (f-print line)
(display line))
;; user-interrupt ?
(define (repl)
(guard
(exn (((exception-of? 'user-interrupt) exn)
(quit))
((exception? exn)
(display (message exn))
(newline)
(repl))
(else
(display (arguments exn))
(newline)
(repl)))
(init-words)
(f-print (f-eval (f-parse (f-read))))
(repl)))
scheme
scheme
New contributor
New contributor
New contributor
asked 2 hours ago
Anonimista
1
1
New contributor
New contributor
add a comment |
add a comment |
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Anonimista is a new contributor. Be nice, and check out our Code of Conduct.
draft saved
draft discarded
Anonimista is a new contributor. Be nice, and check out our Code of Conduct.
Anonimista is a new contributor. Be nice, and check out our Code of Conduct.
Anonimista is a new contributor. Be nice, and check out our Code of Conduct.
draft saved
draft discarded
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f207631%2frpn-calculator-in-chicken-scheme%23new-answer', 'question_page');
}
);
Post as a guest
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password