mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-26 20:49:29 -05:00
pull: '--news' shows the list of channels added or removed.
* guix/scripts/pull.scm (display-channel, channel=?) (display-channel-news, display-news): New procedures. (process-query): Call 'display-news' instead of 'display-profile-news'.
This commit is contained in:
parent
acedaec798
commit
961b95c985
1 changed files with 57 additions and 4 deletions
|
@ -213,6 +213,62 @@ (define* (display-profile-news profile #:key concise?
|
|||
(G_ "New in this revision:\n")))))
|
||||
(_ #t)))
|
||||
|
||||
(define (display-channel channel)
|
||||
"Display information about CHANNEL."
|
||||
(format (current-error-port)
|
||||
;; TRANSLATORS: This describes a "channel"; the first placeholder is
|
||||
;; the channel name (e.g., "guix") and the second placeholder is its
|
||||
;; URL.
|
||||
(G_ " ~a at ~a~%")
|
||||
(channel-name channel)
|
||||
(channel-url channel)))
|
||||
|
||||
(define (channel=? channel1 channel2)
|
||||
"Return true if CHANNEL1 and CHANNEL2 are the same for all practical
|
||||
purposes."
|
||||
;; Assume that the URL matters less than the name.
|
||||
(eq? (channel-name channel1) (channel-name channel2)))
|
||||
|
||||
(define (display-channel-news profile)
|
||||
"Display news about the channels of PROFILE "
|
||||
(define previous
|
||||
(and=> (relative-generation profile -1)
|
||||
(cut generation-file-name profile <>)))
|
||||
|
||||
(when previous
|
||||
(let ((old-channels (profile-channels previous))
|
||||
(new-channels (profile-channels profile)))
|
||||
(and (pair? old-channels) (pair? new-channels)
|
||||
(begin
|
||||
(match (lset-difference channel=? new-channels old-channels)
|
||||
(()
|
||||
#t)
|
||||
(new
|
||||
(let ((count (length new)))
|
||||
(format (current-error-port)
|
||||
(N_ " ~*One new channel:~%"
|
||||
" ~a new channels:~%" count)
|
||||
count)
|
||||
(for-each display-channel new))))
|
||||
(match (lset-difference channel=? old-channels new-channels)
|
||||
(()
|
||||
#t)
|
||||
(removed
|
||||
(let ((count (length removed)))
|
||||
(format (current-error-port)
|
||||
(N_ " ~*One channel removed:~%"
|
||||
" ~a channels removed:~%" count)
|
||||
count)
|
||||
(for-each display-channel removed)))))))))
|
||||
|
||||
(define (display-news profile)
|
||||
;; Display profile news, with the understanding that this process represents
|
||||
;; the newest generation.
|
||||
(display-profile-news profile
|
||||
#:current-is-newer? #t)
|
||||
|
||||
(display-channel-news profile))
|
||||
|
||||
(define* (build-and-install instances profile
|
||||
#:key use-substitutes? verbose? dry-run?)
|
||||
"Build the tool from SOURCE, and install it in PROFILE. When DRY-RUN? is
|
||||
|
@ -521,10 +577,7 @@ (define (list-generations profile numbers)
|
|||
((numbers ...)
|
||||
(list-generations profile numbers)))))))
|
||||
(('display-news)
|
||||
;; Display profile news, with the understanding that this process
|
||||
;; represents the newest generation.
|
||||
(display-profile-news profile
|
||||
#:current-is-newer? #t))))
|
||||
(display-news profile))))
|
||||
|
||||
(define (process-generation-change opts profile)
|
||||
"Process a request to change the current generation (roll-back, switch, delete)."
|
||||
|
|
Loading…
Reference in a new issue