]> git.jsancho.org Git - guile-click.git/blobdiff - click.scm
Nested commands help message
[guile-click.git] / click.scm
index c3769a448956d0ad78a2a52ba6b195e573da758a..e8f8c09833acf6bb8abc67a22beb6d7141bd1731 100644 (file)
--- a/click.scm
+++ b/click.scm
 
 (define-module (click)
   #:use-module (ice-9 getopt-long)
+  #:use-module (srfi srfi-9)
+  #:use-module (srfi srfi-9 gnu)
+  #:use-module (click command)
   #:use-module (click constant)
-  #:use-module (click display)
+  #:use-module (click help)
   #:use-module (click util)
-  #:export (command))
+  #:use-module (click value)
+  #:export (command
+            group))
 
-(define (get-options-value options option-spec)
-  (cond ((null? option-spec)
-         '())
-        (else
-         (let ((option (caar option-spec)))
-           (cons (cons option (option-ref options option #f))
-                 (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)
-            (display-help procedure click-option-spec)
-            (apply procedure (map cdr (get-options-value options option-spec))))))))
+(define* (command #:key (name #f) (option-spec '()) (help "") (procedure #f))
+  "Define a new command for the procedure"
+  (group #:name name
+         #:option-spec option-spec
+         #:help help
+         #:procedure procedure))
+
+
+(define* (group #:key (name #f) (option-spec '()) (help "") (procedure #f) (commands '()))
+  "Define a new group with a list of commands associated"
+  (let* ((click-option-spec (append option-spec (list HELP_OPTION)))
+         (new-command (make-command name click-option-spec help procedure commands)))
+    (let ((click-manager
+           (lambda (args)
+             (let ((values
+                    (getopt-long args (getopt-long-option-spec click-option-spec))))
+               (if (option-ref values 'help #f)
+                   (let ((program-name (car args)))
+                     (display-help program-name new-command))
+                   (apply procedure (map cdr (get-values option-spec values))))))))
+      (set-command-click-manager! new-command click-manager)
+      new-command)))