Sha256: f381d48700bda3ce184ebb8f7bc17ee3d91620253101b2bc15a123aa69ab4347
Contents?: true
Size: 1.87 KB
Versions: 1
Compression:
Stored size: 1.87 KB
Contents
module Opener class PropertyTagger ## # CLI wrapper around {Opener::PropertyTagger} using OptionParser. # # @!attribute [r] options # @return [Hash] # @!attribute [r] option_parser # @return [OptionParser] # class CLI attr_reader :options, :option_parser ## # @param [Hash] options # def initialize(options = {}) @options = DEFAULT_OPTIONS.merge(options) @option_parser = OptionParser.new do |opts| opts.program_name = 'polarity-tagger' opts.summary_indent = ' ' opts.on('-h', '--help', 'Shows this help message') do show_help end opts.on('-v', '--version', 'Shows the current version') do show_version end opts.on('-l', '--log', 'Enable logging to STDERR') do @options[:logging] = true end opts.separator <<-EOF Examples: cat example.kaf | #{opts.program_name} # Basic usage cat example.kaf | #{opts.program_name} # Logs information to STDERR EOF end end ## # @param [String] input # def run(input) option_parser.parse!(options[:args]) tagger = PropertyTagger.new(options) stdout, stderr, process = tagger.run(input) if process.success? puts stdout if options[:logging] and !stderr.empty? STDERR.puts(stderr) end else abort stderr end end private ## # Shows the help message and exits the program. # def show_help abort option_parser.to_s end ## # Shows the version and exits the program. # def show_version abort "#{option_parser.program_name} v#{VERSION} on #{RUBY_DESCRIPTION}" end end # CLI end # PropertyTagger end # Opener
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
opener-property-tagger-2.0.1 | lib/opener/property_tagger/cli.rb |