Augment 'TODO'.
[jackhill/guix/guix.git] / TODO
CommitLineData
6b8875c8
LC
1-*- mode: org; coding: utf-8; -*-
2
8c247e1c
LC
3#+TITLE: What's left to do?
4#+STARTUP: content hidestars
5
c0b3c89f 6Copyright © 2012, 2013 Ludovic Courtès <ludo@gnu.org>
6b8875c8
LC
7
8 Copying and distribution of this file, with or without modification,
9 are permitted in any medium without royalty provided the copyright
10 notice and this notice are preserved.
11
12* integrate needed Nix code
13
a9128eac
LC
14** Remove dependency on OpenSSL
15
16The ‘openssl’ command-line tool is used in libstore to sign store paths
17to be exported, and to check such signatures. The signing keys are
18usually in /etc/nix/signing-key.{pub,sec}. They are a PKCS#8-encoded
19X.509 SubjectPublicKeyInfo. These can be decoded with the [[http://lists.gnu.org/archive/html/help-gnutls/2012-12/msg00012.html][C API of
20GnuTLS]], but not yet with its Guile bindings. There’s also
21‘gnutls_privkey_sign_data’ to sign, and related functions.
22
c0b3c89f 23
9297c90b
LC
24** Add `guix publish' to publish the store using Guile's web server
25
26Generate narinfos and nars on the fly, upon HTTP GET requests.
27Ideally, extend .nix-cache-info to include the server's public key, and also
28reply to requests for .narinfo.sig.
29Optionally, use Guile-Avahi to publish the service.
c0b3c89f 30
5d388c7c 31** MAYBE Add a substituter that uses the GNUnet DHT or [[http://libswift.org][libswift]]
c7e4a72a 32
5d388c7c
LC
33Would be neat if binaries could be pushed to and pulled from the GNUnet DHT or
34rather libswift (since DHTs aren’t suited for large payloads). Guix users
35would sign their binaries, and define which binaries they trust.
36
37Use UPnP and similar to traverse NAT, like ‘filegive’ does.
c7e4a72a 38
c0b3c89f
LC
39** Add a remote build hook
40
41Like scripts/build-remote.pl in Nix.
42
c7e4a72a
LC
43* user interface
44** Add a package.el (Emacs) back-end
45
3e5980de
LC
46package.el is quite monolithic, but we may be able to reuse/extend
47‘package-menu-mode’ or at least ‘tabulated-list-mode’.
48
49** add guile-ncurses interface
c7e4a72a 50
6b8875c8
LC
51* extend <origin>
52** add OpenPGP signatures:
53
54 (origin
55 (method http-fetch)
56 (uri "http://.../foo.tgz")
57 (signature-uri (string-append uri ".sig"))
58 (signer-openpgp-fingerprint "..."))
59
60** allow <origin> to be a derivation/package or a file
61
62* extend <package>
63
499b8d1f
LC
64** add ‘recommends’ field
65
66For instance, glibc, binutils, gcc, and ld-wrapper would recommend each other.
67‘guix package -i’ could ask interactively (?), or allow users to follow all or
68none of the recommendations.
69
6b8875c8
LC
70** add a ‘user-environment-hook’
71
72This should specify builder code to be run when building a user
73environment with ‘guix-package’. For instance, Texinfo’s hook would
74create a new ‘dir’.
75
3036a01f
LC
76** add ‘patches’ there
77
78** extend ‘propagated-build-inputs’ with support for multiple outputs
79
80#+BEGIN_SRC scheme
81 (outputs '("out" "include"))
82 (propagated-build-inputs
83 `(((("i1" ,p1 "o1")
84 ("i2" ,p2))
85 => "include")
86 ("i3" ,p3)))
87#+END_SRC
88
3e5980de 89
8c247e1c 90* synchronize package descriptions with GSRC and/or the [[http://directory.fsf.org][FSD]]
29767aae
LC
91
92Meta-data for GNU packages, including descriptions and synopses, can be
93dumped from the FSD:
94http://directory.fsf.org/wiki?title=GNU/Export&action=purge .
95We could periodically synchronize with that.
96
3e5980de
LC
97See http://lists.gnu.org/archive/html/bug-guix/2013-04/msg00120.html for info
98on how to synchronize with GSRC's descriptions.
6b8875c8 99
c7e4a72a
LC
100* add a guildhall build system
101
102The Guildhall is Guile’s packaging system. It should be easy to add a
103‘guildhall-build-system’ that does the right thing based on guildhall
104recipes.
105
6b8875c8
LC
106* build-expression->derivation: define `%system' in the builder
107
108Would allow build expressions to have system-dependent code, like
109`glibc-dynamic-linker'.
110
111* add ‘allowed-references’ in <package>
112
113[[file:~/src/nix/src/libstore/build.cc::if%20(drv.env.find("allowedReferences")%20!%3D%20drv.env.end())%20{][See how Nix implements that internally]].
114
6b8875c8
LC
115* union
116
117Support sophisticated collision handling when building a union: check
118whether the colliding files are identical, honor per-package priorities,
119etc.
120
3dfd7cef
LC
121* add GUIX_ALLOW_EXPENSIVE_TESTS
122
123Tests that need to download stuff or otherwise take a long time would only be
124run when that is defined.
125
290d4370
LC
126* add "guix challenge"
127
128Would download a substitute, and compare its contents against a (hopefully
129locally-built) copy.
130
d8f257f9 131* guix package
6b8875c8 132
6b8875c8 133** add ‘--list-generations’, and ‘--delete-generations’
6b8875c8
LC
134
135* guix build utils
29767aae
LC
136** MAYBE Change ‘ld-wrapper’ to add RPATH for libs passed by file name
137
8c247e1c 138** MAYBE Add equivalent to chrpath that uses [[https://gitorious.org/guile-dlhacks/guile-dlhacks/][guile-dlhacks]]
6b8875c8 139
29767aae 140** MAYBE Add a hash-rewriting thing for deep dependency replacement without rebuild
c7e4a72a
LC
141
142See [[https://github.com/NixOS/nixpkgs/commit/d1662d715514e6ef9d3dc29f132f1b3d8e608a18][Shea Levy's `replace-dependency' in Nixpkgs]].
143
6b8875c8 144* distro
6b8875c8
LC
145** port to new GNU/Linux platforms, notably ‘mipsel64-linux’
146** port to GNU/Hurd, aka. ‘i686-gnu’
147
148Problems include that current glibc releases do not build on GNU/Hurd.
149In addition, there haven’t been stable releases of GNU Mach, MiG, and
150Hurd, which would be a pre-condition.
151
152** make a bootable GNU/Linux-Libre distro, with OS configuration EDSL
153
154Similar in spirit to /etc/nixos/configuration.nix.