向 DrRacket 添加“Simply Scheme”语言

Jim*_*Boy 4 scheme racket

我想通读这本书:http : //www.eecs.berkeley.edu/~bh/ss-toc2.html。但是我很难让“Simply Scheme”语言工作。代码不会运行。

    #lang planet dyoo/simply-scheme:2
    (parse ’(4 + 3 * 7 - 5 / (3 + 4) + 6))
Run Code Online (Sandbox Code Playgroud)

我不断收到以下错误消息:“解析:模块中的未绑定标识符:解析”。

Ósc*_*pez 5

看看这个页面,它有完整的说明。只需这样做:

#lang racket
(require (planet dyoo/simply-scheme:2:2))
Run Code Online (Sandbox Code Playgroud)

还要注意字符不正确,对于引用使用',这可能是因为您复制粘贴的代码排版错误。

当然,在上面完成之后,你必须定义第18章中解释的过程,它们不是在你刚刚导入的包中定义的!这肯定会起作用:

(define (parse expr)
  (parse-helper expr '() '()))

(define (parse-helper expr operators operands)
  (cond ((null? expr)
     (if (null? operators)
         (car operands)
         (handle-op '() operators operands)))
    ((number? (car expr))
     (parse-helper (cdr expr)
               operators
               (cons (make-node (car expr) '()) operands)))
    ((list? (car expr))
     (parse-helper (cdr expr)
               operators
               (cons (parse (car expr)) operands)))
    (else (if (or (null? operators)
              (> (precedence (car expr))
             (precedence (car operators))))
          (parse-helper (cdr expr)
                (cons (car expr) operators)
                operands)
          (handle-op expr operators operands)))))

(define (handle-op expr operators operands)
  (parse-helper expr
        (cdr operators)
        (cons (make-node (car operators)
                 (list (cadr operands) (car operands)))
              (cddr operands))))

(define (precedence oper)
  (if (member? oper '(+ -)) 1 2))

(define (compute tree)
  (if (number? (datum tree))
      (datum tree)
      ((function-named-by (datum tree))
         (compute (car (children tree)))
         (compute (cadr (children tree))))))

(define (function-named-by oper)
  (cond ((equal? oper '+) +)
    ((equal? oper '-) -)
    ((equal? oper '*) *)
    ((equal? oper '/) /)
    (else (error "no such operator as" oper))))

(parse '(4 + 3 * 7 - 5 / (3 + 4) + 6))
=> '(+ (- (+ (4) (* (3) (7))) (/ (5) (+ (3) (4)))) (6))

(compute (parse '(4 + 3 * 7 - 5 / (3 + 4) + 6)))
=> 30 2/7
Run Code Online (Sandbox Code Playgroud)