Class: TreasureData::Command::TextParser
- Inherits:
-
Object
- Object
- TreasureData::Command::TextParser
- Defined in:
- lib/td/command/table.rb
Instance Method Summary collapse
- #call(file, path, &block) ⇒ Object
-
#initialize(names, regexp, time_format) ⇒ TextParser
constructor
A new instance of TextParser.
- #parse_time(value) ⇒ Object
Constructor Details
#initialize(names, regexp, time_format) ⇒ TextParser
Returns a new instance of TextParser.
558 559 560 561 562 |
# File 'lib/td/command/table.rb', line 558 def initialize(names, regexp, time_format) @names = names @regexp = regexp @time_format = time_format end |
Instance Method Details
#call(file, path, &block) ⇒ Object
564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 |
# File 'lib/td/command/table.rb', line 564 def call(file, path, &block) i = 0 file.each_line {|line| i += 1 begin line.rstrip! m = @regexp.match(line) unless m raise "invalid log format at #{path}:#{i}" end record = {} cap = m.captures @names.each_with_index {|name,cap_i| if value = cap[cap_i] if name == "time" value = parse_time(value).to_i end record[name] = value end } block.call(record) rescue $stderr.puts " skipped: #{$!}: #{line.dump}" end } end |
#parse_time(value) ⇒ Object
596 597 598 |
# File 'lib/td/command/table.rb', line 596 def parse_time(value) Time.strptime(value, @time_format) end |