Class: MCollective::RPC::Progress
- Inherits:
-
Object
- Object
- MCollective::RPC::Progress
- Defined in:
- lib/mcollective/rpc/progress.rb
Overview
Class that shows a progress bar, currently only supports a twirling progress bar.
You can specify a size for the progress bar if you want if you dont it will use the helper functions to figure out terminal dimensions and draw an appropriately sized bar
p = Progress.new 100.times {|i| print p.twirl(i+1, 100) + “r”};puts
* [ ==================================================> ] 100 / 100
Instance Method Summary collapse
-
#initialize(size = nil) ⇒ Progress
constructor
A new instance of Progress.
- #twirl(current, total) ⇒ Object
Constructor Details
#initialize(size = nil) ⇒ Progress
Returns a new instance of Progress.
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/mcollective/rpc/progress.rb', line 15 def initialize(size=nil) @twirl = ["|", "/", "-", "\\", "|", "/", "-", "\\"] @twirldex = 0 if size @size = size else cols = Util.terminal_dimensions[0] - 22 # Defaults back to old behavior if it # couldn't figure out the size or if # its more than 60 wide if cols <= 0 @size = 0 elsif cols > 60 @size = 60 else @size = cols end end end |
Instance Method Details
#twirl(current, total) ⇒ Object
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/mcollective/rpc/progress.rb', line 37 def twirl(current, total) # if the size is negative there is just not enough # space on the terminal, return a simpler version return "\r#{current} / #{total}" if @size == 0 if current == total txt = "\r %s [ " % Util.colorize(:green, "*") else txt = "\r %s [ " % Util.colorize(:red, @twirl[@twirldex]) end dashes = ((current.to_f / total) * @size).round dashes.times { txt << "=" } txt << ">" (@size - dashes).times { txt << " " } txt << " ] #{current} / #{total}" @twirldex == 7 ? @twirldex = 0 : @twirldex += 1 txt end |