[Rd] Question about Unix file paths

Prof Brian Ripley ripley at stats.ox.ac.uk
Tue Nov 25 08:35:57 MET 2003


On Mon, 24 Nov 2003, Duncan Murdoch wrote:

> >Duncan Murdoch <dmurdoch at pair.com> writes:
> >
> >> Gabor Grothendieck pointed out a bug to me in list.files(...,
> >> full.name=TRUE), that essentially comes down to the fact that in
> >> Windows it's not always valid to add a path separator (slash or
> >> backslash) between a path specifier and a filename.  For example,
> >> 
> >> c:foo
> >> 
> >> is different from
> >> 
> >> c:\foo
> >> 
> >> and there are other examples.
> 
> I've committed a change to r-patched to fix this in Windows only.
> Sounds like it's not an issue elsewhere.

I think there are some potential issues with doubling separators and final
separators on dirs.  On Unix file systems /part1//part2 and /path/to/dir/
are valid.  However, file systems on Unix may not be Unix file systems:
examples are earlier MacOS systems on MacOS X and mounted Windows and 
Novell systems on Linux.  I would not want to assume that all of these
combinations worked.

> Gabor also suggested an option to use shell globbing instead of
> regular expressions to select the files in the list, e.g.
> 
> list.files(dir="/", pattern="a*.dat", glob=T)
> 
> This would be easy to do in Windows, but from the little I know about
> Unix programming, would not be so easy there, so I haven't done
> anything about it.

It would be shell-dependent and OS-dependent as well as a retrograde step,
as those who wanted to use regular expressions no longer would be able to.

-- 
Brian D. Ripley,                  ripley at stats.ox.ac.uk
Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
University of Oxford,             Tel:  +44 1865 272861 (self)
1 South Parks Road,                     +44 1865 272866 (PA)
Oxford OX1 3TG, UK                Fax:  +44 1865 272595



More information about the R-devel mailing list