- Use an enumerated value instead of separate flags for commands
- Look for a verb if no command flag is set
- Lookup the "xocontainer" value based on the command
- Document the new command verbs in the man-page
Details
- Reviewers
brooks allanjude rwatson - Group Reviewers
manpages - Commits
- rS324619: Switch procstat from subcommand flags to verbs
I checked that each of the new commands produces the same output as
their command flag counterparts, and that all of the tests passed.
Diff Detail
- Lint
Lint Warnings Severity Location Code Message Warning usr.bin/procstat/tests/procstat_test.sh: CHMOD1 Invalid Executable - Unit
No Test Coverage - Build Status
Buildable 12047 Build 12354: arc lint + arc unit
Event Timeline
Note to other reviewers. This change is at my suggestion and it's from the ideas page (https://wiki.freebsd.org/IdeasPage?highlight=%28procstat%29#Switch_procstat_from_subcommand_flags_to_verbs). The motivation to switch to subcommands comes from conflict after conflict with CheriBSD additions to procstat. It's also more natural for the various exclusive modes to be subcommands and the vastly larger namespace of whole words make more room for expansion vs single character flags.
usr.bin/procstat/procstat.1 | ||
---|---|---|
50 | I think the new command based versions should go first so people get used to them. | |
usr.bin/procstat/procstat.c | ||
121 | There should probably be a list of commands some where (even if that's just another command). | |
147 | How many of these we want is an interesting question. Some shortcuts seem useful, but too many cloud up the namespace. | |
399–400 | I think we want to reject -C on files to encourage migration to the new syntax. Maybe check in cmdopt_files()? | |
475 | style(9) permits long while bodies like this without braces, but I strongly prefer adding the braces to prevent future errors. |
- Move the new command verb usages above those of the command flags
- Add a list of commands to the usage message
- Add around additional loop bodies
- Move more command data to the main table, to be more inline with other sub-command implementations in the tree (geom, camcontrol, etc.)
- Add support for looking up plural and/or substring commands
- Use function pointers instead of enumerated values
- Reorder the switch statements for getopt(3)
usr.bin/procstat/procstat.1 | ||
---|---|---|
131 | I'm really not a fan of substring support. Shell integrated command line completion is a much better approach to this problem and doesn't pollute the namespace by making things like procstat a valid. |
usr.bin/procstat/procstat.1 | ||
---|---|---|
131 | Looking back on it I tend to agree. | |
usr.bin/procstat/procstat.c | ||
147 | I think that the common idioms can be kept: "bin" as in "/bin", "env" as in "/usr/bin/env", Questions regarding names that fall outside of the "idiom" glob:
|
Sorry for letting this sit so long. I'm finally getting back to this now that I can run FreeBSD 12 binaries on my build systems.
Other than the two comments above I think we're ready to go.
One thing that would be a good idea would be to add some tests using subcommands.
usr.bin/procstat/procstat.c | ||
---|---|---|
107 | the sizeof bits should use the nitems macro. | |
114 | I think the list should be sorted. |
This change should be reverted. This isn't an sh script.
IMO the decision to name atf-sh scripts .sh was a mistake. We should probably name them .atf or something, but that's beyond the scope of this change. We should also ensure they don't have execute permission in svn.
- Remove ``#!/bin/sh'' from the test script, reverting the previous change
- Unset the execute bit on the test script
Arg. I was ready to go, but ran into conflicts with a change to usage() by @ngie. I'm not sure how best to blend the result. If we add that expansion to the subcommands the result will got from unwieldy to incomprehensible (not to mention not fitting on an 80 column display).
In some ways the best answer might be to remove usage display of the old style command flags.
Rather, not fitting on a 45-row terminal. Width is fine, but the message was getting long already.
The command specific flags could be embedded in the sub-command flag list: ... -f [-C] | -i [-n] | -j [-n] | -k [-k] ...
Also, the -L sub-command flag can not be mixed with other sub-commands because of how flags are checked.
If embedding the flags is acceptable then that would reduce the line count of the new usage message, and add one one additional line to this diff's usage message.
Ack -- sorry! I think your changes are more suitable -- I was trying to clarify -L usage in previous commits, which involved clarifying how things needed to be called in general since it wasn't very clear.
usr.bin/procstat/procstat.1 | ||
---|---|---|
20 | Please run make manlint on the changes. | |
131 | I'm a bit curious about substring support -- will substrings be accidentally matched with the old specification mechanism if there's a program that starts with sig, etc? | |
145 | subcommand is the proper spelling. | |
193 | thread(s) seems like more a natural way to write this. | |
usr.bin/procstat/procstat.c | ||
107 | This relies on the sorting you did above -- should this be enforced a bit better via qsort or a relevant comment? | |
107–108 | Consolidate declarations on one line? | |
205–208 | Consolidate the int/size_t declarations on one line? | |
251 | Should this initialization be committed separately? | |
475 | getopt(3) supports not specifying an option string? I didn't know that! | |
555 | (picking a random item) should argv be const char *argv[] (as a hint to the compiler)? | |
usr.bin/procstat/procstat_files.c | ||
318 | (picking a random line) these bitwise AND/OR truth checks are actually a style(9) regression. It should be done using an idiom like: if ((procstat_opts & PS_OPT_CAPABILITIES) != 0) | |
usr.bin/procstat/tests/procstat_test.sh | ||
58 | It would be nice to add more tests beforehand to ensure that code doesn't regress in areas that aren't currently being tested after the change. |
- Update usage
- Correct the order of `cmd_table'
- Remove unnecessary hyphens
- Correct `manlint' errors
- Make suggested changes to `procstat.1'
- Consolidate some variable declarations
- Add additional `const' specifiers
- Change flag tests to comparisons