class String

def pathmap(spec=nil, &block)

This String extension comes from Rake

"/path/to/file.txt"

Returns:

}
ext.downcase
"/path/to/file.TXT".pathmap("%X%{.*,*}x") { |ext|

For example:

some arbitrary calculation for the replacement.
If the replacement text is '*', then a block may be provided to perform

"class/org/onestepback/proj/A.class"

returns:

"src/org/onestepback/proj/A.java".pathmap("%{^src,class}X.class")

For example:

reasonable).
excluded from both the pattern and replacement text (let's keep parsing
used in the replacement text. Curly braces, commas and semi-colons are
Regular expressions may be used for the pattern, and back refs may be

"%{old,new;src,bin}d").
Multiple replacement specs should be separated by semi-colons (e.g.
character but before the operator letter. (e.g. "%{old,new}d").
enclosed by curly braces. The replacement spec comes after the %
the path. The pattern and replacement are separated by a comma and are
argument to perform simple string substitutions on a particular part of
%x, and %X operators can take a pattern/replacement
Also the %d, %p, %f, %n,

'a/b/c/d/file.txt'.pathmap("%-2d") => 'c/d'
'a/b/c/d/file.txt'.pathmap("%2d") => 'a/b'

Examples:

to) +n+ directories from the right hand side of the path.
path, starting from the left hand side. If +n+ is negative, return (up
If the number is positive, only return (up to) +n+ directories in the
The %d specifier can also have a numeric prefix (e.g. '%2d').

%% :: A percent sign.
the standard file separator.
%s :: The alternate file separator if defined, otherwise use #
%X :: Everything *but* the file extension.
is no extension.
%x :: The file extension of the path. An empty string if there
%d :: The directory list of the path.
%n :: The file name of the path without its file extension.
but without any directories.
%f :: The base file name of the path, with its file extension,
%p :: The complete path.

recognized:
controls the details of the mapping. The following special patterns are
Map the path according to the given specification. The specification
def pathmap(spec=nil, &block)
  return self if spec.nil?
  result = "".dup
  spec.scan(/%\{[^}]*\}-?\d*[sdpfnxX%]|%-?\d+d|%.|[^%]+/) do |frag|
    case frag
    when "%f"
      result << File.basename(self)
    when "%n"
      result << File.basename(self).ext
    when "%d"
      result << File.dirname(self)
    when "%x"
      result << File.extname(self)
    when "%X"
      result << self.ext
    when "%p"
      result << self
    when "%s"
      result << (File::ALT_SEPARATOR || File::SEPARATOR)
    when "%-"
      # do nothing
    when "%%"
      result << "%"
    when /%(-?\d+)d/
      result << pathmap_partial($1.to_i)
    when /^%\{([^}]*)\}(\d*[dpfnxX])/
      patterns, operator = $1, $2
      result << pathmap("%" + operator).pathmap_replace(patterns, &block)
    when /^%/
      fail ArgumentError, "Unknown pathmap specifier #{frag} in '#{spec}'"
    else
      result << frag
    end
  end
  result
end