]> git.ipfire.org Git - thirdparty/systemd.git/blob - units/meson.build
network,udev: refuse .link and .network settings with no matches
[thirdparty/systemd.git] / units / meson.build
1 # SPDX-License-Identifier: LGPL-2.1+
2
3 units = [
4 ['basic.target', ''],
5 ['bluetooth.target', ''],
6 ['boot-complete.target', ''],
7 ['cryptsetup-pre.target', 'HAVE_LIBCRYPTSETUP'],
8 ['cryptsetup.target', 'HAVE_LIBCRYPTSETUP',
9 'sysinit.target.wants/'],
10 ['dev-hugepages.mount', '',
11 'sysinit.target.wants/'],
12 ['dev-mqueue.mount', '',
13 'sysinit.target.wants/'],
14 ['emergency.target', ''],
15 ['exit.target', ''],
16 ['final.target', ''],
17 ['getty.target', '',
18 'multi-user.target.wants/'],
19 ['getty-pre.target', ''],
20 ['graphical.target', '',
21 'runlevel5.target default.target'],
22 ['halt.target', ''],
23 ['hibernate.target', 'ENABLE_HIBERNATE'],
24 ['hybrid-sleep.target', 'ENABLE_HIBERNATE'],
25 ['suspend-then-hibernate.target', 'ENABLE_HIBERNATE'],
26 ['initrd-fs.target', ''],
27 ['initrd-root-device.target', ''],
28 ['initrd-root-fs.target', ''],
29 ['initrd-switch-root.target', ''],
30 ['initrd.target', ''],
31 ['kexec.target', ''],
32 ['ldconfig.service', 'ENABLE_LDCONFIG',
33 'sysinit.target.wants/'],
34 ['local-fs-pre.target', ''],
35 ['local-fs.target', ''],
36 ['machine.slice', 'ENABLE_MACHINED'],
37 ['machines.target', 'ENABLE_MACHINED'],
38 ['modprobe@.service', ''],
39 ['multi-user.target', '',
40 'runlevel2.target runlevel3.target runlevel4.target'],
41 ['network-online.target', ''],
42 ['network-pre.target', ''],
43 ['network.target', ''],
44 ['nss-lookup.target', ''],
45 ['nss-user-lookup.target', ''],
46 ['paths.target', ''],
47 ['poweroff.target', '',
48 'runlevel0.target'],
49 ['printer.target', ''],
50 ['proc-sys-fs-binfmt_misc.automount', 'ENABLE_BINFMT',
51 'sysinit.target.wants/'],
52 ['proc-sys-fs-binfmt_misc.mount', 'ENABLE_BINFMT'],
53 ['reboot.target', '',
54 'runlevel6.target ctrl-alt-del.target'],
55 ['remote-cryptsetup.target', 'HAVE_LIBCRYPTSETUP'],
56 ['remote-fs-pre.target', ''],
57 ['remote-fs.target', ''],
58 ['rescue.target', '',
59 'runlevel1.target'],
60 ['rpcbind.target', ''],
61 ['shutdown.target', ''],
62 ['sigpwr.target', ''],
63 ['sleep.target', ''],
64 ['slices.target', ''],
65 ['smartcard.target', ''],
66 ['sockets.target', ''],
67 ['sound.target', ''],
68 ['suspend.target', ''],
69 ['swap.target', ''],
70 ['sys-fs-fuse-connections.mount', '',
71 'sysinit.target.wants/'],
72 ['sys-kernel-config.mount', '',
73 'sysinit.target.wants/'],
74 ['sys-kernel-debug.mount', '',
75 'sysinit.target.wants/'],
76 ['sysinit.target', ''],
77 ['syslog.socket', ''],
78 ['system-systemd\\x2dcryptsetup.slice', 'HAVE_LIBCRYPTSETUP'],
79 ['system-update.target', ''],
80 ['system-update-pre.target', ''],
81 ['system-update-cleanup.service', ''],
82 ['systemd-ask-password-console.path', '',
83 'sysinit.target.wants/'],
84 ['systemd-ask-password-wall.path', '',
85 'multi-user.target.wants/'],
86 ['systemd-coredump.socket', 'ENABLE_COREDUMP',
87 'sockets.target.wants/'],
88 ['systemd-exit.service', ''],
89 ['systemd-initctl.socket', '',
90 'sockets.target.wants/'],
91 ['systemd-journal-gatewayd.socket', 'ENABLE_REMOTE HAVE_MICROHTTPD'],
92 ['systemd-journal-remote.socket', 'ENABLE_REMOTE HAVE_MICROHTTPD'],
93 ['systemd-journald-audit.socket', '',
94 'sockets.target.wants/'],
95 ['systemd-journald-dev-log.socket', '',
96 'sockets.target.wants/'],
97 ['systemd-journald.socket', '',
98 'sockets.target.wants/'],
99 ['systemd-userdbd.socket', 'ENABLE_USERDB',
100 'sockets.target.wants/'],
101 ['systemd-networkd.socket', 'ENABLE_NETWORKD'],
102 ['systemd-poweroff.service', ''],
103 ['systemd-reboot.service', ''],
104 ['systemd-rfkill.socket', 'ENABLE_RFKILL'],
105 ['systemd-tmpfiles-clean.timer', 'ENABLE_TMPFILES',
106 'timers.target.wants/'],
107 ['systemd-udevd-control.socket', '',
108 'sockets.target.wants/'],
109 ['systemd-udevd-kernel.socket', '',
110 'sockets.target.wants/'],
111 ['time-set.target', ''],
112 ['time-sync.target', ''],
113 ['timers.target', ''],
114 ['tmp.mount', '',
115 'local-fs.target.wants/'],
116 ['umount.target', ''],
117 ['user.slice', ''],
118 ['var-lib-machines.mount', 'ENABLE_MACHINED',
119 'remote-fs.target.wants/ machines.target.wants/'],
120 ]
121
122 in_units = [
123 ['debug-shell.service', ''],
124 ['emergency.service', ''],
125 ['initrd-cleanup.service', ''],
126 ['initrd-parse-etc.service', ''],
127 ['initrd-switch-root.service', ''],
128 ['initrd-udevadm-cleanup-db.service', ''],
129 ['kmod-static-nodes.service', 'HAVE_KMOD ENABLE_TMPFILES',
130 'sysinit.target.wants/'],
131 ['quotaon.service', 'ENABLE_QUOTACHECK'],
132 ['rc-local.service', 'HAVE_SYSV_COMPAT'],
133 ['rescue.service', ''],
134 ['systemd-ask-password-console.service', ''],
135 ['systemd-ask-password-wall.service', ''],
136 ['systemd-backlight@.service', 'ENABLE_BACKLIGHT'],
137 ['systemd-binfmt.service', 'ENABLE_BINFMT',
138 'sysinit.target.wants/'],
139 ['systemd-bless-boot.service', 'ENABLE_EFI HAVE_BLKID'],
140 ['systemd-boot-check-no-failures.service', ''],
141 ['systemd-boot-system-token.service', 'ENABLE_EFI',
142 'sysinit.target.wants/'],
143 ['systemd-coredump@.service', 'ENABLE_COREDUMP'],
144 ['systemd-pstore.service', 'ENABLE_PSTORE'],
145 ['systemd-firstboot.service', 'ENABLE_FIRSTBOOT',
146 'sysinit.target.wants/'],
147 ['systemd-fsck-root.service', ''],
148 ['systemd-fsck@.service', ''],
149 ['systemd-halt.service', ''],
150 ['systemd-hibernate-resume@.service', 'ENABLE_HIBERNATE'],
151 ['systemd-hibernate.service', 'ENABLE_HIBERNATE'],
152 ['systemd-hybrid-sleep.service', 'ENABLE_HIBERNATE'],
153 ['systemd-suspend-then-hibernate.service', 'ENABLE_HIBERNATE'],
154 ['systemd-hostnamed.service', 'ENABLE_HOSTNAMED',
155 'dbus-org.freedesktop.hostname1.service'],
156 ['systemd-hwdb-update.service', 'ENABLE_HWDB',
157 'sysinit.target.wants/'],
158 ['systemd-importd.service', 'ENABLE_IMPORTD',
159 'dbus-org.freedesktop.import1.service'],
160 ['systemd-initctl.service', ''],
161 ['systemd-journal-catalog-update.service', '',
162 'sysinit.target.wants/'],
163 ['systemd-journal-flush.service', '',
164 'sysinit.target.wants/'],
165 ['systemd-journal-gatewayd.service', 'ENABLE_REMOTE HAVE_MICROHTTPD'],
166 ['systemd-journal-remote.service', 'ENABLE_REMOTE HAVE_MICROHTTPD'],
167 ['systemd-journal-upload.service', 'ENABLE_REMOTE HAVE_LIBCURL'],
168 ['systemd-journald.service', '',
169 'sysinit.target.wants/'],
170 ['systemd-kexec.service', ''],
171 ['systemd-localed.service', 'ENABLE_LOCALED',
172 'dbus-org.freedesktop.locale1.service'],
173 ['systemd-logind.service', 'ENABLE_LOGIND',
174 'multi-user.target.wants/ dbus-org.freedesktop.login1.service'],
175 ['systemd-machine-id-commit.service', '',
176 'sysinit.target.wants/'],
177 ['systemd-machined.service', 'ENABLE_MACHINED',
178 'dbus-org.freedesktop.machine1.service'],
179 ['systemd-modules-load.service', 'HAVE_KMOD',
180 'sysinit.target.wants/'],
181 ['systemd-network-generator.service', 'ENABLE_NETWORKD'],
182 ['systemd-networkd.service', 'ENABLE_NETWORKD'],
183 ['systemd-networkd-wait-online.service', 'ENABLE_NETWORKD'],
184 ['systemd-nspawn@.service', ''],
185 ['systemd-portabled.service', 'ENABLE_PORTABLED',
186 'dbus-org.freedesktop.portable1.service'],
187 ['systemd-userdbd.service', 'ENABLE_USERDB'],
188 ['systemd-quotacheck.service', 'ENABLE_QUOTACHECK'],
189 ['systemd-random-seed.service', 'ENABLE_RANDOMSEED',
190 'sysinit.target.wants/'],
191 ['systemd-remount-fs.service', ''],
192 ['systemd-resolved.service', 'ENABLE_RESOLVE'],
193 ['systemd-rfkill.service', 'ENABLE_RFKILL'],
194 ['systemd-suspend.service', ''],
195 ['systemd-sysctl.service', '',
196 'sysinit.target.wants/'],
197 ['systemd-sysusers.service', 'ENABLE_SYSUSERS',
198 'sysinit.target.wants/'],
199 ['systemd-timedated.service', 'ENABLE_TIMEDATED',
200 'dbus-org.freedesktop.timedate1.service'],
201 ['systemd-timesyncd.service', 'ENABLE_TIMESYNCD'],
202 ['systemd-time-wait-sync.service', 'ENABLE_TIMESYNCD'],
203 ['systemd-tmpfiles-clean.service', 'ENABLE_TMPFILES'],
204 ['systemd-tmpfiles-setup-dev.service', 'ENABLE_TMPFILES',
205 'sysinit.target.wants/'],
206 ['systemd-tmpfiles-setup.service', 'ENABLE_TMPFILES',
207 'sysinit.target.wants/'],
208 ['systemd-udev-settle.service', ''],
209 ['systemd-udev-trigger.service', '',
210 'sysinit.target.wants/'],
211 ['systemd-udevd.service', '',
212 'sysinit.target.wants/'],
213 ['systemd-update-done.service', '',
214 'sysinit.target.wants/'],
215 ['systemd-update-utmp-runlevel.service', 'ENABLE_UTMP HAVE_SYSV_COMPAT',
216 'multi-user.target.wants/ graphical.target.wants/ rescue.target.wants/'],
217 ['systemd-update-utmp.service', 'ENABLE_UTMP',
218 'sysinit.target.wants/'],
219 ['systemd-user-sessions.service', 'HAVE_PAM',
220 'multi-user.target.wants/'],
221 ['systemd-vconsole-setup.service', 'ENABLE_VCONSOLE'],
222 ['systemd-volatile-root.service', ''],
223 ['user-runtime-dir@.service', ''],
224 ['user@.service', ''],
225 ]
226
227 m4_units = [
228 ['console-getty.service', ''],
229 ['container-getty@.service', ''],
230 ['getty@.service', '',
231 'autovt@.service '],
232 ['serial-getty@.service', ''],
233 ]
234
235 foreach tuple : in_units
236 file = tuple[0]
237
238 # we do this here because install_data does not accept custom_target output
239 conds = tuple[1].split(' ')
240 install = ((conds.get(0, '') == '' or conf.get(conds[0]) == 1) and
241 (conds.get(1, '') == '' or conf.get(conds[1]) == 1))
242
243 gen1 = configure_file(
244 input : file + '.in',
245 output : file + '.tmp',
246 configuration : substs)
247 gen2 = custom_target(
248 file,
249 input : gen1,
250 output : file,
251 command : [sed, '/^## /d', '@INPUT@'],
252 capture : true,
253 install : install,
254 install_dir : systemunitdir)
255
256 if install and tuple.length() > 2
257 foreach target : tuple[2].split()
258 meson.add_install_script('meson-add-wants.sh', systemunitdir, target, file)
259 endforeach
260 endif
261 endforeach
262
263 foreach tuple : m4_units
264 file = tuple[0]
265 input = tuple.get(3, file + '.m4')
266
267 # we do this here because install_data does not accept custom_target output
268 conds = tuple[1].split(' ')
269 install = ((conds.get(0, '') == '' or conf.get(conds[0]) == 1) and
270 (conds.get(1, '') == '' or conf.get(conds[1]) == 1))
271
272 custom_target(
273 file,
274 input : input,
275 output: file,
276 command : [meson_apply_m4, config_h, '@INPUT@'],
277 capture : true,
278 install : install,
279 install_dir : systemunitdir)
280
281 if tuple.length() > 2 and install
282 foreach target : tuple[2].split()
283 meson.add_install_script('meson-add-wants.sh', systemunitdir, target, file)
284 endforeach
285 endif
286 endforeach
287
288 foreach tuple : units
289 file = tuple[0]
290 input = tuple.get(3, file)
291
292 conds = tuple[1].split(' ')
293 install = ((conds.get(0, '') == '' or conf.get(conds[0]) == 1) and
294 (conds.get(1, '') == '' or conf.get(conds[1]) == 1))
295
296 if install
297 install_data(input,
298 install_dir : systemunitdir)
299
300 if tuple.length() > 2
301 foreach target : tuple[2].split()
302 meson.add_install_script(
303 'meson-add-wants.sh', systemunitdir, target, file)
304 endforeach
305 endif
306 endif
307 endforeach
308
309 install_data('user-.slice.d/10-defaults.conf',
310 install_dir : systemunitdir + '/user-.slice.d')
311
312 ############################################################
313
314 meson.add_install_script(meson_make_symlink,
315 join_paths(pkgsysconfdir, 'user'),
316 join_paths(sysconfdir, 'xdg/systemd/user'))
317 meson.add_install_script(meson_make_symlink,
318 join_paths(dbussystemservicedir, 'org.freedesktop.systemd1.service'),
319 join_paths(dbussessionservicedir, 'org.freedesktop.systemd1.service'))
320 if conf.get('HAVE_SYSV_COMPAT') == 1
321 foreach i : [1, 2, 3, 4, 5]
322 meson.add_install_script(
323 'sh', '-c',
324 mkdir_p
325 .format(join_paths(systemunitdir, 'runlevel@0@.target.wants'.format(i))))
326 endforeach
327 endif
328
329 subdir('user')