[8/8]
CLOSED: [2020-03-29 So 20:00]
CLOSED: [2020-03-29 So 20:01]
[8/8]
CLOSED: [2020-03-29 So 20:49]
define-syntax -> define-macro
mutate -> mutate!
pair -> cons
first -> car
rest -> cdr
generate-docs -> generate-docs-file
break -> show-environment
mytry -> attempt
CLOSED: [2020-03-29 So 21:00]
CLOSED: [2020-03-29 So 21:27]
CLOSED: [2020-03-29 So 21:27]
CLOSED: [2020-03-31 Di 11:36]
(define-syntax-shorthand [ vector ] ) (define-syntax-shorthand { hash-map } )
???
(let fac ([n 10]) (if (zero? n) 1 (* n (fac (sub1 n))))) 3628800
(eval `(+ . ,(list 1 2 3))) ;; should output 6 ;; throws error instead
(begin (define a (list 1 2 3)) (eval `(+ . ,a))) ;; should output 6 ;; outputs 0
define((test val),"") { fetch(val) ; printf("addr of arg: %lld\n", (unsigned long long)&val); return Memory::nil; };
then:
(define a "a") (test a) ;; will output an adress (if 1 (test a) 2) ;; will output a different adress
(define (range (:from 0) to) ...)
should error since we can't have positional args after keywords. right now, 'to' is silently ignored..