unofficial mirror of guix-devel@gnu.org 
 help / color / mirror / code / Atom feed
* Packaging rust crates without compiling dependencies again for every dependent (wasting build time)
@ 2022-04-30  9:29 Maxime Devos
  2022-05-09 10:02 ` Efraim Flashner
  0 siblings, 1 reply; 3+ messages in thread
From: Maxime Devos @ 2022-04-30  9:29 UTC (permalink / raw)
  To: guix-devel

[-- Attachment #1: Type: text/plain, Size: 1947 bytes --]

Hi various distributions packaging rust things (^),

Currently, most (all?) distributions seem to package ‘source-only
crates’, which when ‘compiled’, just copy some source code to a
location.  This works, but the downside is that if both a package X and
a package Y depends on rust-Z, then rust-Z will effectively be compiled
twice: when building X, but also when building Y.

This seems a waste of compilation time to me, so I've been writing a
build tool ‘antioxidant’ (*) for the distribution Guix that avoids
double compilation, at
<https://notabug.org/maximed/cargoless-rust-experiments>).

To avoid the double compilation things, antioxidant calls the
underlying rustc by itself instead of cargo, and it reads and
interprets Cargo.toml by itself instead of letting cargo do that.

Currently, it's rather Guix-specific, but in principle it should be
possible to turn it in some binary 'antioxidant' that could be used on
other distributions as well if someone is interested in that, e.g.
something like

$ # (not implemented yet!)
$ antioxidant configure --prefix=$HOME/extra-software -Lcrate=/usr/lib/crates -L/usr/lib -Lcrate=$HOME/extra-software/lib/crates --features=x,y,z
$ antioxidant make
$ antioxidant make check
$ antioxidant make install DESTDIR=... # this does not install source code, only the compiled crates

(*) A ‘build system’, in Guix terminology.

Currently, it can succesfully compile 'hexyl', 'sniffglue' and all
their dependencies.  I'm working on addressing limitations that
prevent antioxidant from compiling other binaries (currently trying
to make 'agate' and all its dependencies compile).

Greetings,
Maxime.

(^) If you are reading this from guix-devel@: some of the distributions I
intend to contact have a no-crossposting policy, so I'm first sending this to
guix-devel@, then sending some mails to individual distributions with a link
to this e-mail.

[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 260 bytes --]

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2022-05-09 10:10 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-04-30  9:29 Packaging rust crates without compiling dependencies again for every dependent (wasting build time) Maxime Devos
2022-05-09 10:02 ` Efraim Flashner
2022-05-09 10:08   ` Maxime Devos

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).