Class: Chef::ChefFS::PathUtils
Class Method Summary collapse
- .join(*parts) ⇒ Object
- .regexp_path_separator ⇒ Object
-
.relative_to(dest, source) ⇒ Object
If you are in ‘source’, this is what you would have to type to reach ‘dest’ relative_to(‘/a/b/c/d/e’, ‘/a/b/x/y’) == ‘../../c/d/e’ relative_to(‘/a/b’, ‘/a/b’) == ”.
- .split(path) ⇒ Object
Class Method Details
.join(*parts) ⇒ Object
42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/chef/chef_fs/path_utils.rb', line 42 def self.join(*parts) return "" if parts.length == 0 # Determine if it started with a slash absolute = parts[0].length == 0 || parts[0].length > 0 && parts[0] =~ /^#{regexp_path_separator}/ # Remove leading and trailing slashes from each part so that the join will work (and the slash at the end will go away) parts = parts.map { |part| part.gsub(/^\/|\/$/, "") } # Don't join empty bits result = parts.select { |part| part != "" }.join("/") # Put the / back on absolute ? "/#{result}" : result end |
.regexp_path_separator ⇒ Object
58 59 60 |
# File 'lib/chef/chef_fs/path_utils.rb', line 58 def self.regexp_path_separator Chef::ChefFS::windows? ? '[/\\]' : '/' end |
.relative_to(dest, source) ⇒ Object
If you are in ‘source’, this is what you would have to type to reach ‘dest’ relative_to(‘/a/b/c/d/e’, ‘/a/b/x/y’) == ‘../../c/d/e’ relative_to(‘/a/b’, ‘/a/b’) == ”
28 29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/chef/chef_fs/path_utils.rb', line 28 def self.relative_to(dest, source) # Skip past the common parts source_parts = Chef::ChefFS::PathUtils.split(source) dest_parts = Chef::ChefFS::PathUtils.split(dest) i = 0 until i >= source_parts.length || i >= dest_parts.length || source_parts[i] != source_parts[i] i+=1 end # dot-dot up from 'source' to the common ancestor, then # descend to 'dest' from the common ancestor result = Chef::ChefFS::PathUtils.join(*(['..']*(source_parts.length-i) + dest_parts[i,dest.length-i])) result == '' ? '.' : result end |