[Haskell-cafe] Re: ANN: System.FilePath 0.9

Simon Marlow simonmarhaskell at gmail.com
Fri Jul 21 11:23:41 EDT 2006


Neil Mitchell wrote:

> I have also added a canonicalPath function, support for spotting
> file\con as invalid and fixing it, support for \\?\ paths (if you
> don't know what they are, don't look it up, they are quite painful!)
> and a few very obscure corner cases which broke some of the
> properties.

I haven't been following this discussion very closely, but this caught my eye. 
Has anyone pointed out yet that eliminating ".." in a FilePath isn't valid in 
the presence of symbolic links?  I vaguely recall that this is why Krasimir's 
System.FilePath library doesn't include normalisation.  Normalisation that just 
changes separators, removes redundant separators and removes "." components is 
probably ok.

I don't really see the point of fullPathWith.  Isn't it just combine?

I think shortPath is on dodgy ground, given the difficulty with normalising 
FilePaths, and the fact that paths are not unique in the presence of symlinks.

The temporary file stuff is wrong - see System.IO.openTemporaryFile.  The only 
way to reliably create a temporary file is to open it at the same time, 
otherwise there's a race condition.

I have some other issues with naming, and the fact that the library mixes IO and 
non-IO functions.  We should avoid referring to $PATH as the "path", since we 
already have FilePath.  eg. spiltPath and getPath are talking about two very 
different things.  Where you use the term Filename, I think it should probably 
be FilePath.  I think we should consistently use a single term, preferably FilePath.

Cheers,
	Simon


More information about the Haskell-Cafe mailing list