25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 
 
 
 
 

72 satır
4.4 KiB

  1. (define (nil? x) "Checks if the argument is nil." (= x nil))
  2. (define (number? x) "Checks if the argument is a number." (= (type x) :number))
  3. (define (symbol? x) "Checks if the argument is a symbol." (= (type x) :symbol))
  4. (define (keyword? x) "Checks if the argument is a keyword." (= (type x) :keyword))
  5. (define (pair? x) "Checks if the argument is a pair." (= (type x) :pair))
  6. (define (string? x) "Checks if the argument is a string." (= (type x) :string))
  7. (define (lambda? x) "Checks if the argument is a function." (= (type x) :dynamic-function))
  8. (define (special-lambda? x) "Checks if the argument is a macro." (= (type x) :dynamic-macro))
  9. (define (built-n-function? x) "Checks if the argument is a built-in function." (= (type x) :built-in-function))
  10. (define (apply fun seq) "Applies the funciton to the sequence, as in calls the function with
  11. ithe sequence as arguemens." (eval (pair fun seq)))
  12. (define (end seq) "Returns the last pair in the sqeuence." (if (or (nil? seq) (not (pair? (rest seq)))) seq (end (rest seq))))
  13. (define (last seq) "Returns the (first) of the last (pair) of the given sequence." (first (end seq)))
  14. (define (extend seq elem) "Extends a list with the given element, by putting it in
  15. the (rest) of the last element of the sequence." (if (pair? seq) (prog (define e (end seq)) (mutate e (pair (first e) elem)) seq) elem))
  16. (define (append seq elem) "Appends an element to a sequence, by extendeing the list
  17. with (pair elem nil)." (extend seq (pair elem nil)))
  18. (define (length seq) "Returns the length of the given sequence." (if (nil? seq) 0.000000 (+ 1.000000 (length (rest seq)))))
  19. (define (increment val) "Adds one to the argument." (+ val 1.000000))
  20. (define (decrement val) "Subtracts one from the argument." (- val 1.000000))
  21. (define (range :keys from :defaults-to 0.000000 to) "Returns a sequence of numbers starting with the number defined
  22. by the key 'from' and ends with the number defined in 'to'." (if (< from to) ([C-function] (pair from (range :from (+ 1.000000 from) :to to))) nil))
  23. (define (range-while :keys from :defaults-to 0.000000 to) "Returns a sequence of numbers starting with the number defined
  24. by the key 'from' and ends with the number defined in 'to'." (define result (list (copy from))) (define head result) (mutate from (increment from)) (while (< from to) (prog (mutate head (pair (first head) (pair (copy from) nil))) (define head (rest head)) (mutate from (increment from)))) result)
  25. (define (map fun seq) "Takes a function and a sequence as arguments and returns a new
  26. sequence which contains the results of using the first sequences
  27. elemens as argument to that function." (if (nil? seq) seq (pair (fun (first seq)) (map fun (rest seq)))))
  28. (define (reduce fun seq) "Takes a function and a sequence as arguments and applies the
  29. function to the argument sequence. This only works correctly if
  30. the given function accepts a variable amount of parameters. If
  31. your funciton is limited to two arguments, use `reduce-binary'
  32. instead." (apply fun seq))
  33. (define (reduce-binary fun seq) "Takes a function and a sequence as arguments and applies the
  34. function to the argument sequence. reduce-binary applies the
  35. arguments `pair-wise' which means it works with binary functions
  36. as compared to `reduce'." (if (nil? (rest seq)) (first seq) (fun (first seq) (reduce-binary fun (rest seq)))))
  37. (define (filter fun seq) "Takes a function and a sequence as arguments and applies the
  38. function to every value in the sequence. If the result of that
  39. funciton application returns a truthy value, the original value is
  40. added to a list, which in the end is returned." (if seq ([C-function] (if (fun (first seq)) (pair (first seq) (filter fun (rest seq))) (filter fun (rest seq)))) nil))
  41. (define (zip l1 l2) (if (and (nil? l1) (nil? l2)) nil (pair (list (first l1) (first l2)) (zip (rest l1) (rest l2)))))
  42. (define (printf :keys sep :defaults-to " " end :defaults-to "
  43. " :rest args) "A wrapper for the built-in (print) that accepts a variable number
  44. of arguments and also provides keywords for specifying the printed
  45. separators between the arguments and what should be printed after the
  46. las argument." (define printf-quoted (special-lambda (:keys @sep @end :rest @args) (if (nil? @args) (prog (print (eval @end)) nil) (prog (print (first @args)) (if (nil? (rest @args)) nil ([C-function] (print (eval @sep)))) (eval (pair printf-quoted (extend (list :@sep (eval @sep) :@end (eval @end)) (rest @args)))))))) (eval (pair printf-quoted (extend (list :@sep (eval sep) :@end (eval end)) args))))