 8e0158b4d7
			
		
	
	
		8e0158b4d7
		
	
	
	
	
		
			
			I'm tired of not remembering if start_with?/end_with? are portable, so just add them both if they're not defined.
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| class String
 | |
|   def undent
 | |
|     gsub(/^.{#{slice(/^ +/).length}}/, '')
 | |
|   end
 | |
| 
 | |
|   # 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
 | |
| 
 | |
|   def start_with?(*prefixes)
 | |
|     prefixes.any? do |prefix|
 | |
|       if prefix.respond_to?(:to_str)
 | |
|         prefix = prefix.to_str
 | |
|         self[0, prefix.length] == prefix
 | |
|       end
 | |
|     end
 | |
|   end unless method_defined?(:start_with?)
 | |
| 
 | |
|   def end_with?(*suffixes)
 | |
|     suffixes.any? do |suffix|
 | |
|       if suffix.respond_to?(:to_str)
 | |
|         suffix = suffix.to_str
 | |
|         self[-suffix.length, suffix.length] == suffix
 | |
|       end
 | |
|     end
 | |
|   end unless method_defined?(:end_with?)
 | |
| 
 | |
|   # 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
 | |
| end
 | |
| 
 | |
| # used by the inreplace function (in utils.rb)
 | |
| module StringInreplaceExtension
 | |
|   # 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
 | |
| 
 | |
|   # 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}"
 | |
|     sub = gsub! Regexp.new("^#{flag}[ \\t]*=[ \\t]*(.*)$"), new_value, false
 | |
|     opoo "inreplace: changing '#{flag}' to '#{new_value}' failed" if sub.nil?
 | |
|   end
 | |
| 
 | |
|   # Removes variable assignments completely.
 | |
|   def remove_make_var! flags
 | |
|     Array(flags).each do |flag|
 | |
|       # Also remove trailing \n, if present.
 | |
|       sub = gsub! Regexp.new("^#{flag}[ \\t]*=(.*)$\n?"), "", false
 | |
|       opoo "inreplace: removing '#{flag}' failed" if sub.nil?
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   # Finds the specified variable
 | |
|   def get_make_var flag
 | |
|     m = match Regexp.new("^#{flag}[ \\t]*=[ \\t]*(.*)$")
 | |
|     return m[1] if m
 | |
|   end
 | |
| end
 |