System.FilePath survey

Andrew Pimlott andrew at pimlott.net
Mon Feb 6 14:36:50 EST 2006


On Mon, Feb 06, 2006 at 03:36:17PM +0000, Simon Marlow wrote:
> The reason we can't just go right ahead and do The Right Thing (i.e. 
> introduce a new ADT for FilePaths) is because it touches so much other 
> stuff, including stuff that also needs revising, so it doesn't feel 
> right to just fix the FilePath library.
> 
> Experience with GHC releases has left me with the opinion that it's 
> better to group breaking changes together rather than dribble them out - 
> people only have to modify their code once, and conditional compilation 
> gets fewer cases.
> 
> So I'm of the opinion that introducing an ADT for FilePaths is something 
> that should wait until the I/O library is revised.  In the meantime, we 
> should include a String-based Data.FilePath library in Haskell'.  It's 
> not as elegant, but it's terribly practical, and that's one goal of 
> Haskell'.

I don't see why merely introducing an ADT would break anyone's code, as
there is no existing standard filepath model, therefore no code to
break!  The code I posted works with the current IO library and uses an
ADT.  I also think it has the potential to be compatible with a
redesigned IO library.

I further believe in incremental change when possible.  So if it's
possible to try out a "better" approach to filepaths (whatever "better"
may be) without redesigning IO, IMO that's exactly what we should do.

Now it may be that the need for a filepath library is so great, and
"better" approaches sufficiently untested, that we should use whatever
exists and works right now.  But that is a separate question.

Andrew


More information about the Libraries mailing list