On Mon, Jan 06, 2025 at 04:56:05PM -0500, Bernhard Voelker <invalid.nore...@gnu.org> wrote:
> Update of bug #46791 (group findutils): > > Status: Obsolete => None > Assigned to: jay => berny > Open/Closed: Closed => Open > > _______________________________________________________ > > Follow-up Comment #5: > > I see that adding such predicates is almost trivial, as the implementation > has > just to evaluate the already known value of 'struct stat' member 'rdev', and > we > already deal with major/minor numbers in -ls,-fls (although not in -printf). > > I also don't see that this would add much risks or bloat, so it may fit quite > well into find(1). > As such, I'm hereby re-opening this one for discussion. > > As for the user interface, I'd rather avoid messy parsing of the "x:y" > syntax, > and instead use the gear we already have for other numerical comparisons > (-inum, -gid, -uid, -size, -links) which additionally allows the comparison > with +N (COMP_GT), -N (COMP_LT) and exactly N (COMP_EQ). > > > # Search the device with number '1:3'. > $ find /dev -major 1 -minor 3 -exec ls -logd '{}' + > crw-rw-rw- 1 1, 3 Jan 5 23:14 /dev/null > > # Search all devices with major number <2. > $ find /dev -major -2 -exec ls -logd '{}' + > crw-rw-rw- 1 1, 7 Jan 5 23:14 /dev/full > crw-r--r-- 1 1, 11 Jan 5 23:14 /dev/kmsg > crw-r----- 1 1, 1 Jan 5 23:14 /dev/mem > crw-rw-rw- 1 1, 3 Jan 5 23:14 /dev/null > crw-r----- 1 1, 4 Jan 5 23:14 /dev/port > crw-rw-rw- 1 1, 8 Jan 5 23:14 /dev/random > crw-rw-rw- 1 1, 9 Jan 5 23:14 /dev/urandom > crw-rw-rw- 1 1, 5 Jan 5 23:14 /dev/zero > > # Search for all devices with minor number >300. > $ find /dev -type c -minor +300 -exec ls -logd '{}' + > crw-rw-r-- 1 189, 384 Jan 5 23:14 /dev/bus/usb/004/001 > crw-rw-r-- 1 189, 385 Jan 5 23:14 /dev/bus/usb/004/002 > crw-rw-r-- 1 189, 386 Jan 5 23:14 /dev/bus/usb/004/003 > > > I prototyped that as new predicate names '-major N -minor N', > but I'm not strictly opposed to use more descriptive yet longer names > like '-devmajor N -devminor N' or even '-rdev_major N -rdev_minor N' > to emphasize that this test is limited to char+block devices. > > I'm not sure one would rather like to see a combined '-rdev' test, as > e.g. one wouldn't really search with '-rdev 259' for '/dev/null', would one? > > Missing at this point: doc (man+texi), tests. > > FWIW: the suggested '-major N -minor N' even works for '0:0' devices > found in '/run/systemd/inaccessible/' on my system. > > Opinions, objections, ...? > > (file #56745) > Just a thought: Might it better to use , rather than : between major,minor device numbers, so as to be similar to ls output? It's easier to type (no shift key), and maybe prettier.