blob: 1857d06edf7df49faf7056ca0288bb74a3bc5275 (
plain)
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
|
(use-modules (srfi srfi-1))
(include "projects.scm")
(define %members
;; List of member/projects tuples.
(let ((table (make-hash-table eq? hashq)))
(hash-table-fold %projects
(lambda (key project lst)
(for-each (lambda (member)
(let ((projects (hash-table-ref/default
table member '())))
(hash-table-set! table member
(cons project
projects))))
(project-members project)))
'())
(sort (delete-duplicates
(hash-table-fold table alist-cons '()))
(match-lambda*
(((member1 . _) (member2 . _))
(string<? (person-name member1)
(person-name member2)))))))
`((title . "Software")
(author . "The GNU Assembly")
(menu . "people")
(date . ,(string->date* "2021-04-14 23:00"))
(content
((h2 "People")
(p "The following maintainers and contributors endorsed the "
(a (@ (href "/en/documents/social-contract"))
"Social Contract")
" and may participate in the GNU Assembly:")
(ul ;; (@ (class "projects"))
,@(map (match-lambda
((person projects ...)
`(li (@ (class "person"))
,(let ((home-page (person-url person)))
(if home-page
`(a (@ (href ,home-page))
,(person-name person))
(person-name person)))
" ("
,(string-join (map project-name projects)
", ")
")")))
%members)))))
|