diff options
author | Alex Kost <alezost@gmail.com> | 2015-07-04 12:27:26 +0300 |
---|---|---|
committer | Alex Kost <alezost@gmail.com> | 2015-07-06 19:00:19 +0300 |
commit | a8ac45b19ebb3006ced49b46342e01632829cef2 (patch) | |
tree | 15d82d68340fa0aba233ea75c6c37f0dd240786e /build-aux | |
parent | f2820e076362a418bfdb486fb4a39e19d517a6d6 (diff) | |
download | guix-a8ac45b19ebb3006ced49b46342e01632829cef2.tar.gz |
build: Generate 'AUTHORS'.
* build-aux/generate-authors.scm: New file. * Makefile.am (gen-AUTHORS): New target. (dist-hook, .PHONY): Add it.
Diffstat (limited to 'build-aux')
-rw-r--r-- | build-aux/generate-authors.scm | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/build-aux/generate-authors.scm b/build-aux/generate-authors.scm new file mode 100644 index 0000000000..1dc882ff8a --- /dev/null +++ b/build-aux/generate-authors.scm @@ -0,0 +1,120 @@ +;;; GNU Guix --- Functional package management for GNU +;;; Copyright © 2015 Alex Kost <alezost@gmail.com> +;;; +;;; This file is part of GNU Guix. +;;; +;;; GNU Guix is free software; you can redistribute it and/or modify it +;;; under the terms of the GNU General Public License as published by +;;; the Free Software Foundation; either version 3 of the License, or (at +;;; your option) any later version. +;;; +;;; GNU Guix is distributed in the hope that it will be useful, but +;;; WITHOUT ANY WARRANTY; without even the implied warranty of +;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +;;; GNU General Public License for more details. +;;; +;;; You should have received a copy of the GNU General Public License +;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>. + +;;; +;;; Generate AUTHORS file for directory with the Guix git repository. +;;; + +(use-modules + (ice-9 popen) + (ice-9 rdelim) + (ice-9 match) + (srfi srfi-1) + (guix config) + (guix utils) + (guix build utils)) + +(define %guix-dir + (make-parameter #f)) + +(define-syntax-rule (append-maybe init-lst (test add-lst) ...) + (let* ((lst init-lst) + (lst (if test + (append lst add-lst) + lst)) + ...) + lst)) + +(define (command-output cmd . args) + "Execute CMD with ARGS and return its output without trailing newspace." + (let* ((port (apply open-pipe* OPEN_READ cmd args)) + (output (read-string port))) + (close-port port) + (string-trim-right output #\newline))) + +(define (git-output . args) + "Execute git command with ARGS and return its output without trailing +newspace." + (with-directory-excursion (%guix-dir) + (apply command-output "git" args))) + +(define* (contributors-string #:optional (range "HEAD")) + "Return a string with names of people contributed to commit RANGE." + (git-output "shortlog" "--numbered" "--summary" "--email" range)) + +(define* (tags #:key pattern sort) + "Return a list of the git repository tags. +PATTERN is passed to '--list' and SORT is passed to '--sort' options of +'git tag' command." + (let* ((args (append-maybe + '("tag") + (pattern (list "--list" pattern)) + (sort (list "--sort" sort)))) + (output (apply git-output args))) + (string-split output #\newline))) + +(define (version-tags) + "Return only version tags (v0.8, etc.) sorted from the biggest version +to the smallest one." + (tags #:pattern "v*" + #:sort "-version:refname")) + +(define (generate-authors-file file) + "Generate authors FILE." + (define previous-release-tag + (find (lambda (tag) + (version>? %guix-version + (substring tag 1))) ; remove leading 'v' + (version-tags))) + + (define release-range + (string-append previous-release-tag "..HEAD")) + + (with-output-to-file file + (lambda () + (display "\ +GNU Guix consists of Scheme code that implements the deployment model +of the Nix package management tool. In fact, it currently talks to a +build daemon whose code comes from Nix (see the manual for details.) + +Nix was initially written by Eelco Dolstra; other people have been +contributing to it. See `nix/AUTHORS' for details.\n\n") + (format #t "Contributors to GNU Guix ~a:\n\n" + %guix-version) + (display (contributors-string release-range)) + (newline) (newline) + (display "Overall contributors:\n\n") + (display (contributors-string)) + (newline)))) + +(define (show-help) + (match (command-line) + ((me _ ...) + (format #t "Usage: guile ~a DIRECTORY AUTHORS +Generate AUTHORS file for DIRECTORY with the Guix git repository.\n" + me)))) + +(match (command-line) + ((_ guix-dir authors-file) + (parameterize ((%guix-dir guix-dir)) + (generate-authors-file authors-file))) + (_ + (show-help) + (exit 1))) + +;;; generate-authors.scm ends here |