X-Git-Url: https://git.jsancho.org/?p=guile-click.git;a=blobdiff_plain;f=click.scm;fp=click.scm;h=aa804306de2fd2ec6d2ebd2a5864e28ef83fd78f;hp=afeb2f914fa1145ad0573108a18f37f9ae84b0f8;hb=432c741eb5dac653c1a65fae2b8f15c4b444897f;hpb=a2c12dede99c0d296194699e025a2e541c8a98a0 diff --git a/click.scm b/click.scm index afeb2f9..aa80430 100644 --- a/click.scm +++ b/click.scm @@ -24,22 +24,13 @@ #:use-module (click util) #:export (command)) -(define (get-options-value options option-spec) - (cond ((null? option-spec) - '()) - (else - (let* ((option (car option-spec)) - (option-name (car option)) - (default (option-default-value option))) - (cons (cons option-name (option-ref options option-name default)) - (get-options-value options (cdr option-spec))))))) (define (command option-spec procedure) (lambda (args) (with-fluids ((%program-name (car args))) (let* ((click-option-spec (append option-spec (list HELP_OPTION))) - (options (getopt-long args - (getopt-long-option-spec click-option-spec)))) - (if (option-ref options 'help #f) + (values (getopt-long args + (getopt-long-option-spec click-option-spec)))) + (if (option-ref values 'help #f) (display-help procedure click-option-spec) - (apply procedure (map cdr (get-options-value options option-spec)))))))) + (apply procedure (map cdr (get-values option-spec values))))))))