| 9 Aug 2023 |
ckie (they/them; limited keyboard usage, voice preferred) | lmk when you figure out what's needed of the nix bit. you know the general requirements though right? | 19:34:36 |
JoelMcCracken | let me jut write out what i'm thinking | 19:35:13 |
JoelMcCracken | emacs is run w a shim, similar to what currently occurs via nix-straight, which grabs more of the
data besides just the package name (ideally, all of the data)
some lisp is called which looks up the metadata to see how straight.el would
resolve the package (the repo, the commit, etc). this data is serialized (json?)
at subsequent step, nix reads this serialized data, and then constructs an
overlay with the correct packages.
the installation then procedes as it currently does, using this new overlay to
just install the requrired packages.
| 19:39:42 |
JoelMcCracken | i noticed that these are done as separate... derivations? steps? not sure of the right term here.. in nix-straight; i'm not sure why it needs to be this way | 19:44:10 |
ckie (they/them; limited keyboard usage, voice preferred) | JoelMcCracken: right so, the emacs shim runs in one go, currently collecting just the package names, and it doesn't have a network connection at this point because it's in a Nix build. the package meta is put into a json file, which is the output of this derivation. next up the nix evaluator parses this JSON, and prepares the next derivation using that, reading another derivation's result is called IFD | 19:49:25 |
ckie (they/them; limited keyboard usage, voice preferred) | * JoelMcCracken: right so, the emacs shim runs in one go, currently collecting just the package names, and it doesn't have a network connection at this point because it's in a Nix build. the package meta is put into a json file, which is the output of this derivation. next up the nix evaluator parses this JSON, and prepares the next derivation using that: reading another derivation's result is called IFD | 19:49:32 |
ckie (they/them; limited keyboard usage, voice preferred) | * JoelMcCracken: right so, the emacs shim runs in one go, currently collecting just the package names, and it doesn't have a network connection at this point because it's in a Nix build. the package meta is put into a json file, which is the output of this derivation. next up the nix evaluator parses this JSON, and prepares the next derivation using that: reading & Importing From a Derivation's result is called IFD | 19:49:51 |
JoelMcCracken | ahhhhhh | 19:50:16 |
ckie (they/them; limited keyboard usage, voice preferred) | but the trick is we don't always get fully-qualified package paths, sometimes we just get a (package! blahblah-mode), and we have to resolve it | 19:50:38 |
JoelMcCracken | sure | 19:50:55 |
ckie (they/them; limited keyboard usage, voice preferred) | so that's done here atm | 19:51:55 |
JoelMcCracken | this seems to be the key https://github.com/radian-software/straight.el/blob/master/straight.el#L3022 | 19:54:45 |
ckie (they/them; limited keyboard usage, voice preferred) | i feel that comment on 3031 | 19:55:36 |
ckie (they/them; limited keyboard usage, voice preferred) | so essentially we need to determine a good spot to splice Nix in | 19:56:38 |
ckie (they/them; limited keyboard usage, voice preferred) | that ideally doesn't involve a large api surface area | 19:56:52 |
JoelMcCracken | yeah | 19:58:12 |
ckie (they/them; limited keyboard usage, voice preferred) | so that's about where i timed out last time after running around the room trying to read elisp | 19:58:40 |
j4m3s | slighty related question, is it sufficient to lock doom's git version to lock package version or ? (I'm confused about the ~/.emacs.d/bin/doom upgrade | 19:59:10 |
ckie (they/them; limited keyboard usage, voice preferred) | moooostly | 19:59:28 |
ckie (they/them; limited keyboard usage, voice preferred) | all of doom's own packages should be pinned, but the user doesn't have to specify a pin | 19:59:50 |
ckie (they/them; limited keyboard usage, voice preferred) | like I have all of these: | 20:00:09 |
ckie (they/them; limited keyboard usage, voice preferred) |  Download image.png | 20:00:10 |
j4m3s | Yeah right, i was just confused by the fact that in the modules they're called w/o the pin | 20:00:41 |
j4m3s | But seems like the pin is global to the repo :) | 20:00:49 |
ckie (they/them; limited keyboard usage, voice preferred) |  Download image.png | 20:01:36 |
ckie (they/them; limited keyboard usage, voice preferred) | JoelMcCracken: so this is another thing to consider actually. we need to save straight's resolutions. or every package registry's, but that might not be as feasible | 20:02:42 |
ckie (they/them; limited keyboard usage, voice preferred) | i'm tending more towards that doom2nix that saves all the source url/commit-ish/hash pins | 20:03:43 |
j4m3s | mb then, I remembered it being empty. Thanks for the correction ~ | 20:07:46 |
JoelMcCracken | what is doom2nix? | 21:15:16 |
JoelMcCracken | also,
we need to save straight's resolutions is this covered by e..g exporting them as json output?
| 21:16:07 |