From: daniel@... Date: 2014-03-11T18:28:24+00:00 Subject: [ruby-core:61420] [ruby-trunk - Bug #9618] Pathname#cleanpath creates mixed path separators Issue #9618 has been updated by Daniel Rikowski. I could not find anything official regarding UNC paths with forward slashes in the Win32 documentation for paths (http://msdn.microsoft.com/en-us/library/windows/desktop/aa365247%28v=vs.85%29.aspx) So I did a few tests: They work on the command line and `CreateFile` works fine, too. Surprisingly they don't work in Explorer. Extended file names OTOH, e.g. names starting with `\\?\`, do **not** support forward slashes. I guess even if they work officially, they are rather unusual. I suspect they'll most likely lead to some practical problems with 3rd-party apps or libs which do not share the same flexibility as the Windows kernel. If not even the Windows Explorer can handle them properly... ---------------------------------------- Bug #9618: Pathname#cleanpath creates mixed path separators https://bugs.ruby-lang.org/issues/9618#change-45729 * Author: Daniel Rikowski * Status: Open * Priority: Low * Assignee: cruby-windows * Category: platform/windows * Target version: * ruby -v: ruby 2.0.0p451 (2014-02-24) [i386-mingw32] * Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN, 2.1: UNKNOWN ---------------------------------------- When using `Pathname#cleanpath` with a Windows path the resulting path contains a mixture of slashes and backslashes. ~~~ require 'pathname' path = Pathname.new('c:\projects\ruby\bug\test.rb') path.to_s # => "c:\\projects\\ruby\\bug\\test.rb" path.cleanpath.to_s # => "c:\\projects/ruby/bug/test.rb" ~~~ I'd expect `cleanpath` to use the same path separator for all path segments. The problem doesn't happen on non-Windows platforms because there backslashes are not detected as path separators. The problem is that the first path segment is added verbatim and only subsequent segments are joined by `File::join`. Personally I'd prefer it to use `File::SEPARATOR` **only**, regardless of any original separator(s). That way it would blend with the current 'normalizing' behaviour of `cleanpath`, which then could be also used to normalize any existing separator weirdness and - for example - make a path compatible with `Dir.glob` (which can't use backslashes) -- http://bugs.ruby-lang.org/