mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	 6b35c34c68
			
		
	
	
		6b35c34c68
		
	
	
	
	
		
			
			with inheritance. [fix GH-1227] Patch by @adrfer * lib/irb/*: ditto. * lib/prime.rb: ditto. * lib/shell/builtin-command.rb: ditto. * object.c: ditto. * sample/*.rb: ditto. * test/-ext-/method/test_arity.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@56371 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
		
			
				
	
	
		
			92 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: false
 | |
| #
 | |
| #   output-method.rb - output methods used by irb
 | |
| #   	$Release Version: 0.9.6$
 | |
| #   	$Revision$
 | |
| #   	by Keiju ISHITSUKA(keiju@ruby-lang.org)
 | |
| #
 | |
| # --
 | |
| #
 | |
| #
 | |
| #
 | |
| 
 | |
| require "e2mmap"
 | |
| 
 | |
| module IRB
 | |
|   # An abstract output class for IO in irb. This is mainly used internally by
 | |
|   # IRB::Notifier. You can define your own output method to use with Irb.new,
 | |
|   # or Context.new
 | |
|   class OutputMethod
 | |
|     extend Exception2MessageMapper
 | |
|     def_exception :NotImplementedError, "Need to define `%s'"
 | |
| 
 | |
| 
 | |
|     # Open this method to implement your own output method, raises a
 | |
|     # NotImplementedError if you don't define #print in your own class.
 | |
|     def print(*opts)
 | |
|       OutputMethod.Raise NotImplementedError, "print"
 | |
|     end
 | |
| 
 | |
|     # Prints the given +opts+, with a newline delimiter.
 | |
|     def printn(*opts)
 | |
|       print opts.join(" "), "\n"
 | |
|     end
 | |
| 
 | |
|     # Extends IO#printf to format the given +opts+ for Kernel#sprintf using
 | |
|     # #parse_printf_format
 | |
|     def printf(format, *opts)
 | |
|       if /(%*)%I/ =~ format
 | |
|         format, opts = parse_printf_format(format, opts)
 | |
|       end
 | |
|       print sprintf(format, *opts)
 | |
|     end
 | |
| 
 | |
|     # Returns an array of the given +format+ and +opts+ to be used by
 | |
|     # Kernel#sprintf, if there was a successful Regexp match in the given
 | |
|     # +format+ from #printf
 | |
|     #
 | |
|     #     %
 | |
|     #     <flag>  [#0- +]
 | |
|     #     <minimum field width> (\*|\*[1-9][0-9]*\$|[1-9][0-9]*)
 | |
|     #     <precision>.(\*|\*[1-9][0-9]*\$|[1-9][0-9]*|)?
 | |
|     #     #<length modifier>(hh|h|l|ll|L|q|j|z|t)
 | |
|     #     <conversion specifier>[diouxXeEfgGcsb%]
 | |
|     def parse_printf_format(format, opts)
 | |
|       return format, opts if $1.size % 2 == 1
 | |
|     end
 | |
| 
 | |
|     # Calls #print on each element in the given +objs+, followed by a newline
 | |
|     # character.
 | |
|     def puts(*objs)
 | |
|       for obj in objs
 | |
|         print(*obj)
 | |
|         print "\n"
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     # Prints the given +objs+ calling Object#inspect on each.
 | |
|     #
 | |
|     # See #puts for more detail.
 | |
|     def pp(*objs)
 | |
|       puts(*objs.collect{|obj| obj.inspect})
 | |
|     end
 | |
| 
 | |
|     # Prints the given +objs+ calling Object#inspect on each and appending the
 | |
|     # given +prefix+.
 | |
|     #
 | |
|     # See #puts for more detail.
 | |
|     def ppx(prefix, *objs)
 | |
|       puts(*objs.collect{|obj| prefix+obj.inspect})
 | |
|     end
 | |
| 
 | |
|   end
 | |
| 
 | |
|   # A standard output printer
 | |
|   class StdioOutputMethod < OutputMethod
 | |
|     # Prints the given +opts+ to standard output, see IO#print for more
 | |
|     # information.
 | |
|     def print(*opts)
 | |
|       STDOUT.print(*opts)
 | |
|     end
 | |
|   end
 | |
| end
 |