nixpkgs/pkgs/by-name
Sigmanificient a4dac9efcb criterion: migrate to by-name
fix AndersonTorres requested changes

Co-authored-by: Anderson Torres <torres.anderson.85@protonmail.com>
2024-05-05 18:03:14 +02:00
..
_0/_0xpropo
_4 4d-minesweeper: fix package name 2024-04-25 13:52:41 +02:00
_6/_64gram
_9/_9base
a4/a4
a5/a52dec
aa
ab
ac
ad
ae treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
af
ag/ags treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
ai airlift: 0.3.1 -> 0.4.0 2024-04-27 05:11:42 +00:00
al Merge master into staging-next 2024-04-26 18:00:58 +00:00
am am2rlauncher: wrapGAppsHook -> wrapGAppsHook3 2024-04-27 10:32:44 +02:00
an Merge master into staging-next 2024-05-01 18:01:22 +00:00
ao/aocl-utils
ap Merge branch 'master' into staging-next 2024-05-02 09:05:49 +02:00
ar Merge pull request #308269 from liquidovski/patch-10 2024-05-02 13:04:55 +02:00
as ast-grep: 0.21.1 -> 0.21.3 2024-05-03 08:13:05 +02:00
at athens: 0.13.3 -> 0.14.0 2024-05-02 07:13:06 +00:00
au audiness: 0.3.2 -> 0.4.0 2024-04-29 08:48:20 +02:00
av
aw
ax ax25ms: init at unstable-2024-04-28 2024-05-02 12:43:07 +00:00
ay Merge master into staging-next 2024-04-29 12:01:15 +00:00
ba
bc/bc-ur
be bee: 2.0.0 -> 2.0.1 2024-04-25 12:28:14 +00:00
bi Merge branch 'master' into staging-next 2024-04-28 17:33:27 +02:00
bk/bk
bl blanket: avoid double wrapping 2024-05-02 12:43:33 +02:00
bm/bmake
bn/bngblaster bngblaster: 0.8.47 -> 0.8.49 2024-04-27 10:17:53 +00:00
bo
bp/bpftop bpftop: 0.4.1 -> 0.4.2 2024-04-27 12:24:01 +00:00
br Merge #306057: init broom at 0.3.0 2024-05-02 13:29:16 +00:00
bs
bt
bu Merge master into staging-next 2024-05-02 18:01:05 +00:00
by
c2
c-
ca cargo-autoinherit: 0.1.4 -> 0.1.5 2024-04-30 12:25:24 +00:00
cb
cc
cd
ce cent: init at 1.3.3 2024-05-02 20:10:30 +02:00
cg
ch chemacs2: init at 0-unstable-2023-01-20 2024-04-29 18:05:05 -03:00
ci
cl Merge master into staging-next 2024-05-02 18:01:05 +00:00
cm
cn/cntb
co Merge #306080: staging-next 2024-04-22 2024-05-03 17:36:08 +02:00
cp treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
cr criterion: migrate to by-name 2024-05-05 18:03:14 +02:00
cs Merge pull request #308630 from r-ryantm/auto-update/csvkit 2024-05-03 18:49:46 +00:00
ct/ctx
cu Merge pull request #306317 from selfuryon/chore/cue-version-fix 2024-05-01 00:08:32 +08:00
cv/cvemap
cy
cz/czkawka
da
db/dbus-cpp
dc/dc3dd
dd
de dep-scan: 5.3.3 -> 5.3.4 2024-05-03 02:18:12 +00:00
dg/dgoss
dh/dhcpig
di Merge pull request #308709 from bnapolitano/master 2024-05-03 21:00:23 +02:00
dj/djent
dm dmarc-report-converter: 0.7.1 -> 0.7.2 2024-05-01 06:14:05 +00:00
dn/dns2tcp
do treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
dp dps8m: init at 3.0.1 2024-05-02 15:34:02 +00:00
dr/drone-scp
ds
dt
du Merge master into staging-next 2024-05-03 12:01:32 +00:00
dv/dvb-apps
dx dxvk: switch to Win32 thread model and cleanups 2024-04-25 01:36:01 -04:00
dy
ea
eb
ec
ed treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
ei
ek/eksctl eksctl: 0.175.0 -> 0.176.0 2024-04-25 12:40:51 +00:00
el
em
en
ep/epub-thumbnailer
er
es
et
eu
ew/eww Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
ex
ez/eza eza: 0.18.13 -> 0.18.14 2024-05-02 08:28:05 +02:00
fa fastfetch: 2.10.2 -> 2.11.0 2024-05-02 11:41:46 +01:00
fb/fbset
fc
fe feather: 2.6.5 -> 2.6.7 2024-04-29 22:18:31 +02:00
ff fflogs: init at 8.3.42 2024-04-25 23:33:33 +01:00
fg/fgqcanvas
fi firefoxpwa: 2.11.1 -> 2.12.0 2024-05-02 07:03:47 +05:30
fl Merge pull request #291763 from grahamnorris/add-flashgbx 2024-05-03 00:37:27 +02:00
fm fmtoy: 0.0.0-unstable-2023-05-21 -> 0-unstable-2024-04-18 2024-04-27 04:00:17 +02:00
fn/fnott fnott: 1.4.1 -> 1.5.0 2024-04-27 09:18:59 +00:00
fo Merge master into staging-next 2024-05-03 00:02:39 +00:00
fr treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
fs
fu/fuchsia-cursor
fv
fw/fwupd Merge pull request #308879 from r-vdp/fwupd 2024-05-04 00:07:46 +02:00
fy/fypp
fz fzf-make: 0.28.0 -> 0.30.0 2024-05-03 02:26:40 +00:00
g3/g3kb-switch
ga Merge pull request #308761 from r-ryantm/auto-update/gamescope 2024-05-03 13:00:29 +03:00
gb/gbar
gc
ge Merge branch 'master' into staging-next 2024-05-02 09:05:49 +02:00
gf
gg/gg
gh ghciwatch: 0.5.10 -> 0.5.11 2024-05-02 12:59:06 +00:00
gi gitversion: init at 5.12.0 2024-05-03 23:14:10 +03:00
gl
gm treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
gn
go Merge pull request #302110 from mibmo/pkg/gophish 2024-04-30 15:38:29 +02:00
gp Merge master into staging-next 2024-05-02 18:01:05 +00:00
gr grype: 0.77.1 -> 0.77.2 2024-05-03 01:22:31 +02:00
gt Merge branch 'master' into staging-next 2024-04-27 10:30:24 +02:00
gu Merge pull request #308788 from r-ryantm/auto-update/guile-lzlib 2024-05-03 20:17:56 +02:00
gv/gvisor maintainers: remove andrew-d as a maintainer 2024-04-27 14:05:07 -04:00
gx/gxml
h8/h8mail
ha hamtransfer: init at unstable-2024-04-05 2024-04-29 21:25:13 +00:00
hb/hb-honeypot hb-honeypot: init at 0-unstable-2024-02-13 2024-04-25 09:40:34 +02:00
hd/hdrop
he
hi hieroglyphic: init at 1.0.1 2024-05-02 23:43:28 +02:00
hj/hjson-go
ho hoppscotch: 24.3.1-2 -> 24.3.2-1 2024-05-01 11:25:57 +02:00
ht htb-toolkit: unstable-2024-01-17 -> 0-unstable-2024-04-22 2024-04-25 10:35:24 +02:00
hu hugo: 0.125.4 -> 0.125.5 2024-05-02 09:54:02 +00:00
hy hyprcursor: 0.1.7 -> 0.1.8 2024-04-30 23:33:23 +00:00
i2/i2p
i3
ia
ic icloudpd: 1.17.4 -> 1.17.5 2024-04-29 17:41:16 +01:00
id
if/ifrextractor-rs
ig
ii
im
in inotify-info: unstable-2024-01-05 -> 0.0.1 (#308759) 2024-05-03 19:01:53 +00:00
io/ioq3-scion
ip
ir treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
is/iscc
it
ja jazz2: drop graphicsLibrary, switch to SDL2 by default 2024-04-29 21:53:01 +02:00
jd/jdt-language-server
je jetbrains-toolbox: 2.2.3.20090 -> 2.3.1.31116 2024-05-01 06:36:06 +00:00
ji jikken: init at 0.7.1 (#305885) 2024-05-02 17:22:14 +00:00
jj/jj
jn
jo
jr/jrl-cmakemodules
js/jsoncons jsoncons: 0.174.0 -> 0.175.0 2024-05-03 02:34:12 +00:00
jt/jtdx jtdx: init at unstable-2022-03-01 2024-05-02 15:33:08 +00:00
ju
ka kanidm: add adamcstephens as maintainer 2024-05-01 09:47:46 -04:00
kc kcl-cli: 0.8.6 -> 0.8.7 2024-05-02 07:26:33 +00:00
kd kdotool: init at 0.2.1 2024-04-30 01:14:19 +08:00
ke keydb: move to finalAttrs, cleanup 2024-04-29 19:07:40 +05:30
kg/kgeotag
ki ki: init at 0-unstable-2023-11-08 2024-04-26 00:50:16 +01:00
kl/klog-time-tracker
km
kn/knossosnet
ko Merge master into staging-next 2024-05-01 18:01:22 +00:00
kp/kplex
kr
ks
kt
ku
kx/kxstitch
ky/kyverno-chainsaw
la Merge master into staging-next 2024-05-01 18:01:22 +00:00
lb lbreakouthd: 1.1.7 -> 1.1.8 2024-05-03 10:25:50 +00:00
lc lc0: init at 0.30.0 2024-05-02 17:25:19 +02:00
ld/ldproxy
le Merge pull request #306702 from marsam/goodbye 2024-04-25 13:51:10 +02:00
li Merge master into staging-next 2024-05-03 00:02:39 +00:00
ll llama-cpp: 2746 -> 2781 2024-05-03 10:06:47 +00:00
lm/lmstudio lmstudio: 0.2.18 -> 0.2.20 2024-04-27 23:27:09 +00:00
ln/lngen
lo Merge branch 'master' into staging-next 2024-04-30 13:24:52 +02:00
lp lprint: remove self from maintainer list 2024-04-28 19:48:36 +02:00
ls
lt/ltris
lu Merge pull request #306907 from rohanssrao/master 2024-05-04 08:16:21 +10:00
lw/lwgrp
lx Merge pull request #306002 from oo-infty/init-lx-music-desktop 2024-04-28 13:43:03 +00:00
lz
m2
ma maltego: 4.6.0 -> 4.7.0 2024-05-01 04:26:37 +00:00
mb
mc Merge master into staging-next 2024-04-30 12:01:12 +00:00
md
me Merge master into staging-next 2024-05-03 00:02:39 +00:00
mf
mg Merge branch 'master' into staging-next 2024-04-28 04:02:14 +02:00
mi Merge pull request #307938 from r-ryantm/auto-update/minijinja 2024-05-02 09:45:30 +02:00
mk
ml/mlx42
mo mold: 2.30.0 -> 2.31.0 2024-05-03 19:35:47 +03:00
mp
mq
ms
mu
my treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
n2/n2
na Merge pull request #307282 from r-ryantm/auto-update/namespace-cli 2024-05-02 09:30:54 +02:00
nb/nbtscan
nc
nd/ndstrim
ne Merge branch 'master' into staging-next 2024-04-27 05:44:19 +02:00
nf nf-test: init at 0.8.4 (#308756) 2024-05-03 14:45:50 +00:00
ng nginx-sso: move to 'pkgs/by-name' 2024-04-27 23:11:38 +10:00
nh nh: 3.5.13 -> 3.5.14 2024-05-03 10:59:56 +00:00
ni Merge pull request #308108 from r-ryantm/auto-update/nickel 2024-05-01 10:38:04 +02:00
nl
nm/nmap-parse
nn/nncp
no Merge pull request #308047 from pbsds/fix-replace-fail 2024-05-02 00:05:08 +02:00
np
nr
ns
nt/ntfs2btrfs
nu
nv
nw treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
nx/nxengine-evo nxengine-evo.assets: 2.6.4 -> 2.6.5-1 2024-05-01 23:59:19 -03:00
oa
ob
oc ocenaudio: 3.13.5 -> 3.13.8 2024-05-01 23:35:15 +00:00
oe/oelint-adv oelint-adv: 5.3.0 -> 5.3.1 2024-04-28 05:44:45 +00:00
of offat: 0.17.2 -> 0.17.3 2024-04-30 20:34:58 +00:00
oh/oh-my-fish
oi
ol/olvid Merge master into staging-next 2024-04-29 00:02:23 +00:00
om omnictl: 0.33.2 -> 0.34.0 2024-04-26 11:12:58 +00:00
on treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
op Merge pull request #307836 from jopejoe1/openasar/split-out 2024-05-03 19:47:18 +03:00
or Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
os
ot oterm: 0.2.6 -> 0.2.7 2024-04-25 20:19:59 +00:00
ou
ov
ow
pa Merge master into staging-next 2024-05-02 18:01:05 +00:00
pd
pe Merge pull request #305596 from raspher/peergos-update 2024-04-29 10:51:53 -03:00
pf/pfft
pg pgmoneta: 0.11.0 -> 0.11.1 2024-04-30 16:42:31 +00:00
ph Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
pi pinact: 0.1.2 -> 0.1.3 2024-05-01 14:44:03 +09:00
pk
pl Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
pm
pn
po Merge master into staging-next 2024-05-02 12:01:36 +00:00
pp/ppsspp
pq
pr protoc-gen-js: Update hash after bazel_6 upgrade 2024-04-26 20:57:54 +02:00
pt
pu pupdate: 3.10.1 -> 3.10.2 2024-05-03 13:51:01 +00:00
pv/pvsneslib
pw Merge master into staging-next 2024-04-29 12:01:15 +00:00
px/pxder
py pyprland: add johnrtitor as maintainer 2024-05-02 00:28:42 +05:30
pz/pzip
qa/qadwaitadecorations
qc/qcm
qd/qdirstat
qg/qgrep
qp/qpoases
qr qrtool: 0.10.9 -> 0.10.10 2024-04-28 00:59:34 +00:00
qs
qt/qtractor
qu Merge branch 'master' into staging-next 2024-04-28 05:11:43 +02:00
r1/r10k
ra
rc
rd/rdwatool
re regal: 0.21.2 -> 0.21.3 2024-05-02 19:28:01 +00:00
ri Merge pull request #291392 from pkulak/create-filtile 2024-05-02 13:00:07 +02:00
rk
rl/rl_json
rm Merge master into staging-next 2024-05-03 06:01:07 +00:00
rn/rnd-name
ro Merge branch 'master' into staging-next 2024-04-30 13:24:52 +02:00
rp/rpcs3 rpcs3: 0.0.31-16364-dff7352e2 -> 0.0.31-16377-08c3a38b6 2024-04-25 16:31:57 +00:00
rq/rqbit treewide: adopt orphaned packages 2024-04-28 20:43:06 +02:00
rs
rt rtaudio_6: Modernise 2024-04-29 15:59:35 +02:00
ru
rw/rwpspread rwpspread: 0.2.5 -> 0.2.6 (#305629) 2024-05-03 19:11:59 +00:00
ry
s3
sa Merge master into staging-next 2024-05-02 18:01:05 +00:00
sb/sbom-utility
sc Merge pull request #308004 from TomaSajt/scotch 2024-05-01 21:18:49 +08:00
sd SDL2_mixer: migrate to by-name 2024-05-03 00:04:32 -03:00
se sendme: 0.5.0 -> 0.6.0 2024-04-30 04:44:30 +00:00
sg/sgfutils
sh shopware-cli: 0.4.40 -> 0.4.42 2024-05-03 16:58:47 +00:00
si silverbullet: 0.7.6 -> 0.7.7 2024-04-30 15:28:08 +02:00
sk Merge pull request #277052 from YvesStraten/init-skimpdf 2024-04-27 01:32:20 -04:00
sl Merge pull request #308200 from javaes/add_slumber_to_pkgs 2024-05-03 17:56:28 +08:00
sm treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
sn Merge branch 'master' into staging-next 2024-04-30 13:24:52 +02:00
so soupault: 4.9.0 → 4.10.0 2024-04-26 15:26:55 +02:00
sp Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
sq treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
sr
ss
st stats: 2.10.10 -> 2.10.11 2024-05-02 19:53:32 +03:00
su surrealdb: 1.3.1 → 1.4.2 2024-05-01 15:59:31 +04:00
sv
sw Merge branch 'master' into staging-next 2024-05-01 09:37:47 +03:00
sx
sy Merge pull request #308662 from r-ryantm/auto-update/systemctl-tui 2024-05-03 13:19:01 +02:00
t-/t-rex
ta taler-merchant: 0.10.1 -> 0.10.2 2024-04-28 05:40:07 +02:00
tc/tcsh
td Merge pull request #307698 from malt3/tdnf-init 2024-05-02 14:47:33 +02:00
te Merge branch 'master' into staging-next 2024-05-01 10:51:08 +02:00
tg/tgpt
th treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
ti Merge master into staging-next 2024-05-02 18:01:05 +00:00
tk
tl tlrc: 1.9.1 -> 1.9.2 2024-04-29 17:20:11 +02:00
tm/tmuxifier
to tootik: 0.10.2 -> 0.10.3 2024-04-27 14:55:47 +00:00
tp
tr Merge master into staging-next 2024-05-02 18:01:05 +00:00
tt/ttop
tu tuifimanager: 4.0.0 -> 4.0.5 2024-04-28 11:03:02 -04:00
tw/twitch-dl twitch-dl: harden and add maintainer pbsds 2024-04-30 19:09:42 +02:00
tx/txr
ty Merge pull request #308547 from r-ryantm/auto-update/typos-lsp 2024-05-03 13:20:38 +02:00
uc ucblogo: wrapGAppsHook -> wrapGAppsHook3 2024-05-02 21:58:10 +02:00
ud
ue ueviewer: init at 0-unstable-2024-02-23 2024-04-29 16:08:25 +02:00
ug
uh/uhttpmock_1_0
ui uiua: fix darwin build 2024-04-29 12:08:06 +02:00
um/umpire
un Merge master into staging-next 2024-05-01 18:01:22 +00:00
up ups: init at 0.2.1 2024-05-02 23:43:18 +02:00
us/usql
ut
uu/uuu
uv/uv uv: add GaetanLepage as maintainer 2024-04-27 20:30:06 +02:00
uw/uwhoisd
ux/uxn
va Merge master into staging-next 2024-05-02 12:01:36 +00:00
vc vcpkg: 2024.03.25 -> 2024.04.26 2024-05-01 21:35:06 +00:00
vd/vdhcoapp vdhcoapp: init at 2.0.19 2024-05-02 10:17:33 +02:00
ve vesktop: 1.5.1 -> 1.5.2 2024-05-01 23:13:48 +02:00
vg/vgm2x
vi vis: migrate to by-name 2024-05-02 13:26:14 +04:00
vl treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
vo/voidmap
vu
vv/vvvvvv
wa Merge pull request #307576 from r-ryantm/auto-update/warp-terminal 2024-05-03 19:18:47 +02:00
wb/wb32-dfu-updater
we
wh whistle: 2.9.68 -> 2.9.70 2024-05-01 08:42:55 +00:00
wi Merge pull request #304227 from pinpox/init-wireviz 2024-05-01 00:52:50 +02:00
wl wl-clip-persist: 0.4.0 -> 0.4.1 2024-04-30 05:02:22 +00:00
wo workout-tracker: 0.14.1 -> 0.14.2 2024-04-29 02:38:07 +00:00
wp wpaperd: 0.3.0 -> 1.0.1 & mv to by-name 2024-05-03 12:36:30 +12:00
ws
wt
wy/wyoming-satellite
x1/x16
x5/x509-limbo
xa/xarcan
xc Merge branch 'master' into staging-next 2024-04-28 17:33:27 +02:00
xd
xe Merge branch 'master' into staging-next 2024-04-28 04:02:14 +02:00
xf/xfs-undelete
xh/xhosts nss-xhosts: init at unstable-2023-12-30 2024-05-02 15:20:30 +00:00
xi treewide: adopt orphaned packages 2024-04-28 20:43:06 +02:00
xl/xlights Merge pull request #308102 from kashw2/xlights 2024-05-01 00:29:28 +02:00
xm
xn/xnlinkfinder xnlinkfinder: init at 6.0 2024-05-02 20:01:14 +02:00
xo
xp xpointerbarrier: 20.07 -> 23.08 2024-04-27 17:38:44 +00:00
xr/xr-hardware
xs
xw/xwayland-run
ya yamlscript: 0.1.57 -> 0.1.58 2024-04-28 09:25:20 +00:00
yc/ycmd
ye treewide: wrapGAppsHook → wrapGAppsHook3 2024-04-27 02:23:22 +02:00
yg/yggdrasil
yj/yj
yo
ys/ysfx
yt
yu
za zapzap: 5.3 -> 5.3.1 2024-04-29 17:36:28 +00:00
zb/zbus-xmlgen
zc/zcfan
ze zed-editor: 0.132.4 -> 0.133.5 2024-05-01 19:26:18 +02:00
zi
zl/zluda
zo/zola
zp
zs
zu/zug
zw/zwave-js-server
zx zxtune: 5056 -> 5060 2024-04-26 20:07:09 +00:00
README.md

Name-based package directories

The structure of this directory maps almost directly to top-level package attributes. Add new top-level packages to Nixpkgs using this mechanism whenever possible.

Packages found in the name-based structure are automatically included, without needing to be added to all-packages.nix. However if the implicit attribute defaults need to be changed for a package, this must still be declared in all-packages.nix.

Example

The top-level package pkgs.some-package may be declared by setting up this file structure:

pkgs
└── by-name
   ├── so
   ┊  ├── some-package
      ┊  └── package.nix

Where some-package is the package name and so is the lowercased 2-letter prefix of the package name.

The package.nix may look like this:

# A function taking an attribute set as an argument
{
  # Get access to top-level attributes for use as dependencies
  lib,
  stdenv,
  libbar,

  # Make this derivation configurable using `.override { enableBar = true }`
  enableBar ? false,
}:

# The return value must be a derivation
stdenv.mkDerivation {
  # ...
  buildInputs =
    lib.optional enableBar libbar;
}

You can also split up the package definition into more files in the same directory if necessary.

Once defined, the package can be built from the Nixpkgs root directory using:

nix-build -A some-package

See the general package conventions for more information on package definitions.

Changing implicit attribute defaults

The above expression is called using these arguments by default:

{
  lib = pkgs.lib;
  stdenv = pkgs.stdenv;
  libbar = pkgs.libbar;
}

But the package might need pkgs.libbar_2 instead. While the function could be changed to take libbar_2 directly as an argument, this would change the .override interface, breaking code like .override { libbar = ...; }. So instead it is preferable to use the same generic parameter name libbar and override its value in pkgs/top-level/all-packages.nix:

{
  libfoo = callPackage ../by-name/so/some-package/package.nix {
    libbar = libbar_2;
  };
}

Manual migration guidelines

Most packages are still defined in all-packages.nix and the category hierarchy. Please hold off migrating your maintained packages to this directory.

  1. An automated migration for the majority of packages is being worked on. In order to save on contributor and reviewer time, packages should only be migrated manually afterwards if they couldn't be migrated automatically.

  2. Manual migrations should only be lightly encouraged if the relevant code is being worked on anyways. For example with a package update or refactoring.

  3. Manual migrations should not remove definitions from all-packages.nix with custom arguments. That is a backwards-incompatible change because it changes the .override interface. Such packages may still be moved to pkgs/by-name however, while keeping the definition in all-packages.nix. See also changing implicit attribute defaults.

Limitations

There's some limitations as to which packages can be defined using this structure:

  • Only packages defined using pkgs.callPackage. This excludes packages defined using pkgs.python3Packages.callPackage ....

    Instead:

    • Either change the package definition to work with pkgs.callPackage.
    • Or use the category hierarchy.
  • Only top-level packages. This excludes packages for other package sets like pkgs.pythonPackages.*.

    Refer to the definition and documentation of the respective package set to figure out how such packages can be declared.

Validation

CI performs certain checks on the pkgs/by-name structure. This is done using the nixpkgs-check-by-name tool.

You can locally emulate the CI check using

$ ./maintainers/scripts/check-by-name.sh master

See here for more info.

Recommendation for new packages with multiple versions

These checks of the pkgs/by-name structure can cause problems in combination:

  1. New top-level packages using callPackage must be defined via pkgs/by-name.
  2. Packages in pkgs/by-name cannot refer to files outside their own directory.

This means that outside pkgs/by-name, multiple already-present top-level packages can refer to some common file. If you open a PR to another instance of such a package, CI will fail check 1, but if you try to move the package to pkgs/by-name, it will fail check 2.

This is often the case for packages with multiple versions, such as

{
  foo_1 = callPackage ../tools/foo/1.nix { };
  foo_2 = callPackage ../tools/foo/2.nix { };
}

The best way to resolve this is to not use callPackage directly, such that check 1 doesn't trigger. This can be done by using inherit on a local package set:

{
  inherit
    ({
      foo_1 = callPackage ../tools/foo/1.nix { };
      foo_2 = callPackage ../tools/foo/2.nix { };
    })
    foo_1
    foo_2
    ;
}

While this may seem pointless, this can in fact help with future package set refactorings, because it establishes a clear connection between related attributes.

Further possible refactorings

This is not required, but the above solution also allows refactoring the definitions into a separate file:

{
  inherit (import ../tools/foo pkgs)
    foo_1 foo_2;
}
# pkgs/tools/foo/default.nix
pkgs: {
  foo_1 = callPackage ./1.nix { };
  foo_2 = callPackage ./2.nix { };
}

Alternatively using callPackages if callPackage isn't used underneath and you want the same .override arguments for all attributes:

{
  inherit (callPackages ../tools/foo { })
    foo_1 foo_2;
}
# pkgs/tools/foo/default.nix
{
  stdenv
}: {
  foo_1 = stdenv.mkDerivation { /* ... */ };
  foo_2 = stdenv.mkDerivation { /* ... */ };
}

Exposing the package set

This is not required, but the above solution also allows exposing the package set as an attribute:

{
  foo-versions = import ../tools/foo pkgs;
  # Or using callPackages
  # foo-versions = callPackages ../tools/foo { };

  inherit (foo-versions) foo_1 foo_2;
}