YouPlot/lib/uplot/command.rb

101 lines
2.8 KiB
Ruby
Raw Normal View History

2020-07-29 16:01:39 +08:00
module Uplot
class Command
def initialize(argv)
@params = {}
@ptype = nil
parse_options(argv)
end
def parse_options(argv)
2020-07-30 10:48:27 +08:00
parser = OptionParser.new do |opt|
add_common_opts(opt)
2020-07-30 10:08:36 +08:00
end
2020-07-29 16:01:39 +08:00
subparsers = Hash.new do |_h, k|
warn "no such subcommand: #{k}"
exit 1
end
2020-07-30 10:48:27 +08:00
subparsers['hist'] = OptionParser.new do |sub|
sub.on('--nbins VAL', Numeric) { |v| @params[:nbins] = v }
add_common_opts(sub)
2020-07-29 16:01:39 +08:00
end
2020-07-29 18:01:10 +08:00
subparsers['histogram'] = subparsers['hist']
2020-07-30 10:48:27 +08:00
subparsers['line'] = OptionParser.new do |sub|
add_common_opts(sub)
2020-07-29 18:01:10 +08:00
end
subparsers['lineplot'] = subparsers['line']
2020-07-30 10:48:27 +08:00
subparsers['lines'] = OptionParser.new do |sub|
add_common_opts(sub)
2020-07-29 18:01:10 +08:00
end
2020-07-29 16:01:39 +08:00
2020-07-30 10:48:27 +08:00
parser.banner = <<~MSG
Usage:\tuplot <command> [options]
Command:\t#{subparsers.keys.join(' ')}
MSG
parser.order!(argv)
@ptype = argv.shift
2020-07-29 16:01:39 +08:00
subparsers[@ptype].parse!(argv) unless argv.empty?
end
2020-07-30 10:48:27 +08:00
def add_common_opts(opt)
opt.on('-o', '--output', TrueClass) { |v| @print = v }
opt.on('-t', '--title VAL', String) { |v| @params[:title] = v }
opt.on('-w', '--width VAL', Numeric) { |v| @params[:width] = v }
opt.on('-h', '--height VAL', Numeric) { |v| @params[:height] = v }
opt.on('-b', '--border VAL', Numeric) { |v| @params[:border] = v }
opt.on('-m', '--margin VAL', Numeric) { |v| @params[:margin] = v }
opt.on('-p', '--padding VAL', Numeric) { |v| @params[:padding] = v }
opt.on('-l', '--labels', TrueClass) { |v| @params[:labels] = v }
end
2020-07-29 16:01:39 +08:00
def run
2020-07-30 09:37:20 +08:00
# Sometimes the input file does not end with a newline code.
while input = Kernel.gets(nil)
input_lines = input.split(/\R/)
case @ptype
when 'hist', 'histogram'
histogram(input_lines)
when 'line', 'lineplot'
line(input_lines)
when 'lines'
lines(input_lines)
end.render($stderr)
2020-07-29 16:01:39 +08:00
2020-07-30 10:08:36 +08:00
print input if @print
2020-07-30 09:37:20 +08:00
end
2020-07-29 16:01:39 +08:00
end
def histogram(input_lines)
series = input_lines.map(&:to_f)
2020-07-30 10:08:36 +08:00
UnicodePlot.histogram(series, **@params.compact)
2020-07-29 16:01:39 +08:00
end
2020-07-29 17:24:08 +08:00
def line(input_lines)
x = []
y = []
input_lines.each_with_index do |l, i|
x[i], y[i] = l.split("\t")[0..1].map(&:to_f)
end
2020-07-30 10:08:36 +08:00
UnicodePlot.lineplot(x, y, **@params.compact)
2020-07-29 17:24:08 +08:00
end
def lines(input_lines)
n_cols = input_lines[0].split("\t").size
2020-07-30 09:37:20 +08:00
cols = Array.new(n_cols) { [] }
2020-07-29 17:24:08 +08:00
input_lines.each_with_index do |row, i|
row.split("\t").each_with_index do |v, j|
cols[j][i] = v.to_f
end
end
2020-07-30 10:08:36 +08:00
plot = UnicodePlot.lineplot(cols[0], cols[1], **@params.compact)
2020-07-29 17:24:08 +08:00
2.upto(n_cols - 1) do |i|
UnicodePlot.lineplot!(plot, cols[0], cols[i])
end
plot
end
2020-07-29 16:01:39 +08:00
end
end