2012-11-18 11:10:47 -05:00
|
|
|
|
-*- mode: org; coding: utf-8; -*-
|
|
|
|
|
|
2013-05-10 15:08:01 -04:00
|
|
|
|
#+TITLE: What's left to do?
|
|
|
|
|
#+STARTUP: content hidestars
|
|
|
|
|
|
2013-01-09 16:12:11 -05:00
|
|
|
|
Copyright © 2012, 2013 Ludovic Courtès <ludo@gnu.org>
|
2012-11-18 11:10:47 -05:00
|
|
|
|
|
|
|
|
|
Copying and distribution of this file, with or without modification,
|
|
|
|
|
are permitted in any medium without royalty provided the copyright
|
|
|
|
|
notice and this notice are preserved.
|
|
|
|
|
|
|
|
|
|
* integrate needed Nix code
|
|
|
|
|
|
2012-12-12 09:32:35 -05:00
|
|
|
|
** Remove dependency on OpenSSL
|
|
|
|
|
|
|
|
|
|
The ‘openssl’ command-line tool is used in libstore to sign store paths
|
|
|
|
|
to be exported, and to check such signatures. The signing keys are
|
|
|
|
|
usually in /etc/nix/signing-key.{pub,sec}. They are a PKCS#8-encoded
|
|
|
|
|
X.509 SubjectPublicKeyInfo. These can be decoded with the [[http://lists.gnu.org/archive/html/help-gnutls/2012-12/msg00012.html][C API of
|
|
|
|
|
GnuTLS]], but not yet with its Guile bindings. There’s also
|
|
|
|
|
‘gnutls_privkey_sign_data’ to sign, and related functions.
|
|
|
|
|
|
2013-01-09 16:12:11 -05:00
|
|
|
|
|
2013-04-12 09:59:03 -04:00
|
|
|
|
** Add `guix publish' to publish the store using Guile's web server
|
|
|
|
|
|
|
|
|
|
Generate narinfos and nars on the fly, upon HTTP GET requests.
|
|
|
|
|
Ideally, extend .nix-cache-info to include the server's public key, and also
|
|
|
|
|
reply to requests for .narinfo.sig.
|
|
|
|
|
Optionally, use Guile-Avahi to publish the service.
|
2013-01-09 16:12:11 -05:00
|
|
|
|
|
2013-10-06 16:55:36 -04:00
|
|
|
|
** MAYBE Add a substituter that uses the GNUnet DHT or [[http://libswift.org][libswift]]
|
2013-01-15 05:35:15 -05:00
|
|
|
|
|
2013-10-06 16:55:36 -04:00
|
|
|
|
Would be neat if binaries could be pushed to and pulled from the GNUnet DHT or
|
|
|
|
|
rather libswift (since DHTs aren’t suited for large payloads). Guix users
|
|
|
|
|
would sign their binaries, and define which binaries they trust.
|
|
|
|
|
|
|
|
|
|
Use UPnP and similar to traverse NAT, like ‘filegive’ does.
|
2013-01-15 05:35:15 -05:00
|
|
|
|
|
2013-01-09 16:12:11 -05:00
|
|
|
|
** Add a remote build hook
|
|
|
|
|
|
|
|
|
|
Like scripts/build-remote.pl in Nix.
|
|
|
|
|
|
2013-01-15 05:35:15 -05:00
|
|
|
|
* user interface
|
|
|
|
|
** Add a package.el (Emacs) back-end
|
|
|
|
|
|
2013-06-14 11:05:49 -04:00
|
|
|
|
package.el is quite monolithic, but we may be able to reuse/extend
|
|
|
|
|
‘package-menu-mode’ or at least ‘tabulated-list-mode’.
|
|
|
|
|
|
|
|
|
|
** add guile-ncurses interface
|
2013-01-15 05:35:15 -05:00
|
|
|
|
|
2012-11-18 11:10:47 -05:00
|
|
|
|
* extend <origin>
|
|
|
|
|
** add OpenPGP signatures:
|
|
|
|
|
|
|
|
|
|
(origin
|
|
|
|
|
(method http-fetch)
|
|
|
|
|
(uri "http://.../foo.tgz")
|
|
|
|
|
(signature-uri (string-append uri ".sig"))
|
|
|
|
|
(signer-openpgp-fingerprint "..."))
|
|
|
|
|
|
|
|
|
|
** allow <origin> to be a derivation/package or a file
|
|
|
|
|
|
|
|
|
|
* extend <package>
|
|
|
|
|
|
2013-05-17 17:15:49 -04:00
|
|
|
|
** add ‘recommends’ field
|
|
|
|
|
|
|
|
|
|
For instance, glibc, binutils, gcc, and ld-wrapper would recommend each other.
|
|
|
|
|
‘guix package -i’ could ask interactively (?), or allow users to follow all or
|
|
|
|
|
none of the recommendations.
|
|
|
|
|
|
2012-11-18 11:10:47 -05:00
|
|
|
|
** add a ‘user-environment-hook’
|
|
|
|
|
|
|
|
|
|
This should specify builder code to be run when building a user
|
|
|
|
|
environment with ‘guix-package’. For instance, Texinfo’s hook would
|
|
|
|
|
create a new ‘dir’.
|
|
|
|
|
|
2012-12-04 16:04:03 -05:00
|
|
|
|
** add ‘patches’ there
|
|
|
|
|
|
|
|
|
|
** extend ‘propagated-build-inputs’ with support for multiple outputs
|
|
|
|
|
|
|
|
|
|
#+BEGIN_SRC scheme
|
|
|
|
|
(outputs '("out" "include"))
|
|
|
|
|
(propagated-build-inputs
|
|
|
|
|
`(((("i1" ,p1 "o1")
|
|
|
|
|
("i2" ,p2))
|
|
|
|
|
=> "include")
|
|
|
|
|
("i3" ,p3)))
|
|
|
|
|
#+END_SRC
|
|
|
|
|
|
2013-06-14 11:05:49 -04:00
|
|
|
|
|
2013-05-10 15:08:01 -04:00
|
|
|
|
* synchronize package descriptions with GSRC and/or the [[http://directory.fsf.org][FSD]]
|
2013-01-26 18:59:04 -05:00
|
|
|
|
|
|
|
|
|
Meta-data for GNU packages, including descriptions and synopses, can be
|
|
|
|
|
dumped from the FSD:
|
|
|
|
|
http://directory.fsf.org/wiki?title=GNU/Export&action=purge .
|
|
|
|
|
We could periodically synchronize with that.
|
|
|
|
|
|
2013-06-14 11:05:49 -04:00
|
|
|
|
See http://lists.gnu.org/archive/html/bug-guix/2013-04/msg00120.html for info
|
|
|
|
|
on how to synchronize with GSRC's descriptions.
|
2012-11-18 11:10:47 -05:00
|
|
|
|
|
2013-01-15 05:35:15 -05:00
|
|
|
|
* add a guildhall build system
|
|
|
|
|
|
|
|
|
|
The Guildhall is Guile’s packaging system. It should be easy to add a
|
|
|
|
|
‘guildhall-build-system’ that does the right thing based on guildhall
|
|
|
|
|
recipes.
|
|
|
|
|
|
2012-11-18 11:10:47 -05:00
|
|
|
|
* build-expression->derivation: define `%system' in the builder
|
|
|
|
|
|
|
|
|
|
Would allow build expressions to have system-dependent code, like
|
|
|
|
|
`glibc-dynamic-linker'.
|
|
|
|
|
|
|
|
|
|
* add ‘allowed-references’ in <package>
|
|
|
|
|
|
|
|
|
|
[[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]].
|
|
|
|
|
|
|
|
|
|
* union
|
|
|
|
|
|
|
|
|
|
Support sophisticated collision handling when building a union: check
|
|
|
|
|
whether the colliding files are identical, honor per-package priorities,
|
|
|
|
|
etc.
|
|
|
|
|
|
2013-07-19 17:22:59 -04:00
|
|
|
|
* add GUIX_ALLOW_EXPENSIVE_TESTS
|
|
|
|
|
|
|
|
|
|
Tests that need to download stuff or otherwise take a long time would only be
|
|
|
|
|
run when that is defined.
|
|
|
|
|
|
2013-08-23 05:37:10 -04:00
|
|
|
|
* add "guix challenge"
|
|
|
|
|
|
|
|
|
|
Would download a substitute, and compare its contents against a (hopefully
|
|
|
|
|
locally-built) copy.
|
|
|
|
|
|
2013-02-17 13:23:45 -05:00
|
|
|
|
* guix package
|
2012-11-18 11:10:47 -05:00
|
|
|
|
|
|
|
|
|
** add ‘--list-generations’, and ‘--delete-generations’
|
|
|
|
|
|
|
|
|
|
* guix build utils
|
2013-01-26 18:59:04 -05:00
|
|
|
|
** MAYBE Change ‘ld-wrapper’ to add RPATH for libs passed by file name
|
|
|
|
|
|
2013-05-10 15:08:01 -04:00
|
|
|
|
** MAYBE Add equivalent to chrpath that uses [[https://gitorious.org/guile-dlhacks/guile-dlhacks/][guile-dlhacks]]
|
2012-11-18 11:10:47 -05:00
|
|
|
|
|
2013-01-26 18:59:04 -05:00
|
|
|
|
** MAYBE Add a hash-rewriting thing for deep dependency replacement without rebuild
|
2013-01-15 05:35:15 -05:00
|
|
|
|
|
|
|
|
|
See [[https://github.com/NixOS/nixpkgs/commit/d1662d715514e6ef9d3dc29f132f1b3d8e608a18][Shea Levy's `replace-dependency' in Nixpkgs]].
|
|
|
|
|
|
2012-11-18 11:10:47 -05:00
|
|
|
|
* distro
|
|
|
|
|
** port to new GNU/Linux platforms, notably ‘mipsel64-linux’
|
|
|
|
|
** port to GNU/Hurd, aka. ‘i686-gnu’
|
|
|
|
|
|
|
|
|
|
Problems include that current glibc releases do not build on GNU/Hurd.
|
|
|
|
|
In addition, there haven’t been stable releases of GNU Mach, MiG, and
|
|
|
|
|
Hurd, which would be a pre-condition.
|
|
|
|
|
|
|
|
|
|
** make a bootable GNU/Linux-Libre distro, with OS configuration EDSL
|
|
|
|
|
|
|
|
|
|
Similar in spirit to /etc/nixos/configuration.nix.
|