yes produces a stream of "y" chars, or other requested.
If Unixen have a pseudodevice for random numbers, why not useful streams like this too?
yes produces a stream of "y" chars, or other requested.
If Unixen have a pseudodevice for random numbers, why not useful streams like this too?
yes produces a stream of "y" chars, or other requested.
Precisely because of that. See yes(1) (which can repeat strings, not necessarily a single character - followed by newline).
It would be unpractical to have many devices, like /dev/repeatY to repeat Y, /dev/repeatO to repeat O etc.
Indeed, if you just want to get repeated zero bytes, consider /dev/zero (see zero(4))
BTW, on Linux, you could easily write your own kernel module implementing /dev/repeatY. But it is probably not worth the effort.
(so the why is also perhaps an historical reason)
Unixen have a pseudodevice for random numbers
These are probably much more difficult to get than a flow of constant bytes, and much more useful (and requires in practice some hardware support). See random(4) and this question. Read also myths about /dev/urandom
yes program can write arbitrary strings is a valid argument why there should be a yes program; not so much that there should not be a /dev/yes. It would be trivial to make a family of /dev/zero clones that provide arbitrary byte values.
– G-Man Says 'Reinstate Monica'
Apr 22 '18 at 03:36
/dev/repeat0x00, /dev/repeat0x01, .... /dev/repeat0xfe, /dev/repeat0xff? I feel that would be too much (especially in the previous century)
– Basile Starynkevitch
Apr 22 '18 at 06:02
mknod /dev/zero c 42 0 and mknod /dev/yes c 42 121 (at least as a matter of principle). The modification to the /dev/zero driver — and I estimate that it would be a one-line change — wouldn’t require the user / administrator to instantiate all 256 nodes in /dev. Alternatively, we could make /dev/repeat/0x00 through /dev/repeat/0xFF and then link to the ones we want. There’s lots of clutter under /dev/char and /dev/disk, and it doesn’t bother anybody.
– G-Man Says 'Reinstate Monica'
Apr 22 '18 at 15:24
yes helloworld to be done by a device, it could be more difficult. I really think the reason is mostly historical: in the 1980s, 256 device inodes was not unsignificant
– Basile Starynkevitch
Apr 22 '18 at 16:23
yes program — although I would raise the point that the produce-a-string-repeatedly functionality could just as easily have been added to echo or printf as an option.) And, as I said, (a) it’s a one-line change to the kernel code, and (b) you don’t need to create all 256 inodes; just create the ones you want. /bin/yes also takes an inode, and some disk space, too.
– G-Man Says 'Reinstate Monica'
Apr 22 '18 at 16:34
losetup for loop device for the hypothetical /dev/repeat. Loop Device makes a regular file accessible just like a block device. It uses the losetup command to to send the loop device the name of this file via ioctl. In the same way we could send the name of the string we wish to repeat to the repeat device
– Ankur S
Apr 22 '18 at 21:03
/dev/randoma device file and not just a program that runs the very same CSPRNG in application space and writes to standard output. Not Why isn't everything like this all in the kernel? which is obvious, but Why is this in the kernel at all? – JdeBP Apr 21 '18 at 17:07/dev/randomis not the best comparison;/dev/zerois the same asyesexcept it provides nulls instead ofybytes. – G-Man Says 'Reinstate Monica' Apr 22 '18 at 03:36