mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-23 15:07:03 +01:00
tests: Move argument parser.
* tests/gpgme/gpgme-defs.scm (flag): Move... * tests/gpgscm/tests.scm: ... over here. Signed-off-by: Justus Winter <justus@g10code.com>
This commit is contained in:
parent
e2ed3c1597
commit
a30c0a6972
@ -83,31 +83,6 @@
|
|||||||
(start-agent))
|
(start-agent))
|
||||||
(apply create-gpgme-gpghome path)))
|
(apply create-gpgme-gpghome path)))
|
||||||
|
|
||||||
;; Command line flag handling. Returns the elements following KEY in
|
|
||||||
;; ARGUMENTS up to the next argument, or #f if KEY is not in
|
|
||||||
;; ARGUMENTS.
|
|
||||||
(define (flag key arguments)
|
|
||||||
(cond
|
|
||||||
((null? arguments)
|
|
||||||
#f)
|
|
||||||
((string=? key (car arguments))
|
|
||||||
(let loop ((acc '())
|
|
||||||
(args (cdr arguments)))
|
|
||||||
(if (or (null? args) (string-prefix? (car args) "--"))
|
|
||||||
(reverse acc)
|
|
||||||
(loop (cons (car args) acc) (cdr args)))))
|
|
||||||
((string=? "--" (car arguments))
|
|
||||||
#f)
|
|
||||||
(else
|
|
||||||
(flag key (cdr arguments)))))
|
|
||||||
(assert (equal? (flag "--xxx" '("--yyy")) #f))
|
|
||||||
(assert (equal? (flag "--xxx" '("--xxx")) '()))
|
|
||||||
(assert (equal? (flag "--xxx" '("--xxx" "yyy")) '("yyy")))
|
|
||||||
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "zzz")) '("yyy" "zzz")))
|
|
||||||
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "zzz" "--")) '("yyy" "zzz")))
|
|
||||||
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "--" "zzz")) '("yyy")))
|
|
||||||
(assert (equal? (flag "--" '("--" "xxx" "yyy" "--" "zzz")) '("xxx" "yyy")))
|
|
||||||
|
|
||||||
(define (parse-makefile port key)
|
(define (parse-makefile port key)
|
||||||
(define (is-continuation? tokens)
|
(define (is-continuation? tokens)
|
||||||
(string=? (last tokens) "\\"))
|
(string=? (last tokens) "\\"))
|
||||||
|
@ -658,3 +658,28 @@
|
|||||||
(test' (test::set-directory wd)))
|
(test' (test::set-directory wd)))
|
||||||
(loop (pool::add (test'::run-sync '--unpack-tarball gpghome-tar))
|
(loop (pool::add (test'::run-sync '--unpack-tarball gpghome-tar))
|
||||||
(cdr tests')))))))
|
(cdr tests')))))))
|
||||||
|
|
||||||
|
;; Command line flag handling. Returns the elements following KEY in
|
||||||
|
;; ARGUMENTS up to the next argument, or #f if KEY is not in
|
||||||
|
;; ARGUMENTS.
|
||||||
|
(define (flag key arguments)
|
||||||
|
(cond
|
||||||
|
((null? arguments)
|
||||||
|
#f)
|
||||||
|
((string=? key (car arguments))
|
||||||
|
(let loop ((acc '())
|
||||||
|
(args (cdr arguments)))
|
||||||
|
(if (or (null? args) (string-prefix? (car args) "--"))
|
||||||
|
(reverse acc)
|
||||||
|
(loop (cons (car args) acc) (cdr args)))))
|
||||||
|
((string=? "--" (car arguments))
|
||||||
|
#f)
|
||||||
|
(else
|
||||||
|
(flag key (cdr arguments)))))
|
||||||
|
(assert (equal? (flag "--xxx" '("--yyy")) #f))
|
||||||
|
(assert (equal? (flag "--xxx" '("--xxx")) '()))
|
||||||
|
(assert (equal? (flag "--xxx" '("--xxx" "yyy")) '("yyy")))
|
||||||
|
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "zzz")) '("yyy" "zzz")))
|
||||||
|
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "zzz" "--")) '("yyy" "zzz")))
|
||||||
|
(assert (equal? (flag "--xxx" '("--xxx" "yyy" "--" "zzz")) '("yyy")))
|
||||||
|
(assert (equal? (flag "--" '("--" "xxx" "yyy" "--" "zzz")) '("xxx" "yyy")))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user