;;; GNU Guix --- Functional package management for GNU ;;; Copyright © 2015 Alex Kost ;;; ;;; 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 . ;;; ;;; 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 installer proceeds after hitting "Edit"....Fixes <https://bugs.gnu.org/39199>. Reported by Jonathan Brielmaier <jonathan.brielmaier@web.de>. * gnu/installer/newt/page.scm (run-file-textbox-page): Move 'loop' to the beginning of the body. Do not call 'loop' from the 'dynamic-wind' exit handler as we would not return the value of the second call to 'loop'. Ludovic Courtès 2020-01-12installer: Add an "Edit" button on the final page....Fixes <https://bugs.gnu.org/36885>. Reported by <lukasbf@tutanota.com>. * gnu/installer/newt/page.scm (edit-file): New procedure. (run-file-textbox-page): Add #:edit-button? and #:editor-locale parameters. Remove 'file-text' and add 'edit-button', and add it to the horizontal stacked grid when EXIT-BUTTON? is true. Wrap body in 'loop'. Handle case where ARGUMENT is EDIT-BUTTON by calling 'loop'. * gnu/installer/newt/final.scm (run-config-display-page): Add #:locale parameter. Pass #:edit-button? and #:editor-locale to 'run-file-textbox-page'. (run-final-page): Pass LOCALE to 'run-config-display-page'. Ludovic Courtès 2020-01-05installer: Add JFS support....* gnu/installer/newt/partition.scm (run-fs-type-page): Add ‘jfs’ to the list box. * gnu/installer/parted.scm (user-fs-type-name, user-fs-type->mount-type) (partition-filesystem-user-type): Add ‘jfs’ mapping (create-jfs-file-system): New procedure. (format-user-partitions): Use it. * gnu/installer.scm (set-installer-path): Add jfsutils. Tobias Geerinckx-Rice 2020-01-05installer: Fix typo....* gnu/installer/parted.scm (create-btrfs-file-system): Fix typo in docstring. Tobias Geerinckx-Rice 2019-12-29installer: Pass '--fallback' to 'guix system init'....Fixes <https://bugs.gnu.org/38608>. Reported by Nathan Dehnel <ncdehnel@gmail.com>. * gnu/installer/final.scm (install-system): Pass '--fallback' to 'guix system init'. Ludovic Courtès