/* * call-seq: * str.gsub(pattern, replacement) => new_str * str.gsub(pattern) {|match| block } => new_str * * Returns a copy of <i>str</i> with <em>all</em> occurrences of <i>pattern</i> * replaced with either <i>replacement</i> or the value of the block. The * <i>pattern</i> will typically be a <code>Regexp</code>; if it is a * <code>String</code> then no regular expression metacharacters will be * interpreted (that is <code>/\d/</code> will match a digit, but * <code>'\d'</code> will match a backslash followed by a 'd'). * * If a string is used as the replacement, special variables from the match * (such as <code>$&</code> and <code>$1</code>) cannot be substituted into it, * as substitution into the string occurs before the pattern match * starts. However, the sequences <code>\1</code>, <code>\2</code>, and so on * may be used to interpolate successive groups in the match. * * In the block form, the current match string is passed in as a parameter, and * variables such as <code>$1</code>, <code>$2</code>, <code>$`</code>, * <code>$&</code>, and <code>$'</code> will be set appropriately. The value * returned by the block will be substituted for the match on each call. * * The result inherits any tainting in the original string or any supplied * replacement string. * * "hello".gsub(/[aeiou]/, '*') #=> "h*ll*" * "hello".gsub(/([aeiou])/, '<\1>') #=> "h<e>ll<o>" * "hello".gsub(/./) {|s| s[0].to_s + ' '} #=> "104 101 108 108 111 " */ static VALUE rb_str_gsub(argc, argv, str) int argc; VALUE *argv; VALUE str; { return str_gsub(argc, argv, str, 0); }