Nix Milan | 129 Members | |
| https://milano.nix.pizza/ | 10 Servers |
| Sender | Message | Time |
|---|---|---|
| 13 Jun 2026 | ||
magari puoi usare srcs e in base ad un flag negli argomenti del package ci appendi libtwo https://nixos.org/manual/nixpkgs/stable/#variables-controlling-the-unpack-phase | 16:22:22 | |
| * hmm cioè tu vorresti fare in modo che mentre stai lavorando su libone, cmake possa direttamente compilare anche libtwo in modo che quando vai a fare qualche cambiamento su libtwo hai già gli artifact intermedi della build incrementale in cache | 16:33:55 | |
No, io vorrei che me le compilo separatamente ma libone invece che installarla nello store la installo in path nella mia home che poi uso come dipendenza quando buildo libtwo. | 16:56:34 | |
| Ah ok capito | 16:57:24 | |
| Potrei fare una mega derivazione unica, ma è sbatti. Se tengo le derivazioni separate come suggerivo, gli use case "build normale di nix" e "build incrementali a manina" rimangono molto simili (eccetto gli override sostanzialmente). | 16:57:28 | |
| 14 Jun 2026 | ||
| Di base è come se stessi ricreando uno /usr/lib in X giusto? | 08:04:09 | |
| 15 Jun 2026 | ||
Mmmmh, più /usr. È il prefix di installazione della build di libone. Ma non è un prefix globale (nel senso che X è solo per libone, non anche per libtwo). | 02:00:02 | |
| Hai provato a guardare https://nixos.wiki/wiki/CCache. Puoi fare override di stdenv per quelle due derivation e gli artefatti andranno in un punto comune di cui puoi anche monitorare lo stato e le statistiche | 06:18:14 | |
Penso che configuri il servizio su nixos o darwin etc (ccache.enable più il resto tipo la directory della cache e i permessi) e poiSe ha funzionato puoi fare ccache --show-statsCome bonus lo puoi usare anche per la configurazione, tipo per packages unfree non presenti nei substituter che devi sempre compilare oppure quando applichi patch con gli overlay | 06:24:01 | |
Gli hash sono gestiti separati. Nix ha il suo hash della derivazione intera (file sorgente + compilatore + ...), mentre ccache ha gli hash dei singoli file sorgente quindi li riusa se non cambi i file di libone | 06:28:57 | |
| Se non ti funziona la cache per qualche file leggi https://ccache.dev/manual/4.7.4.html#:~:text=sloppiness Tipo se hai usato __DATE__ nel codice allora l'hash di quell'artefatto cambierà ogni giorno, e ccache lo può evitare usando sempre lo stesso seed | 06:37:06 | |
| Ultima cosa: mozilla ha anche https://github.com/mozilla/sccache per avere cache distribuite su network | 06:42:57 | |
| CCache approaccia il problema ad un altro livello e ti aiuta solo in parte, devi comunque ri-linkare tutto, ri-runnare la fase di configure. Non sono veramente "build incrementali". | 07:38:13 | |
| Also, funziona solo con C/C | 07:38:40 | |
| * Also, funziona solo con C/C++, non funziona con progetti Python/TypeScript ad esempio | 07:38:54 | |
| * CCache approccia il problema ad un altro livello e ti aiuta solo in parte, devi comunque ri-linkare tutto, ri-runnare la fase di configure. Non sono veramente "build incrementali". | 08:06:06 | |
| Già già | 10:19:23 | |
| Grazie, su questo ci devo pensare. Mi fido, ma non so risponderti | 10:19:48 | |
| La fase di configure è gestita da cmake giusto? quindi con il tuo metodo si salvano anche gli artifatti che genera lui e velocizzi il configure. Il linking è così lento? Forse se hai tante compilation unit inizia a pesare? | 10:25:28 | |
Se fai build incrementali rebuildi il minimo necessario a seguito di un cambiamento nel sorgente. Quindi se non cambi CMakeLists.txt, cmake non gira.A volte lo è, soprattutto su progetti grossi (tipo LLVM). Ma overall fare una builda pulita ogni volta è sbatti: CMake + script non ccachabili + linking. A meno che ci sia un blocker insormontabile vorrei le build incrementali Vere™. | 11:15:57 | |
| https://github.com/pdtpartners/nix-ninja (?) | 11:36:40 | |
| Dubito sia meglio di come hai fatto tu comunque | 11:37:35 | |
> Parses ninja.build files and generates a derivation per compilation unit.Aggressivo. Però non risolverebbe il mio problema, io voglio sostanzialmente impurità. Ovvero poter cambiare una dipendenza upstream senza necessariamente ricompilare downstream. | 17:19:14 | |
| Però interessante | 17:19:17 | |
| 17 Jun 2026 | ||
Download image.png | 07:51:44 | |
| Siamo già arrivati alla AGI | 07:59:01 | |
| SLOP | 10:59:00 | |
| 29 Feb 2024 | ||
| 12:19:16 | ||
| 12:19:31 | ||
| 12:20:33 | ||