unofficial mirror of guix-devel@gnu.org 
 help / color / mirror / code / Atom feed
blob 3b141a622dac57c9f5ee0b4725347666c64554d8 2506 bytes (raw)
name: guix/scripts/git.scm 	 # note: path name is non-authoritative(*)

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
 
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2020 Ludovic Courtès <ludo@gnu.org>
;;;
;;; 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/>.

(define-module (guix scripts git)
  #:use-module (ice-9 match)
  #:use-module (ice-9 format)
  #:use-module (guix ui)
  #:use-module (guix scripts)
  #:use-module (srfi srfi-1)
  #:export (guix-git))

(define %sub-commands
  `(("authenticate" . "verify commit signatures and authorizations")
    ("log". "show Git commit history")))

(define (show-help)
  (display (G_ "Usage: guix git COMMAND ARGS...
Operate on Git repositories.\n"))
  (newline)
  (display (G_ "The valid values for ACTION are:\n"))
  (newline)
  (for-each (match-lambda
              ((name . help)
               (format #t "~13a ~a\n" name help)))
            %sub-commands)
  (newline)
  (display (G_ "
  -h, --help             display this help and exit"))
  (display (G_ "
  -V, --version          display version information and exit"))
  (newline)
  (show-bug-report-information))

(define (resolve-sub-command name)
  (let ((module (resolve-interface
                 `(guix scripts git ,(string->symbol name))))
        (proc (string->symbol (string-append "guix-git-" name))))
    (module-ref module proc)))

(define-command (guix-git . args)
  (category plumbing)
  (synopsis "operate on Git repositories")

  (with-error-handling
    (match args
      (()
       (format (current-error-port)
               (G_ "guix git: missing sub-command~%")))
      ((or ("-h") ("--help"))
       (show-help)
       (exit 0))
      ((or ("-V") ("--version"))
       (show-version-and-exit "guix git"))
      ((sub-command args ...)
       (if (find (lambda (s) (string=? (first s) sub-command)) %sub-commands)
           (apply (resolve-sub-command sub-command) args)
           (leave (G_ "~a: invalid sub-command~%") sub-command))))))

debug log:

solving 3b141a622d ...
found 3b141a622d in https://yhetil.org/guix-devel/86im7ghd9c.fsf@gmail.com/
found 8fcd0ccca8 in https://git.savannah.gnu.org/cgit/guix.git
preparing index
index prepared:
100644 8fcd0ccca8017747e4f4a7f7f2610a0803944f91	guix/scripts/git.scm

applying [1/1] https://yhetil.org/guix-devel/86im7ghd9c.fsf@gmail.com/
diff --git a/guix/scripts/git.scm b/guix/scripts/git.scm
index 8fcd0ccca8..3b141a622d 100644

Checking patch guix/scripts/git.scm...
Applied patch guix/scripts/git.scm cleanly.

index at:
100644 3b141a622dac57c9f5ee0b4725347666c64554d8	guix/scripts/git.scm

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).