summaryrefslogtreecommitdiffstats
path: root/Documentation/TODO
diff options
context:
space:
mode:
Diffstat (limited to 'Documentation/TODO')
-rw-r--r--Documentation/TODO204
1 files changed, 204 insertions, 0 deletions
diff --git a/Documentation/TODO b/Documentation/TODO
new file mode 100644
index 0000000..e1ee613
--- /dev/null
+++ b/Documentation/TODO
@@ -0,0 +1,204 @@
+
+See also:
+ https://github.com/util-linux/util-linux/issues?q=is%3Aissue+is%3Aopen+label%3ATODO
+
+all
+---
+
+ - use gettext() for column names on output in libsmartcols based tools and
+ accept trantated as well as original names on command line (lsblk -o NAME,SIZE).
+ https://github.com/util-linux/util-linux/issues/1291
+
+tests
+-----
+ - add MacOS to GitHub Actions (.github/workflows/cibuild.yml). Note, we have used
+ Mac in Travis-CI (see .travis.yml).
+
+ - add Coverity to GitHub Actions (see for example .github/workflows/coverity.yml
+ in systemd repo).
+
+agetty
+------
+ - follow LOGIN_PLAIN_PROMPT from /etc/login.defs as alternative to --nohostname
+
+fstrim
+------
+ - "fstrim --fstab" uses root= from /proc/cmdline to get root FS when it's missing
+ in fstab file. This is fragile (due to missing root= or the root FS is not
+ accessible). The best seems to parse mountinfo and use mnt_table_get_root_fs()
+ as a fallback solution. https://github.com/util-linux/util-linux/issues/1266.
+
+script (lib/pty-session.c)
+--------------------------
+ - (!) add #ifdefs and optional code for non-signalfd() systems
+
+docs
+----
+ - use terminal hyperlinks (for example for --help)
+ try on terminal: printf 'For more details see \e]8;;man:fdisk(8)\e\\fdisk(8)\e]8;;\e\\.\n'
+ https://gist.github.com/egmontkob/eb114294efbcd5adb1944c9f3cb5feda
+
+rev
+---
+ - support huge input lines (for example read input by small fixed buffer
+ rather than try allocate all buffer for a whole line)
+ see: https://github.com/util-linux/util-linux/issues/972
+
+col
+---
+ - use unsigned sizes for columns and lines
+ - check for limits to avoid segfaults
+ - make it more robust
+ https://github.com/util-linux/util-linux/issues/749
+
+cal
+---
+ - support another --reforms, see for example freebsd version
+ https://github.com/freebsd/freebsd/blob/master/usr.bin/ncal/ncal.c#L72
+
+lscpu
+-----
+ - add "Boost/Turbo: true|false" based on /sys/devices/system/cpu/intel_pstate/no_turbo and
+ /sys/devices/system/cpu/cpufreq/boost
+
+ - add --freq output to visualise CPU use, see https://github.com/util-linux/util-linux/issues/1314
+
+ - read cpuid and uname information from file if --sysroot is specified, then
+ we can prepare regression tests completely independent on hw and architecture.
+
+nsenter(1)
+----------
+ - read the default UID and GID from the target process.
+ http://thread.gmane.org/gmane.linux.utilities.util-linux-ng/9553/focus=9585
+
+hwclock
+------
+ - use /var/lib/hwclock/drift to store hw-clock drift numbers.
+ - use /etc/adjtime as read-only for UTC/LOCAL information only
+ - the /var/lib/hwclock/drift should be implemented backwardly compatible,
+ it means use the file only if exists, otherwise follow /etc/adjtime
+ - see topic/hwclock-drift-file branch
+
+bash completion
+---------------
+- Optional argument handling requires user to press backspace to get
+ argument completion.
+- Comma separated value, e.g., --output 'value1,value2', are not
+ completed for users.
+
+libmount (mount/umount)
+-----------------------
+
+ - mnt_context_get_excode() does not return error messages from /sbin/[u]mount.<type>
+ external helpers. It is disadvantages in same cases (non-terminal programs).
+ The solution is to use pipe(), keep output from helper in memory and return it later
+ by mnt_context_get_excode() (or mnt_context_get_helper_output(), etc.). This feature
+ should be optional and disabled by default.
+ see: https://github.com/util-linux/util-linux/issues/1208
+
+ - add --onlyonce to force mount(8) to check if mountpoint is already used. Now
+ "already mounted" detection is used for --all only. The problem is if you
+ call "mount <mountpoint>" more than once for in fstab defined tmpfs (or network
+ filesystem etc.). In this case kernel does not return EBUSY, but a new instance
+ of the FS is created. https://github.com/util-linux/util-linux/issues/448
+ (... just idea, maybe wrong idea)
+
+ - Extend mount(8) command line for mount flags modification without remount:
+ "mount modify --clear noexec --set nodev,private,ro /mnt"
+ This functionality should be implemented by mount_setattr() syscall.
+
+partx
+-----
+
+ - support mapping by device-mapper if argv[0] is "kpartx" or --dm option is used.
+
+
+getopt
+------
+ It would be great if getopt could optionally ignore unknown options.
+ Currently, it outputs -- for every option it doesn't recognize but leaving the
+ option as it is could beneficial wrapper scripts which could then pass the
+ options they don't recognize as they are to the command they are wrapping.
+ https://github.com/util-linux/util-linux/issues/701
+
+docs
+----
+
+ - (!) use something better than gtk-doc for libmount and libblkid (doxygen?)
+
+ - (!) add API documentation to libuuid
+
+ - Improve line breaks in man pages and review markup
+
+
+login-utils:
+-----------
+
+ - consolidate newgrp(1)
+ * we have "su --group/--supp-group" to switch between groups, newgrp(1) in
+ util-linux and shadow-utils (and sg(1) alias in shadow-utils)
+ * the unique functionality provided by newgpr(1) is support for group
+ passwords [/etc/gshadow] -- do we really need this functionality?
+ * maybe we can mark group-passwords as deprecated, and replace sg(1) and
+ newgpr(1) with su(1) code. The another way is to ask for group password in
+ su --group too.
+ * note that shadow-utils newgpr(1) provides support for syslog and audit log.
+
+
+libsmartcols / column -t
+------------------------
+ - add column --table-header-color
+ - add support for border of table
+ * extend 'struct libscols_symbols', use box-drawing chars UTF8/ASCII
+ * add scols_table_enable_border()
+
+
+column(1):
+ - add "--output-width unlimited" and no call cols_table_set_termwidth() and
+ cols_table_set_termforce() in this case. See https://github.com/util-linux/util-linux/issues/1618
+
+
+libblkid
+--------
+
+ - extend ZFS proper to scan for more uberblocks if BLKID_SUBLKS_MAGIC flag is set.
+ This solution will make wipefs(8) more usable as ZFS is extremely variable with
+ additional root blocks locations. See https://github.com/util-linux/util-linux/issues/1228
+
+ - (!) add support for BitLocker Drive Encryption
+ https://github.com/util-linux/util-linux/issues/617
+ https://github.com/libyal/libbde/blob/master/documentation/BitLocker%20Drive%20Encryption%20(BDE)%20format.asciidoc
+
+ - (!) add support for dasd PT (used for example on s390)
+
+libfdisk
+--------
+
+ - add support for Apple Partition Map (see libblkid/src/partitions/mac.c)
+ http://en.wikipedia.org/wiki/Apple_Partition_Map
+
+ - add support for nested PT (e.g. hybrid MBR) to scripts
+ * add "nested-label:" block to sfdisk --dump
+ * add "nested-partitiontable" to sfdisk --JSON
+ * support nested labels parsing from dump
+ see https://github.com/util-linux/util-linux/issues/850
+
+misc
+----
+
+ - add mllockall() and SCHED_FIFO to hwclock,
+ see http://lkml.org/lkml/2008/10/12/132
+
+
+---------------
+exotic requests
+---------------
+
+ - add SELinux security contexts support to the 'ipcs' utility
+ http://bugzilla.redhat.com/show_bug.cgi?id=225342
+
+ Would be great to list the current system IPC Objects with their respective
+ security labels (where allowed) with something like 'ipcs -Z' - following the
+ way other tools reports those.
+
+