Artifact
e2e3d8d3eb7fffa53ee8b1173927eb4688c22951:
- File
c-eval.sls
— part of check-in
[cd7a31d87b]
at
2017-05-03 18:01:41
on branch trunk
— many fixes to usb.sls
(user:
aldo
size: 1749)
;;
;; Copyright 2016 Aldo Nicolas Bruno
;;
;; Licensed under the Apache License, Version 2.0 (the "License");
;; you may not use this file except in compliance with the License.
;; You may obtain a copy of the License at
;;
;; http://www.apache.org/licenses/LICENSE-2.0
;;
;; Unless required by applicable law or agreed to in writing, software
;; distributed under the License is distributed on an "AS IS" BASIS,
;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
;; See the License for the specific language governing permissions and
;; limitations under the License.
(library (c-eval)
(export c-eval c-eval-printf c-eval-includes)
(import (chezscheme)
(posix)
(only (data-structures) string-intersperse ->string))
(define c-eval-includes (make-parameter '("stdio.h")))
(define (c-eval-printf format . values)
(c-eval (string-append "printf (\"" format "\"," (string-intersperse (map ->string values) ",") ");")))
(define (c-eval expr)
(with-mktemp
"/tmp/c-eval-XXXXXX"
(lambda (file)
(apply
(lambda (in out pid)
(for-each (lambda (x)
(fprintf out "#include <~a>~%" x)) (c-eval-includes))
(fprintf out "int main() {~%")
(fprintf out "~a~%" expr)
(fprintf out "}~%")
(close-port out)
(display (cond [(get-string-all in ) => (lambda (x) (if (eof-object? x) "" x))]))
(unless (zero? (wait-for-pid pid))
(errorf 'c-repl "compilation failed"))
(apply (lambda (p-in p-out p-pid)
(get-string-all p-in))
(process (format "~a" file))))
(process (format #f "gcc -o ~a -x c -" file))))))
) ;;library c-eval
#|
(import (c-eval))
(c-eval-includes '("stdio.h" "stdint.h"))
(string->number (c-eval-printf "%d" "sizeof (uint32_t)"))
|#