Module: Vivarium::CLI
- Defined in:
- lib/vivarium/cli.rb
Class Method Summary collapse
-
.resolve_report_filter(options) ⇒ Object
Resolve the report display filter by precedence: –all > –filter JSON > –event NAMES > DEFAULT_FILTER.
- .run!(argv = ARGV) ⇒ Object
- .run_load!(argv, options) ⇒ Object
- .run_report!(argv, options) ⇒ Object
Class Method Details
.resolve_report_filter(options) ⇒ Object
Resolve the report display filter by precedence:
--all > --filter JSON > --event NAMES > DEFAULT_FILTER
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'lib/vivarium/cli.rb', line 86 def self.resolve_report_filter() return nil if [:show_all] if [:filter_json] begin return JSON.parse([:filter_json]) rescue JSON::ParserError => e abort "Invalid --filter JSON: #{e.}" end end names = [:event_names] return { include_events: names } if names && !names.empty? Vivarium::DEFAULT_FILTER end |
.run!(argv = ARGV) ⇒ Object
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/vivarium/cli.rb', line 8 def self.run!(argv = ARGV) = { socket_path: Vivarium.socket_path, dest: $stdout } parser = OptionParser.new do |opts| opts. = "Usage: vivarium [options] <command> [args]" opts.separator "" opts.separator "Commands:" opts.separator " load <script> Load and observe a Ruby script" opts.separator " report <raw-file> Render a saved raw event file" opts.separator "" opts.separator "Options:" opts.on("--socket PATH", "vivariumd Unix domain socket path") { |v| [:socket_path] = v } opts.on("-o", "--output PATH", "Log output file (default: stdout)") { |v| [:dest] = File.open(v, "a") } opts.on("--save-raw PATH", "load: save raw events to PATH instead of rendering") { |v| [:save_raw] = v } opts.on("--all", "report: show all events (ignore default filter)") { [:show_all] = true } opts.on("--filter JSON", "report: filter as a JSON object (overrides --event/default)") { |v| [:filter_json] = v } opts.on("--event NAMES", "report: comma-separated event names to include") do |v| [:event_names] = v.split(",").map(&:strip).reject(&:empty?) end opts.on("--max-span-depth N", Integer, "report: collapse method spans deeper than N (events kept)") do |v| [:max_span_depth] = v end end parser.order!(argv) command = argv.shift case command when "load" run_load!(argv, ) when "report" run_report!(argv, ) else abort parser.help end end |
.run_load!(argv, options) ⇒ Object
43 44 45 46 47 48 49 50 51 52 |
# File 'lib/vivarium/cli.rb', line 43 def self.run_load!(argv, ) script = argv.shift abort "Usage: vivarium load <script>" unless script abort "File not found: #{script}" unless File.exist?(script) Vivarium.observe(socket_path: [:socket_path], dest: [:dest], filter: Vivarium::DEFAULT_FILTER, save_raw: [:save_raw]) do Kernel.load(File.(script)) end end |
.run_report!(argv, options) ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
# File 'lib/vivarium/cli.rb', line 54 def self.run_report!(argv, ) raw = argv.shift abort "Usage: vivarium report <raw-file>" unless raw abort "File not found: #{raw}" unless File.exist?(raw) data = begin File.open(raw, "rb") { |io| Vivarium::RawStore.load(io) } rescue Vivarium::RawStore::FormatError => e abort "Invalid vivarium-raw file #{raw}: #{e.}" end = data[:meta] filter = resolve_report_filter() if [:max_span_depth] filter = (filter || {}).merge(max_span_depth: [:max_span_depth]) end Vivarium::TreeRenderer.new( events: data[:events], observer_pid: [:observer_pid], main_tid: [:main_tid], session_start_iso: [:session_start_iso], session_start_ktime: [:session_start_ktime], session_stop_iso: [:session_stop_iso], session_stop_ktime: [:session_stop_ktime], filter: filter, dest: [:dest] ).render end |