summaryrefslogtreecommitdiff
path: root/module/scripts
diff options
context:
space:
mode:
authorAndy Wingo <wingo@pobox.com>2020-05-08 15:58:23 +0200
committerAndy Wingo <wingo@pobox.com>2020-05-08 16:03:32 +0200
commit220934c49d2629ebf826cc377541694334f44e7e (patch)
treeaf0e30ae74e913a0386709e6ba23cd5cd12f2c1c /module/scripts
parent116f94d661b61e297b733363b49042c6c14169b4 (diff)
downloadguile-220934c49d2629ebf826cc377541694334f44e7e.tar.gz
Wire up simplified warning levels in "guild compile"
* am/guilec (GUILE_WARNINGS): * am/bootstrap.am (GUILE_WARNINGS): Explictly default to -W1. * bootstrap/Makefile.am (GUILE_WARNINGS): Set to -Wnone, as the meaning of "no -W flags" has changed to be effectively -W1. * module/scripts/compile.scm (%options): Adapt to parse -Wnone, -W2, and so on. (parse-args): Default to (default-warning-level). (show-warning-help): Add more warning help. (compile): Pass #:warning-level.
Diffstat (limited to 'module/scripts')
-rw-r--r--module/scripts/compile.scm42
1 files changed, 31 insertions, 11 deletions
diff --git a/module/scripts/compile.scm b/module/scripts/compile.scm
index 8dcb09bcd..ea6377b48 100644
--- a/module/scripts/compile.scm
+++ b/module/scripts/compile.scm
@@ -30,7 +30,9 @@
(define-module (scripts compile)
#:use-module ((system base language) #:select (lookup-language))
- #:use-module ((system base compile) #:select (compile-file))
+ #:use-module ((system base compile) #:select (compile-file
+ default-warning-level
+ default-optimization-level))
#:use-module (system base target)
#:use-module (system base message)
#:use-module (system base optimize)
@@ -81,14 +83,27 @@
(option '(#\W "warn") #t #f
(lambda (opt name arg result)
- (if (string=? arg "help")
- (begin
- (show-warning-help)
- (exit 0))
- (let ((warnings (assoc-ref result 'warnings)))
- (alist-cons 'warnings
- (cons (string->symbol arg) warnings)
- (alist-delete 'warnings result))))))
+ (match arg
+ ("help"
+ (show-warning-help)
+ (exit 0))
+ ("all"
+ (alist-cons 'warning-level #t
+ (alist-delete 'warning-level result)))
+ ("none"
+ (alist-cons 'warning-level #f
+ (alist-delete 'warning-level result)))
+ ((? string->number)
+ (let ((n (string->number arg)))
+ (unless (and (exact-integer? n) (<= 0 n))
+ (fail "Bad warning level `~a'" n))
+ (alist-cons 'warning-level n
+ (alist-delete 'warning-level result))))
+ (_
+ (let ((warnings (assoc-ref result 'warnings)))
+ (alist-cons 'warnings
+ (cons (string->symbol arg) warnings)
+ (alist-delete 'warnings result)))))))
(option '(#\O "optimize") #t #f
(lambda (opt name arg result)
@@ -141,8 +156,9 @@ options."
result)))
;; default option values
- '((input-files)
+ `((input-files)
(load-path)
+ (warning-level . ,(default-warning-level))
(warnings unsupported-warning))))
(define (show-version)
@@ -159,7 +175,9 @@ There is NO WARRANTY, to the extent permitted by law.~%"))
(format #f "`~A'" (warning-type-name wt))
(warning-type-description wt)))
%warning-types)
- (format #t "~%"))
+ (format #t "~%")
+ (format #t "You may also specify warning levels as `-Wnone', `-W0`, `-W1',~%")
+ (format #t "`-W2', `-W3', or `-Wall`. The default is `-W1'.~%"))
(define (show-optimization-help)
(format #t "The available optimizations are:~%~%")
@@ -184,6 +202,7 @@ There is NO WARRANTY, to the extent permitted by law.~%"))
(define (compile . args)
(let* ((options (parse-args args))
(help? (assoc-ref options 'help?))
+ (warning-level (assoc-ref options 'warning-level))
(compile-opts `(#:warnings
,(assoc-ref options 'warnings)
,@(append-map
@@ -266,6 +285,7 @@ Report bugs to <~A>.~%"
#:output-file output-file
#:from from
#:to to
+ #:warning-level warning-level
#:opts compile-opts))))))
input-files)))