diff options
| author | 2025-10-28 20:13:18 -0400 | |
|---|---|---|
| committer | 2025-10-28 20:13:18 -0400 | |
| commit | 803494c6688f97c38d72ec58d3335228667c91bf (patch) | |
| tree | 6e073d9db3e99544c924b71a9fd91b5ff6b470de /mcgoron/guix/srfi-util.scm | |
| parent | portable r7rs srfi-1 (diff) | |
srfi-1, fixed, for r6rs and r7rs
Diffstat (limited to 'mcgoron/guix/srfi-util.scm')
| -rw-r--r-- | mcgoron/guix/srfi-util.scm | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/mcgoron/guix/srfi-util.scm b/mcgoron/guix/srfi-util.scm new file mode 100644 index 0000000..cc54fa3 --- /dev/null +++ b/mcgoron/guix/srfi-util.scm @@ -0,0 +1,58 @@ +#| Copyright (C) 2025 Peter McGoron + | + | This program is free software: you can redistribute it and/or modify it + | under the terms of the GNU General Public License as published by the + | Free Software Foundation, either version 3 of the License, or (at your + | option) any later version. + | + | This program is distributed in the hope that it will be useful, but + | WITHOUT ANY WARRANTY; without even the implied warranty of + | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + | General Public License for more details. + | + | You should have received a copy of the GNU General Public License along + | with this program. If not, see <https://www.gnu.org/licenses/>. + |# + +(define-module (mcgoron guix srfi-util) + #:use-module (rnrs)) + +(define-public (splice-files output version name exports imports . filenames) + (with-output-to-file output + (lambda () + (case version + ((6) + (display "(library ") + (write name) + (newline) + (write (cons 'export exports)) + (newline) + (write (cons 'import imports)) + (newline)) + ((7) + (display "(define-library ") + (write name) + (newline) + (write (cons 'import imports)) + (newline) + (write (cons 'export exports)) + (newline) + (display "(begin\n")) + (else (error "unknown version" version))) + (for-each (lambda (filename) + (cond + ((string? filename) + (do ((file (open-input-file filename)) + (s "" (get-line file))) + ((eof-object? s)) + (display s) (newline))) + ((pair? filename) + (write filename) + (newline)) + (else (error "invalid file" filename)))) + filenames) + (case version + ((6) (display ")\n")) + ((7) (display "))\n")) + (else (error "unknown version" version)))))) + |
