On 12/29/2017 06:38 AM, Karel Zak wrote: > On Sun, Dec 24, 2017 at 03:38:58PM -0500, J William Piggott wrote: >> >> Undocumented at this time, because it is a skeleton >> implementation. More debugging points are to be added after >> refactoring is complete, or ad hoc in the mean time. >> >> When fully implemented, enough time may have passed that the >> deprecated --debug could be used to replace --ul-debug. > > We use everywhere env.variables (e.g. HWCLOCK_DEBUG=). The macro > __UL_INIT_DEBUG() already provides all necessary functionality for > this purpose. > > It also allows to use human readable names for the masks or hex > numbers. See for example sys-utils/lsns.c or libsmartcols/src/init.c > for more complex usage. The human readable masks are optional and now > used by shared libs only, see for example "LIBSMARTCOLS_DEBUG=help > lsns". > > I'd like to keep things consistent and with no exceptions... > > IMHO "hwclock --verbose" is good idea for ordinary users and > "HWCLOCK_DEBUG=all hwclock" for developers. > > Karel > Karel, Sami sent me a patch doing exactly that. So I made time to digest debug.h; then I replied that I had reversed my position; I don't like debug.h for hwclock. I slept on it, and thought perhaps using an option instead of an env might be an acceptable compromise. So I figured out how to make debug.h use an option. Would it not be 'consistent' to say that commands use a debug option, and libs use a debug env? Consistent in this case isn't about the code, but the UI; correct? So doesn't consistent really translate to convenient for developers. That does not seem like a strong argument to me. A proportionate counter point could be that it is more convenient to enter 'hwclock -d all' then 'HWCLOCK_DEBUG=all hwclock'. I'm more interested in asking: how does using an env over an option benefit the code? I think it does not. Commands already have the code to parse options; adding more code to parse an env which serves no benefit to the application, IMO, is code bloat (and possibly a security risk). What I dislike the most is that debugging is very seldom used, yet debugging is initialized unconditionally whether it is wanted or not. This is completely unnecessary; an option does the job just as well without the added overhead. For time sensitive commands like hwclock this is just one more place for preemption to slip in. The one thing left that I really want to fix on hwclock it its precision. At least some of that problem is preemption. Using an option over an env eliminates that. My approach to debug.h adds a single line to hwclock.c. It eliminates the unconditional debugging initialization and the other unnecessary code. Regarding debug.h in general, is this an elegant solution? disk-utils/cfdisk.c:2691 fdisk_init_debug(0); scols_init_debug(0); cfdisk_init_debug(); CFDISK_DEBUG=all LIBFDISK_DEBUG=all LIBBLKID_DEBUG=all \ LIBSMARTCOLS_DEBUG=all LIBSMARTCOLS_DEBUG_PADDING=on cfdisk Is anyone else (other than e2fsprogs) using this approach? I also wonder if the way debug.h is using the env argument is a potential security whole? I didn't note any input sanitizing being done? In the end I just do not like the debug.h solution. It's a solution in search of a problem; a problem that commands do not have. I understand the concept for libraries, but I'm not convinced that it is the best solution for them either. Anyway, Sami has a patch queued that uses the env, if that is what you want. Please remove my name from his commit messages, as I object to using debug.h in hwclock. -- To unsubscribe from this list: send the line "unsubscribe util-linux" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html