;; ;; chicken-sdl2: CHICKEN Scheme bindings to Simple DirectMedia Layer 2 ;; ;; Copyright © 2013–2021 John Croisant. ;; All rights reserved. ;; ;; Redistribution and use in source and binary forms, with or without ;; modification, are permitted provided that the following conditions ;; are met: ;; ;; - Redistributions of source code must retain the above copyright ;; notice, this list of conditions and the following disclaimer. ;; ;; - Redistributions in binary form must reproduce the above copyright ;; notice, this list of conditions and the following disclaimer in ;; the documentation and/or other materials provided with the ;; distribution. ;; ;; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ;; "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT ;; LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS ;; FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ;; COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, ;; INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES ;; (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR ;; SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ;; HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, ;; STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ;; ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED ;; OF THE POSSIBILITY OF SUCH DAMAGE. ;;; Like foreign-lambda*, except the function body string is ;;; constructed dynamically (at macro expansion time) using sprintf. ;;; ;;; Usage: ;;; ;;; (foreign-lambda*-with-dynamic-body ;;; RETURN-TYPE ;;; (ARG-TYPE ...) ;;; (BODY-FORMATSTRING FORMAT-ARG ...)) ;;; ;;; This macro is used within other macros to generate function bodies ;;; based on a template. For example, a type or field name within the ;;; function body can be filled in based on the arguments given to the ;;; high-level macro. ;;; ;;; Because the body string is constructed at macro expansion time, ;;; each FORMAT-ARG must be a literal value like a symbol, string, or ;;; number. ;;; (define-syntax foreign-lambda*-with-dynamic-body (ir-macro-transformer (lambda (form inject compare?) (let ((return-type (list-ref form 1)) (args (list-ref form 2)) (body (list-ref form 3))) `(foreign-lambda* ,return-type ,args ,(apply sprintf (map strip-syntax body)))))))