Split out utils so that we don't need SRFI.
This commit is contained in:
parent
98a772cee9
commit
5b32f3a30a
3 changed files with 66 additions and 18 deletions
12
Makefile
12
Makefile
|
@ -25,7 +25,7 @@
|
|||
|
||||
brmsaptool: brmsaptool.o testing.o listing.o month.o period.o ansi.o \
|
||||
member-file.o dictionary.o command-line.o \
|
||||
members-base.o
|
||||
members-base.o utils.o
|
||||
csc -o brmsaptool $^
|
||||
|
||||
.PHONY: clean
|
||||
|
@ -47,7 +47,8 @@ clean:
|
|||
brmsaptool.o: brmsaptool.scm testing.import.scm listing.import.scm \
|
||||
dictionary.import.scm month.import.scm period.import.scm \
|
||||
ansi.import.scm member-file.import.scm \
|
||||
command-line.import.scm members-base.import.scm
|
||||
command-line.import.scm members-base.import.scm \
|
||||
utils.import.scm
|
||||
|
||||
TESTING-SOURCES=testing.scm
|
||||
|
||||
|
@ -74,7 +75,7 @@ PERIOD-SOURCES=period.scm testing.import.scm month.import.scm
|
|||
period.o: $(PERIOD-SOURCES)
|
||||
period.import.scm: $(PERIOD-SOURCES)
|
||||
|
||||
ANSI-SOURCES=ansi.scm testing.import.scm
|
||||
ANSI-SOURCES=ansi.scm testing.import.scm utils.import.scm
|
||||
|
||||
ansi.o: $(ANSI-SOURCES)
|
||||
ansi.import.scm: $(ANSI-SOURCES)
|
||||
|
@ -95,3 +96,8 @@ MEMBERS-BASE-SOURCES=members-base.scm testing.import.scm
|
|||
|
||||
members-base.o: $(MEMBERS-BASE-SOURCES)
|
||||
members-base.import.scm: $(MEMBERS-BASE-SOURCES)
|
||||
|
||||
UTILS-SOURCES=utils.scm testing.import.scm
|
||||
|
||||
utils.o: $(UTILS-SOURCES)
|
||||
utils.import.scm: $(UTILS-SOURCES)
|
||||
|
|
17
ansi.scm
17
ansi.scm
|
@ -35,7 +35,8 @@
|
|||
(import scheme
|
||||
(chicken base)
|
||||
(chicken string)
|
||||
testing)
|
||||
testing
|
||||
utils)
|
||||
|
||||
;; Only basic ANSI colors and bold attribute support.
|
||||
(define colors
|
||||
|
@ -50,18 +51,6 @@
|
|||
(#:default . 0)
|
||||
(#:bold . 1)))
|
||||
|
||||
;; Returns a list with elements matching pred? predicate.
|
||||
(define (filter pred? lst)
|
||||
(let loop ((lst lst)
|
||||
(res '()))
|
||||
(if (null? lst)
|
||||
(reverse res)
|
||||
(if (pred? (car lst))
|
||||
(loop (cdr lst)
|
||||
(cons (car lst) res))
|
||||
(loop (cdr lst)
|
||||
res)))))
|
||||
|
||||
;; Returns ANSI sequence changing color and/or bold attribute.
|
||||
(define (ansi . args)
|
||||
(let ((argsl
|
||||
|
@ -81,8 +70,6 @@
|
|||
(define (ansi-tests!)
|
||||
(run-tests
|
||||
ansi
|
||||
(test-equal? filter (filter odd? '(1 2 3 4)) '(1 3))
|
||||
(test-equal? filter (filter odd? '(2 4)) '())
|
||||
(test-equal? ansi (ansi #:red) "\x1b[31m")
|
||||
(test-equal? ansi (ansi #:nonsense) "")
|
||||
(test-equal? ansi (ansi #:default) "\x1b[0m")
|
||||
|
|
55
utils.scm
Normal file
55
utils.scm
Normal file
|
@ -0,0 +1,55 @@
|
|||
;;
|
||||
;; utils.scm
|
||||
;;
|
||||
;; Various utilities so that no external libraries are needed.
|
||||
;;
|
||||
;; ISC License
|
||||
;;
|
||||
;; Copyright 2023 Brmlab, z.s.
|
||||
;; Dominik Pantůček <dominik.pantucek@trustica.cz>
|
||||
;;
|
||||
;; Permission to use, copy, modify, and/or distribute this software
|
||||
;; for any purpose with or without fee is hereby granted, provided
|
||||
;; that the above copyright notice and this permission notice appear
|
||||
;; in all copies.
|
||||
;;
|
||||
;; THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
|
||||
;; WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
|
||||
;; WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
|
||||
;; AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR
|
||||
;; CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
|
||||
;; OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
||||
;; NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||
;; CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
;;
|
||||
|
||||
(declare (unit utils))
|
||||
|
||||
(module
|
||||
utils
|
||||
(
|
||||
filter
|
||||
utils-tests!
|
||||
)
|
||||
|
||||
;; Returns a list with elements matching pred? predicate.
|
||||
(define (filter pred? lst)
|
||||
(let loop ((lst lst)
|
||||
(res '()))
|
||||
(if (null? lst)
|
||||
(reverse res)
|
||||
(if (pred? (car lst))
|
||||
(loop (cdr lst)
|
||||
(cons (car lst) res))
|
||||
(loop (cdr lst)
|
||||
res)))))
|
||||
|
||||
;; Performs utils module self-tests.
|
||||
(define (utils-tests!)
|
||||
(run-tests
|
||||
utils
|
||||
(test-equal? filter (filter odd? '(1 2 3 4)) '(1 3))
|
||||
(test-equal? filter (filter odd? '(2 4)) '())
|
||||
))
|
||||
|
||||
)
|
Loading…
Add table
Add a link
Reference in a new issue