▲ | threePointFive 20 hours ago | |
> Newlines are now forbidden in filenames No. To quote that article > A bunch of C functions are now encouraged to report EILSEQ if the last component of a pathname to a file they are to create contains a newline This, yes, makes newlines in filenames effectively illegal on operating systems strictly conforming to the new POSIX standard. However, older systems will not be enforcing this and any operating system which exposes a syscall interface that does not require libc (such as Linux) is also not required to emit any errors. The only time even in the future that you should NOT worry about handling the newline case is on filesystems where it's is expressly forbidden, such as NTFS. | ||
▲ | machinestops 10 hours ago | parent [-] | |
Most utilities that create files are encouraged to error on newline filenames, which makes this effective illegality stronger. The post also discusses the future of this encouragement, which is turning it into a requirement. > However, older systems will not be enforcing this Eventually, newlines in filenames will go the way of /usr/xpg4/bin/sh. I'd like to note that up until this point, there hasn't (and isn't) been a fully POSIX compliant way to do many shell operations on newline containing filenames. They are already effectively unsupported, and the standard that adds support also discourages them from being created and used. The best way to handle them up until this point has been to not use sh(1). |