guix lint: make sure synopses do not start with the package name.

* guix/scripts/lint.scm (check-start-with-package-name): New method.
* tests/lint.scm ("synopsis: start with package name"): New test.
This commit is contained in:
Cyril Roelandt 2014-09-27 23:24:12 +02:00
parent a00ffdaa17
commit 3c762a13bf
2 changed files with 19 additions and 0 deletions

View file

@ -167,12 +167,21 @@ (define (check-synopsis-start-upper-case synopsis)
"synopsis should start with an upper-case letter"
'synopsis)))
(define (check-start-with-package-name synopsis)
(let ((idx (string-contains-ci synopsis (package-name package))))
(when (and idx
(= idx 0))
(emit-warning package
"synopsis should not start with the package name")
'synopsis)))
(let ((synopsis (package-synopsis package)))
(if (string? synopsis)
(begin
(check-synopsis-start-upper-case synopsis)
(check-final-period synopsis)
(check-start-article synopsis)
(check-start-with-package-name synopsis)
(check-synopsis-length synopsis)))))
(define (check-patches package)

View file

@ -124,6 +124,16 @@ (define (call-with-warnings thunk)
(check-synopsis-style pkg))))
"synopsis should be less than 80 characters long")))
(test-assert "synopsis: start with package name"
(->bool
(string-contains (call-with-warnings
(lambda ()
(let ((pkg (dummy-package "x"
(name "foo")
(synopsis "foo, a nice package"))))
(check-synopsis-style pkg))))
"synopsis should not start with the package name")))
(test-assert "inputs: pkg-config is probably a native input"
(->bool
(string-contains