Change ontions definition. Able to define only long or short option

This commit is contained in:
Nikolay Puzanov 2022-11-30 14:16:54 +03:00
parent 1156b31463
commit 877efd7f95

View File

@ -11,42 +11,41 @@
;;; TODO: Write docs
;;;
(define (option-get opts name)
(let ((opt (assq name opts)))
(let ((opt (assoc name opts)))
(if opt
(cdr opt)
#f)))
(define (option-set opts name value)
(if (assq name opts)
(if (assoc name opts)
(map (lambda (opt)
(if (eq? (car opt) name)
(if (equal? (car opt) name)
(cons name value)
opt))
opts)
(alist-cons name value opts)))
(define (option-add opts name value)
(if (assq name opts)
(if (assoc name opts)
(option-set opts name
(cons value
(option-get opts name)))
(alist-cons name `(,value) opts)))
;;; opt-spec - '(#\o "option" [none | required | optional | multiple])
;;; opt-spec - '(("option" #\o) [none | required | optional | multiple])
(define (parse-opts args . opt-spec)
(args-fold
;; args
args
;; options
(map (lambda (spec)
(let ((char (list-ref spec 0))
(name (list-ref spec 1))
(type (list-ref spec 2)))
(let ((name-str (symbol->string name))
(let* ((names (list-ref spec 0))
(type (list-ref spec 1))
(name (car names))
(req? (eq? type 'required))
(opt? (eq? type 'optional))
(many? (eq? type 'multiple)))
(option (list char name-str) (or many? req?) opt?
(option names (or many? req?) opt?
(if many?
(lambda (opt nm arg opts rest error)
(values (if arg
@ -55,7 +54,7 @@
rest
error))
(lambda (opt nm arg opts rest error)
(values (option-set opts name (if arg arg #t)) rest error)))))))
(values (option-set opts name (if arg arg #t)) rest error))))))
opt-spec)
;; unrecognized options
(lambda (opt name arg opts rest error)