2010-02-27 17:26:27 +00:00
|
|
|
class String
|
|
|
|
def undent
|
2010-10-25 21:12:41 -07:00
|
|
|
gsub(/^.{#{slice(/^ +/).length}}/, '')
|
2010-02-27 17:26:27 +00:00
|
|
|
end
|
2011-06-13 13:02:17 -07:00
|
|
|
|
2012-08-14 11:23:30 -04:00
|
|
|
# eg:
|
|
|
|
# if foo then <<-EOS.undent_________________________________________________________72
|
|
|
|
# Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do
|
|
|
|
# eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
|
|
|
|
# minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip
|
|
|
|
# ex ea commodo consequat. Duis aute irure dolor in reprehenderit in
|
|
|
|
# voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur
|
|
|
|
# sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt
|
|
|
|
# mollit anim id est laborum.
|
|
|
|
# EOS
|
|
|
|
alias_method :undent_________________________________________________________72, :undent
|
|
|
|
|
2011-06-13 13:02:17 -07:00
|
|
|
unless String.method_defined?(:start_with?)
|
|
|
|
def start_with? prefix
|
|
|
|
prefix = prefix.to_s
|
|
|
|
self[0, prefix.length] == prefix
|
|
|
|
end
|
|
|
|
end
|
2012-08-10 16:06:51 -04:00
|
|
|
|
|
|
|
# String.chomp, but if result is empty: returns nil instead.
|
|
|
|
# Allows `chuzzle || foo` short-circuits.
|
|
|
|
def chuzzle
|
|
|
|
s = chomp
|
|
|
|
s unless s.empty?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class NilClass
|
|
|
|
def chuzzle; end
|
2010-02-27 17:26:27 +00:00
|
|
|
end
|
2010-11-12 21:05:35 -08:00
|
|
|
|
|
|
|
# used by the inreplace function (in utils.rb)
|
|
|
|
module StringInreplaceExtension
|
2012-02-25 16:57:03 -08:00
|
|
|
# Warn if nothing was replaced
|
|
|
|
def gsub! before, after, audit_result=true
|
|
|
|
sub = super(before, after)
|
|
|
|
if audit_result and sub.nil?
|
|
|
|
opoo "inreplace: replacement of '#{before}' with '#{after}' failed"
|
|
|
|
end
|
|
|
|
return sub
|
|
|
|
end
|
|
|
|
|
2010-11-12 21:05:35 -08:00
|
|
|
# Looks for Makefile style variable defintions and replaces the
|
|
|
|
# value with "new_value", or removes the definition entirely.
|
|
|
|
def change_make_var! flag, new_value
|
|
|
|
new_value = "#{flag}=#{new_value}"
|
2012-02-25 16:57:03 -08:00
|
|
|
sub = gsub! Regexp.new("^#{flag}[ \\t]*=[ \\t]*(.*)$"), new_value, false
|
2012-02-23 21:05:49 -06:00
|
|
|
opoo "inreplace: changing '#{flag}' to '#{new_value}' failed" if sub.nil?
|
2010-11-12 21:05:35 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
# Removes variable assignments completely.
|
|
|
|
def remove_make_var! flags
|
2011-07-22 13:52:45 -05:00
|
|
|
# Next line is for Ruby 1.9.x compatibility
|
|
|
|
flags = [flags] unless flags.kind_of? Array
|
2010-11-12 21:05:35 -08:00
|
|
|
flags.each do |flag|
|
|
|
|
# Also remove trailing \n, if present.
|
2012-02-25 16:57:03 -08:00
|
|
|
sub = gsub! Regexp.new("^#{flag}[ \\t]*=(.*)$\n?"), "", false
|
2012-02-23 21:05:49 -06:00
|
|
|
opoo "inreplace: removing '#{flag}' failed" if sub.nil?
|
2010-11-12 21:05:35 -08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Finds the specified variable
|
|
|
|
def get_make_var flag
|
|
|
|
m = match Regexp.new("^#{flag}[ \\t]*=[ \\t]*(.*)$")
|
|
|
|
return m[1] if m
|
|
|
|
return nil
|
|
|
|
end
|
|
|
|
end
|