mes: srfi-1: Make a proper module.

* mes/module/srfi/srfi-1.scm: Move this...
* mes/module/srfi/srfi-1-guile.scm: ...here.
* mes/module/srfi/srfi-1.mes: Update accordingly.
* AUTHORS: Likewise.
* mes/module/srfi/srfi-1.scm: New file.

Co-authored-by: Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
This commit is contained in:
Timothy Sample 2022-04-09 20:43:46 -06:00
parent aecc79eb66
commit ac68527ffe
4 changed files with 155 additions and 99 deletions

View File

@ -65,7 +65,7 @@ Pretty-print from Guile
mes/module/mes/pretty-print.scm mes/module/mes/pretty-print.scm
Srfi-1 bits from Guile Srfi-1 bits from Guile
mes/module/srfi/srfi-1.scm mes/module/srfi/srfi-1-guile.scm
Srfi-16 from Guile Srfi-16 from Guile
mes/module/srfi/srfi-16.scm mes/module/srfi/srfi-16.scm

View File

@ -0,0 +1,115 @@
;;; GNU Mes --- Maxwell Equations of Software
;;; Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
;;;
;;; This file is part of GNU Mes.
;;;
;;; GNU Mes 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.
;;;
;;; GNU Mes 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 GNU Mes. If not, see <http://www.gnu.org/licenses/>.
;;; From Guile-1.8
;;; Author: Martin Grabmueller <mgrabmue@cs.tu-berlin.de>
;;; Date: 2001-06-06
;;; Searching
;; Internal helper procedure. Map `f' over the single list `ls'.
;;
(define map1 map)
(define (any pred ls . lists)
(if (null? lists)
(any1 pred ls)
(let lp ((lists (cons ls lists)))
(cond ((any1 null? lists)
#f)
((any1 null? (map1 cdr lists))
(apply pred (map1 car lists)))
(else
(or (apply pred (map1 car lists)) (lp (map1 cdr lists))))))))
(define (any1 pred ls)
(let lp ((ls ls))
(cond ((null? ls)
#f)
((null? (cdr ls))
(pred (car ls)))
(else
(or (pred (car ls)) (lp (cdr ls)))))))
(define (every pred ls . lists)
(if (null? lists)
(every1 pred ls)
(let lp ((lists (cons ls lists)))
(cond ((any1 null? lists)
#t)
((any1 null? (map1 cdr lists))
(apply pred (map1 car lists)))
(else
(and (apply pred (map1 car lists)) (lp (map1 cdr lists))))))))
(define (every1 pred ls)
(let lp ((ls ls))
(cond ((null? ls)
#t)
((null? (cdr ls))
(pred (car ls)))
(else
(and (pred (car ls)) (lp (cdr ls)))))))
(define (list-index pred clist1 . rest)
(if (null? rest)
(let lp ((l clist1) (i 0))
(if (null? l)
#f
(if (pred (car l))
i
(lp (cdr l) (+ i 1)))))
(let lp ((lists (cons clist1 rest)) (i 0))
(cond ((any1 null? lists)
#f)
((apply pred (map car lists)) i)
(else
(lp (map cdr lists) (+ i 1)))))))
;;; Set operations on lists
(define (lset-union = . rest)
(let ((acc '()))
(for-each (lambda (lst)
(if (null? acc)
(set! acc lst)
(for-each (lambda (elem)
(if (not (member elem acc =))
(set! acc (cons elem acc))))
lst)))
rest)
acc))
(define (lset-intersection = list1 . rest)
(let lp ((l list1) (acc '()))
(if (null? l)
(reverse! acc)
(if (every (lambda (ll) (member (car l) ll =)) rest)
(lp (cdr l) (cons (car l) acc))
(lp (cdr l) acc)))))
(define (lset-difference = list1 . rest)
(if (null? rest)
list1
(let lp ((l list1) (acc '()))
(if (null? l)
(reverse! acc)
(if (any (lambda (ll) (member (car l) ll =)) rest)
(lp (cdr l) acc)
(lp (cdr l) (cons (car l) acc)))))))

View File

@ -111,13 +111,13 @@
(if (eq x (car lst)) lst (if (eq x (car lst)) lst
(srfi-1:member x (cdr lst) eq)))) (srfi-1:member x (cdr lst) eq))))
(define mes:member member) (define mes:member (@ (guile) member))
(define (member x lst . rest) (define (member x lst . rest)
(if (null? rest) (mes:member x lst) (if (null? rest) (mes:member x lst)
(srfi-1:member x lst (car rest)))) (srfi-1:member x lst (car rest))))
(define mes:iota iota) (define mes:iota (@ (guile) iota))
(define (srfi-1:iota n start step) (define (srfi-1:iota n start step)
(if (<= n 0) '() (if (<= n 0) '()
@ -141,7 +141,7 @@
(loop (cdr lst)) (loop (cdr lst))
(cons (car lst) (loop (cdr lst)))))))) (cons (car lst) (loop (cdr lst))))))))
(include-from-path "srfi/srfi-1.scm") (include-from-path "srfi/srfi-1-guile.scm")
(define (take-while pred lst) (define (take-while pred lst)
(if (or (null? lst) (not (pred (car lst)))) '() (if (or (null? lst) (not (pred (car lst)))) '()

View File

@ -1,5 +1,8 @@
;;; -*-scheme-*-
;;; GNU Mes --- Maxwell Equations of Software ;;; GNU Mes --- Maxwell Equations of Software
;;; Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. ;;; Copyright © 2021 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
;;; Copyright © 2022 Timothy Sample <samplet@ngyro.com>
;;; ;;;
;;; This file is part of GNU Mes. ;;; This file is part of GNU Mes.
;;; ;;;
@ -16,100 +19,38 @@
;;; You should have received a copy of the GNU General Public License ;;; You should have received a copy of the GNU General Public License
;;; along with GNU Mes. If not, see <http://www.gnu.org/licenses/>. ;;; along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
;;; From Guile-1.8 ;;; Commentary:
;;; Author: Martin Grabmueller <mgrabmue@cs.tu-berlin.de> ;;; SRFI 1: List Library. This module provides procedures for
;;; Date: 2001-06-06 ;;; constructing, searching, and manipulating lists.
;;; Searching ;;; Code:
;; Internal helper procedure. Map `f' over the single list `ls'. (define-module (srfi srfi-1)
;; #:re-export (every
(define map1 map) find
filter
(define (any pred ls . lists) append-map
(if (null? lists) filter-map
(any1 pred ls) fold
(let lp ((lists (cons ls lists))) fold-right
(cond ((any1 null? lists) unfold
#f) remove
((any1 null? (map1 cdr lists)) reverse!
(apply pred (map1 car lists))) mes:member
(else srfi-1:member
(or (apply pred (map1 car lists)) (lp (map1 cdr lists)))))))) member
mes:iota
(define (any1 pred ls) srfi-1:iota
(let lp ((ls ls)) iota
(cond ((null? ls) delete-duplicates
#f) any
((null? (cdr ls)) any1
(pred (car ls))) every
(else every1
(or (pred (car ls)) (lp (cdr ls))))))) list-index
lset-union
(define (every pred ls . lists) lset-intersection
(if (null? lists) lset-difference
(every1 pred ls) reverse!
(let lp ((lists (cons ls lists))) take-while))
(cond ((any1 null? lists)
#t)
((any1 null? (map1 cdr lists))
(apply pred (map1 car lists)))
(else
(and (apply pred (map1 car lists)) (lp (map1 cdr lists))))))))
(define (every1 pred ls)
(let lp ((ls ls))
(cond ((null? ls)
#t)
((null? (cdr ls))
(pred (car ls)))
(else
(and (pred (car ls)) (lp (cdr ls)))))))
(define (list-index pred clist1 . rest)
(if (null? rest)
(let lp ((l clist1) (i 0))
(if (null? l)
#f
(if (pred (car l))
i
(lp (cdr l) (+ i 1)))))
(let lp ((lists (cons clist1 rest)) (i 0))
(cond ((any1 null? lists)
#f)
((apply pred (map car lists)) i)
(else
(lp (map cdr lists) (+ i 1)))))))
;;; Set operations on lists
(define (lset-union = . rest)
(let ((acc '()))
(for-each (lambda (lst)
(if (null? acc)
(set! acc lst)
(for-each (lambda (elem)
(if (not (member elem acc =))
(set! acc (cons elem acc))))
lst)))
rest)
acc))
(define (lset-intersection = list1 . rest)
(let lp ((l list1) (acc '()))
(if (null? l)
(reverse! acc)
(if (every (lambda (ll) (member (car l) ll =)) rest)
(lp (cdr l) (cons (car l) acc))
(lp (cdr l) acc)))))
(define (lset-difference = list1 . rest)
(if (null? rest)
list1
(let lp ((l list1) (acc '()))
(if (null? l)
(reverse! acc)
(if (any (lambda (ll) (member (car l) ll =)) rest)
(lp (cdr l) acc)
(lp (cdr l) (cons (car l) acc)))))))