* Package variant defined in manifest not visible by Guix
@ 2021-08-16 8:08 Philippe SWARTVAGHER
2021-08-16 12:04 ` Efraim Flashner
2021-08-16 14:34 ` Ricardo Wurmus
0 siblings, 2 replies; 6+ messages in thread
From: Philippe SWARTVAGHER @ 2021-08-16 8:08 UTC (permalink / raw)
To: help-guix
Hello,
I'm trying to use a manifest file to define a package variant which adds
an option to the configure phase:
```
(use-modules (inria storm))
(define starpu-maxnodes1
(package
(inherit starpu)
(arguments
(substitute-keyword-arguments (package-arguments starpu)
((#:configure-flags flags '())
`(cons "--enable-maxnodes=1"
,flags))))))
```
When I'm trying to build this variant, guix can't find it:
```
% guix build -c 2 -m starpu-maxnodes1.scm starpu-maxnodes1
guix build: erreur : starpu-maxnodes1 : paquet inconnu
```
I don't see what I'm doing wrong. Any idea ?
Just if you want to try these exact commands, StarPU is a package
defined in this channel:
```
(channel
(name 'guix-hpc)
(url "https://gitlab.inria.fr/guix-hpc/guix-hpc.git")
(commit
"fa8cc70bc428c08a625a533f778537314be64ce7"))
```
(I didn't subscribe to help-guix mailing list, so please keep me as
recipient of your answers.)
--
Philippe SWARTVAGHER
PhD Student
TADaaM team, Inria Bordeaux Sud-Ouest
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Package variant defined in manifest not visible by Guix
2021-08-16 8:08 Package variant defined in manifest not visible by Guix Philippe SWARTVAGHER
@ 2021-08-16 12:04 ` Efraim Flashner
2021-08-16 14:34 ` Ricardo Wurmus
1 sibling, 0 replies; 6+ messages in thread
From: Efraim Flashner @ 2021-08-16 12:04 UTC (permalink / raw)
To: Philippe SWARTVAGHER; +Cc: help-guix
[-- Attachment #1: Type: text/plain, Size: 1954 bytes --]
On Mon, Aug 16, 2021 at 10:08:34AM +0200, Philippe SWARTVAGHER wrote:
> Hello,
>
> I'm trying to use a manifest file to define a package variant which adds
> an option to the configure phase:
>
> ```
>
> (use-modules (inria storm))
>
> (define starpu-maxnodes1
> (package
> (inherit starpu)
> (arguments
> (substitute-keyword-arguments (package-arguments starpu)
> ((#:configure-flags flags '())
> `(cons "--enable-maxnodes=1"
> ,flags))))))
>
> ```
>
> When I'm trying to build this variant, guix can't find it:
>
> ```
>
> % guix build -c 2 -m starpu-maxnodes1.scm starpu-maxnodes1
> guix build: erreur : starpu-maxnodes1 : paquet inconnu
>
> ```
>
> I don't see what I'm doing wrong. Any idea ?
>
> Just if you want to try these exact commands, StarPU is a package
> defined in this channel:
Inherit inherits everything except for what you override, so your
package can be refered to as starpu-maxnodes1 when using it as an input
for another package (for example), but to build it from the command line
it still has the original name of "starpu".
Also, I haven't tried running 'guix build -m manifest.scm
package-in-manifest', so I don't know if that works or not.
> ```
>
> (channel
> (name 'guix-hpc)
> (url "https://gitlab.inria.fr/guix-hpc/guix-hpc.git")
> (commit
> "fa8cc70bc428c08a625a533f778537314be64ce7"))
>
> ```
>
> (I didn't subscribe to help-guix mailing list, so please keep me as
> recipient of your answers.)
>
--
Efraim Flashner <efraim@flashner.co.il> אפרים פלשנר
GPG key = A28B F40C 3E55 1372 662D 14F7 41AA E7DC CA3D 8351
Confidentiality cannot be guaranteed on emails sent or received unencrypted
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Package variant defined in manifest not visible by Guix
2021-08-16 8:08 Package variant defined in manifest not visible by Guix Philippe SWARTVAGHER
2021-08-16 12:04 ` Efraim Flashner
@ 2021-08-16 14:34 ` Ricardo Wurmus
2021-08-17 7:17 ` zimoun
2021-08-18 8:57 ` Philippe SWARTVAGHER
1 sibling, 2 replies; 6+ messages in thread
From: Ricardo Wurmus @ 2021-08-16 14:34 UTC (permalink / raw)
To: Philippe SWARTVAGHER; +Cc: help-guix
Hi,
> I'm trying to use a manifest file to define a package variant
> which adds
> an option to the configure phase:
>
> ```
>
> (use-modules (inria storm))
>
> (define starpu-maxnodes1
> (package
> (inherit starpu)
> (arguments
> (substitute-keyword-arguments (package-arguments starpu)
> ((#:configure-flags flags
> '())
> `(cons
> "--enable-maxnodes=1"
> ,flags))))))
>
> ```
>
> When I'm trying to build this variant, guix can't find it:
>
> ```
>
> % guix build -c 2 -m starpu-maxnodes1.scm starpu-maxnodes1
> guix build: erreur : starpu-maxnodes1 : paquet inconnu
>
> ```
>
> I don't see what I'm doing wrong. Any idea ?
There seems to be a small misunderstanding. You defined a package
variant, but that’s not a manifest. A manifest describes the
complete contents of a profile; i.e. it’s a list of packages that
Guix should install.
Here are three different ways that should work for you:
1) Build a single package from a file.
Here we define the package variant in a file and make sure that
the file evaluates to the package value:
--8<---------------cut here---------------start------------->8---
(use-modules (inria storm))
(define starpu-maxnodes1
(package
(inherit starpu)
(arguments
(substitute-keyword-arguments (package-arguments starpu)
((#:configure-flags flags '())
`(cons "--enable-maxnodes=1"
,flags))))))
;; Make sure the file evaluates to the package value.
;; The definition alone has no specified return value.
starpu-maxnodes1
--8<---------------cut here---------------end--------------->8---
Now we can build the package specified in the file:
guix build --file=this-file.scm
2) Build a whole manifest from a file.
Here the file must evaluate to a manifest value, not just a single
package.
--8<---------------cut here---------------start------------->8---
(use-modules (inria storm))
(define starpu-maxnodes1
(package
(inherit starpu)
(arguments
(substitute-keyword-arguments (package-arguments starpu)
((#:configure-flags flags '())
`(cons "--enable-maxnodes=1"
,flags))))))
(packages->manifest (list starpu-maxnodes1))
--8<---------------cut here---------------end--------------->8---
Then build the profile from the manifest file:
guix build --manifest=this-file.scm
3) Create a module and use it however you want.
You can make the custom package available to any Guix command by
putting it into a Guile module and then informing Guix about the
module. This is a little more effort as you need more boilerplate
code to define the module (and the file name needs to match the
moule header, etc).
--8<---------------cut here---------------start------------->8---
(define-module (my packages storm)
#:use-module (gnu packages)
#:use-module (guix packages)
#:use-module (guix utils)
;; …
#:use-module (inria storm)
#:export (starpu-maxnodes1))
(define starpu-maxnodes1
(package
(inherit starpu)
(arguments
(substitute-keyword-arguments (package-arguments starpu)
((#:configure-flags flags '())
`(cons "--enable-maxnodes=1"
,flags))))))
--8<---------------cut here---------------end--------------->8---
Put this in a file “my/packages/storm.scm” and then set the
GUIX_PACKAGE_PATH environment variable to the directory containing
“my” (e.g. $HOME/code/guix/custom containing
$HOME/code/guix/custom/my/packages/storm.scm).
Note that you haven’t overridden the “name” field of the original
“starpu” package, so on the command line the package cannot be
distinguished (unless you use “-e '(@ (my packages storm)
starpu-maxnodes1)'”). Do this to also change the name on the
command line:
--8<---------------cut here---------------start------------->8---
(define starpu-maxnodes1
(package
(inherit starpu)
(name "starpu-maxnodes1")
(arguments
(substitute-keyword-arguments (package-arguments starpu)
((#:configure-flags flags '())
`(cons "--enable-maxnodes=1"
,flags))))))
--8<---------------cut here---------------end--------------->8---
Hope this helps!
--
Ricardo
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Package variant defined in manifest not visible by Guix
2021-08-16 14:34 ` Ricardo Wurmus
@ 2021-08-17 7:17 ` zimoun
2021-08-18 8:57 ` Philippe SWARTVAGHER
1 sibling, 0 replies; 6+ messages in thread
From: zimoun @ 2021-08-17 7:17 UTC (permalink / raw)
To: Ricardo Wurmus, Philippe SWARTVAGHER; +Cc: help-guix
Hi Philippe,
On Mon, 16 Aug 2021 at 16:34, Ricardo Wurmus <rekado@elephly.net> wrote:
> 3) Create a module and use it however you want.
[...]
> Put this in a file “my/packages/storm.scm” and then set the
> GUIX_PACKAGE_PATH environment variable to the directory containing
> “my” (e.g. $HOME/code/guix/custom containing
> $HOME/code/guix/custom/my/packages/storm.scm).
Do not miss the CLI option ’--load-path’. Instead of setting the
environment variable GUIX_PACKAGE_PATH, you can also do:
guix build --load-path=my/packages/storm.scm <your-variant-package-name>
> Note that you haven’t overridden the “name” field of the original
> “starpu” package, so on the command line the package cannot be
> distinguished (unless you use “-e '(@ (my packages storm)
> starpu-maxnodes1)'”). Do this to also change the name on the
> command line:
>
> --8<---------------cut here---------------start------------->8---
> (define starpu-maxnodes1
> (package
> (inherit starpu)
> (name "starpu-maxnodes1")
> (arguments
> (substitute-keyword-arguments (package-arguments starpu)
> ((#:configure-flags flags '())
> `(cons "--enable-maxnodes=1"
> ,flags))))))
> --8<---------------cut here---------------end--------------->8---
In the initial error message, the package is unknown because the package
name ’starpu-maxnodes1’ does not exist, it is the name of the symbol.
And the symbol ’starpu-maxnodes1’ has the name ’starpu’. Does it make
sense?
Cheers,
simon
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Package variant defined in manifest not visible by Guix
2021-08-16 14:34 ` Ricardo Wurmus
2021-08-17 7:17 ` zimoun
@ 2021-08-18 8:57 ` Philippe SWARTVAGHER
2021-08-18 13:21 ` zimoun
1 sibling, 1 reply; 6+ messages in thread
From: Philippe SWARTVAGHER @ 2021-08-18 8:57 UTC (permalink / raw)
To: help-guix
Hello,
Le 16/08/2021 à 16:34, Ricardo Wurmus a écrit :
> There seems to be a small misunderstanding. You defined a package
> variant, but that’s not a manifest. A manifest describes the complete
> contents of a profile; i.e. it’s a list of packages that Guix should
> install.
>
> Here are three different ways that should work for you:
>
> 1) Build a single package from a file.
>
> Now we can build the package specified in the file:
>
> guix build --file=this-file.scm
>
>
> 2) Build a whole manifest from a file.
>
> Here the file must evaluate to a manifest value, not just a single
> package.
Ok, I was missing the line to evaluate to a manifest, instead of a
single package.
> Then build the profile from the manifest file:
>
> guix build --manifest=this-file.scm
>
>
> 3) Create a module and use it however you want.
>
> You can make the custom package available to any Guix command by
> putting it into a Guile module and then informing Guix about the
> module. This is a little more effort as you need more boilerplate
> code to define the module (and the file name needs to match the moule
> header, etc).
>
> Hope this helps!
Sure, it helps ! Thanks a lot ! However, I still have some questions:
- I don't really see the difference, or more precisely: the difference
of goal, between defining the package in a simple file (solution 1) and
using a manifest (solution 2).
- The following command builds the package as defined in the *file*,
without running tests:
guix build -c 2 -f starpu-maxnodes1-file.scm
--without-tests=starpu-maxnodes1
So package transformations seem to work. However:
guix build -c 2 -f starpu-maxnodes1-file.scm chameleon
--with-input=starpu=starpu-maxnodes1 --with-input=openblas=mkl
--without-tests=starpu-maxnodes1
doesn't work: starpu-maxnodes1 is an unknown package...
The same happens if I use a manifest instead of a file to define
starpu-maxnodes1:
guix build -c 2 -m starpu-maxnodes1.scm --with-input=openmpi=nmad
--without-tests=starpu-maxnodes1
works (without running tests), however:
guix build -c 2 -m starpu-maxnodes1.scm chameleon
--with-input=starpu=starpu-maxnodes1 --with-input=openblas=mkl
--with-input=openmpi=nmad --without-tests=starpu-maxnodes1
doesn't.
I guess I have to put all transformations of several packages in a
single manifest, one cannot combine manifest and CLI options; packages
defined in manifest aren't available for use in CLI transformations
(although the working --without-tests seems to be a counter argument).
Am I right ?
Thanks again for your help !
--
Philippe SWARTVAGHER
PhD Student
TADaaM team, Inria Bordeaux Sud-Ouest
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: Package variant defined in manifest not visible by Guix
2021-08-18 8:57 ` Philippe SWARTVAGHER
@ 2021-08-18 13:21 ` zimoun
0 siblings, 0 replies; 6+ messages in thread
From: zimoun @ 2021-08-18 13:21 UTC (permalink / raw)
To: Philippe SWARTVAGHER, help-guix
Hi Philippe,
On Wed, 18 Aug 2021 at 10:57, Philippe SWARTVAGHER <philippe.swartvagher@inria.fr> wrote:
> Le 16/08/2021 à 16:34, Ricardo Wurmus a écrit :
>> There seems to be a small misunderstanding. You defined a package
>> variant, but that’s not a manifest. A manifest describes the complete
>> contents of a profile; i.e. it’s a list of packages that Guix should
>> install.
>>
>> Here are three different ways that should work for you:
>>
>> 1) Build a single package from a file.
>>
>> Now we can build the package specified in the file:
>>
>> guix build --file=this-file.scm
>>
>>
>> 2) Build a whole manifest from a file.
>>
>> Here the file must evaluate to a manifest value, not just a single
>> package.
>
> Ok, I was missing the line to evaluate to a manifest, instead of a
> single package.
>
>
>> Then build the profile from the manifest file:
>>
>> guix build --manifest=this-file.scm
>>
>>
>> 3) Create a module and use it however you want.
>>
>> You can make the custom package available to any Guix command by
>> putting it into a Guile module and then informing Guix about the
>> module. This is a little more effort as you need more boilerplate
>> code to define the module (and the file name needs to match the moule
>> header, etc).
>>
>> Hope this helps!
>
> Sure, it helps ! Thanks a lot ! However, I still have some questions:
>
> - I don't really see the difference, or more precisely: the difference
> of goal, between defining the package in a simple file (solution 1) and
> using a manifest (solution 2).
Solution #1 (option --file) builds the package defined by FILE.
Solution #2 (option --manifest) builds the packages listed in FILE.
> - The following command builds the package as defined in the *file*,
> without running tests:
>
> guix build -c 2 -f starpu-maxnodes1-file.scm
> --without-tests=starpu-maxnodes1
>
> So package transformations seem to work. However:
>
> guix build -c 2 -f starpu-maxnodes1-file.scm chameleon
> --with-input=starpu=starpu-maxnodes1 --with-input=openblas=mkl
> --without-tests=starpu-maxnodes1
>
> doesn't work: starpu-maxnodes1 is an unknown package...
>
> The same happens if I use a manifest instead of a file to define
> starpu-maxnodes1:
>
> guix build -c 2 -m starpu-maxnodes1.scm --with-input=openmpi=nmad
> --without-tests=starpu-maxnodes1
>
> works (without running tests), however:
>
> guix build -c 2 -m starpu-maxnodes1.scm chameleon
> --with-input=starpu=starpu-maxnodes1 --with-input=openblas=mkl
> --with-input=openmpi=nmad --without-tests=starpu-maxnodes1
>
> doesn't.
I think what you want is the option --load-path. Create a folder and
put the file starpu-maxnodes1.scm inside; for instance
’/tmp/example/starpu-maxnodes1.scm’. Then, the command-line:
guix build -c 2 -L /tmp/example chameleon --with-input=starpu=starpu-maxnodes1
should do the job. In this case, the file
’/tmp/example/starpu-maxnodes1.scm’ does not have to return a package or
a manifest but instead define a module. Does it make sense?
> I guess I have to put all transformations of several packages in a
> single manifest, one cannot combine manifest and CLI options; packages
> defined in manifest aren't available for use in CLI transformations
> (although the working --without-tests seems to be a counter argument).
> Am I right ?
As Ricardo explained, the aim manifest is to describe the complete
contents of a profile, so from my understanding, the manifest should
also contain the transformation.
Well, I think what you want is the option ’--load-path’ and not a
manifest or the option ’--file’.
Hope that helps,
simon
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2021-08-18 13:40 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-08-16 8:08 Package variant defined in manifest not visible by Guix Philippe SWARTVAGHER
2021-08-16 12:04 ` Efraim Flashner
2021-08-16 14:34 ` Ricardo Wurmus
2021-08-17 7:17 ` zimoun
2021-08-18 8:57 ` Philippe SWARTVAGHER
2021-08-18 13:21 ` zimoun
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).