Commit 8c1b07e0 authored by Shinya Maeda's avatar Shinya Maeda

Optimize reverse_line

parent 6be609dd
...@@ -96,30 +96,31 @@ module Gitlab ...@@ -96,30 +96,31 @@ module Gitlab
end end
def reverse_line def reverse_line
pos = BUFFER_SIZE pos = 0
max = stream.size max = stream.size
debris = '' debris = ''
while pos < max while (read_size = calc_read_size(pos, max)) > 0
pos += read_size
stream.seek(-pos, IO::SEEK_END) stream.seek(-pos, IO::SEEK_END)
stream.read(BUFFER_SIZE).tap do |buf| stream.read(read_size).tap do |buf|
buf = buf + debris buf = buf + debris
debris, *lines = buf.each_line.to_a debris, *lines = buf.each_line.to_a
lines.reverse_each do |line| lines.reverse_each do |line|
yield(line) yield(line)
end end
end end
pos += BUFFER_SIZE
end end
# Reached the head, read only left yield(debris) if debris != ''
stream.seek(0) end
last = (max > BUFFER_SIZE) ? (max % BUFFER_SIZE) : max
stream.read(last).tap do |buf| def calc_read_size(pos, max)
buf = buf + debris if pos > max
buf.each_line.reverse_each do |line| BUFFER_SIZE + (pos - max)
yield(line) else
end remain = max - pos
(remain > BUFFER_SIZE) ? BUFFER_SIZE : remain
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment