generating the tedious code
This commit is contained in:
parent
709ebce4fe
commit
ce56e96aeb
72
generate-c-star-d.rkt
Normal file
72
generate-c-star-d.rkt
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
#lang racket
|
||||||
|
|
||||||
|
(provide make-c*r names)
|
||||||
|
|
||||||
|
;; A little helper to generate the tedious code for the c*r functions.
|
||||||
|
|
||||||
|
(define (make-c*r (n 4))
|
||||||
|
(define template #<<EOF
|
||||||
|
installPrimitiveProcedure(
|
||||||
|
~s,
|
||||||
|
1,
|
||||||
|
function(M) {
|
||||||
|
var x = M.e[M.e.length-1];
|
||||||
|
if (isPair(x)&&~a) {
|
||||||
|
return x.~a;
|
||||||
|
} else {
|
||||||
|
raiseArgumentTypeError(M, ~s, ~s, 0, x);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
EOF
|
||||||
|
|
||||||
|
)
|
||||||
|
(for/list ([desc (combinations n)])
|
||||||
|
(format template
|
||||||
|
(string-append "c" desc "r")
|
||||||
|
(test desc)
|
||||||
|
(accessor desc)
|
||||||
|
(string-append "c" desc "r")
|
||||||
|
(string-append "c" desc "rable value"))))
|
||||||
|
|
||||||
|
|
||||||
|
(define (names (n 4))
|
||||||
|
(for/list ([desc (combinations n)])
|
||||||
|
(string->symbol (string-append "c" desc "r"))))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(define (combinations n)
|
||||||
|
(let loop ([n n])
|
||||||
|
(cond
|
||||||
|
[(= n 2)
|
||||||
|
(list "aa" "ad" "da" "dd")]
|
||||||
|
[else
|
||||||
|
(define sub-answers (loop (sub1 n)))
|
||||||
|
(append sub-answers
|
||||||
|
(map (lambda (x) (string-append x "a")) sub-answers)
|
||||||
|
(map (lambda (x) (string-append x "d")) sub-answers))])))
|
||||||
|
|
||||||
|
(define (accessor s)
|
||||||
|
(string-join
|
||||||
|
(reverse (for/list ([ch s])
|
||||||
|
(case ch
|
||||||
|
[(#\a) "first"]
|
||||||
|
[(#\d) "rest"])))
|
||||||
|
"."))
|
||||||
|
|
||||||
|
(define (test s)
|
||||||
|
(string-join (for/list ([i (in-range 1 (string-length s))])
|
||||||
|
(let ([s (substring s
|
||||||
|
(- (string-length s) i)
|
||||||
|
(string-length s))])
|
||||||
|
(format "isPair(x.~a)"
|
||||||
|
(string-join
|
||||||
|
(reverse (for/list ([ch s])
|
||||||
|
(case ch
|
||||||
|
[(#\a) "first"]
|
||||||
|
[(#\d) "rest"])))
|
||||||
|
"."))))
|
||||||
|
"&&"))
|
||||||
|
|
Loading…
Reference in New Issue
Block a user