2 - mounts might take time, need to be executed asynchronously in a forked process?
4 - need gc for active jobs that nothing cares for
6 - need gc for units that are not referenced anymore
8 - refreshing of units (i.e. reload config files)
18 - hookup with battery status, suspend/resume
20 - add a job mode which shuts everything down but what is requested
22 - implement priv dropping
24 - allow to disable priv dropping for hook scripts from fragment
28 - implement mount/automount
30 - more process attributes: cpu affinity, cpu scheduling
32 - create session/pgroup for child processes? handle input on console properly? interactive fsck? interactive luks password?
36 - templating/instances
38 - verify fragment data after loading: refuse cycles on yourself, service units contradicting, more than one Start executable, ...
40 - automatically delete stale unix sockets
42 - .socket needs to be notified not only by .service state changes, but also unsuccessful start jobs
44 - we probably cannot use glibc's syslog() for logging, since it
45 presumably uses the logging socket in blocking mode which might
46 trigger a deadlock if syslog does not process the socket anymore
47 (maybe because it is restarted) and the socket buffer is full.
49 - in udev/mount if properties change we need to delete the old
50 settings and install the new settings. Deleting the old settings is
53 - ability to kill services? i.e. in contrast to stopping them, go directly
56 - restart-on-success, restart-on-failure, restart-on-abort