Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Clarify the description of "callPackage" #23

Open
WayneSherman opened this issue Feb 3, 2024 · 1 comment
Open

Clarify the description of "callPackage" #23

WayneSherman opened this issue Feb 3, 2024 · 1 comment

Comments

@WayneSherman
Copy link

With reference to:

nix-1p/README.md

Lines 578 to 580 in 1cf10d3

The `callPackage` function looks at the expected arguments (via
`builtins.functionArgs`) and passes the appropriate keys from the set in which
it is defined as the values for each corresponding argument.

Looking specifically at the phrase "the set in which it is defined" it isn't clear:

  1. What is "it"? (the callpackage function?)

  2. Which set is being described?

The callpackage function does not appear to be defined as part of a set in this example:

nix-1p/README.md

Lines 572 to 575 in 1cf10d3

{ pkgs ? import <nixpkgs> {} }:
let my-funky-program = pkgs.callPackage ./my-funky-program.nix {};
in # ... something happens with my-funky-program

@tazjin
Copy link
Owner

tazjin commented Feb 3, 2024

This is about the set from which you got the callPackage function, so in the case of pkgs.callPackage, "it" is that function itself, and the set is pkgs.

There are callPackage functions in multiple different sets (e.g. inside of pkgs.haskellPackages, pkgs.emacsPackages and so on) which all are capable of calling packages with the stuff defined in the set that they themselves are in.

Gonna think about a way to rephrase that ... ideas welcome!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants