> But the time to fix these problems come and gone - today it's much better to extend the spec.
Time to fix these problems using the existing API is now, because right now we have the attention of everyone on how to use the API properly. To the credit of some in this discussion, bugs are already being fixed in Gnome (as I already mentioned in another comment). I also have bugs to fix in my own code - there is no denying that :-(
In general, I agree with you on extending the spec. But, before the spec gets extended officially, we need to make sure that _every_ POSIX compliant file system implements it that way. Otherwise, apps depending on this new spec will not be reliable until that's the case. So, can we actually make sure that's the case? I very much doubt it. There is a lot of different systems out there that are implementing POSIX, some of them very old. Auditing all of them and then fixing them may be harder than fixing the applications.
Posted Mar 16, 2009 0:05 UTC (Mon) by khim (subscriber, #9252)
[Link]
Linux extends POSIX all the time. New syscalls, new features (things
like "According to the standard specification (e.g., POSIX.1-2001),
sync() schedules the writes, but may return before the actual writing is
done. However, since version 1.3.20 Linux does actually wait."), etc.
If application wants to use such "extended feature" - it can do this, if
not - it can use POSIX-approved features only.
As for old POSIX systems... it's up to application writers again. And
you can be pretty sure A LOT OF them don't give a damn about POSIX
compliance. They are starting to consider Linux as third platfrom for their
products (first two are obviously Windows and MacOS in that order), but if
you'll try to talk to them about POSIX it'll just lead to the removal of
Linux from list of supported platforms. Support of many distributions is
already hard enough, support of some exotic filesystems "we'll think about
it but don't hold your breath...", support for old exotic POSIX systems...
fuggetaboudit!
Now - the interesting question is: do we welcome such selfish developers
or not? This is hard question because the answer "no, they should play by
our rules" will just lead to exodus of users - because they need these
applications and WINE is not a good long-term solution...