Sha256: 0c6d8c5b827e26befa35a16c60963b6f8b0d762c2dd4488fafa7ef580fb3b15c

Contents?: true

Size: 1.36 KB

Versions: 5

Compression:

Stored size: 1.36 KB

Contents

require 'opener/core'

module Opener
  class PropertyTagger
    ##
    # CLI wrapper around {Opener::PropertyTagger} using OptionParser.
    #
    # @!attribute [r] parser
    #  @return [Slop]
    #
    class CLI
      attr_reader :parser

      def initialize
        @parser = configure_slop
      end

      ##
      # @param [Array] argv
      #
      def run(argv = ARGV)
        parser.parse(argv)
      end

      ##
      # @return [Slop]
      #
      def configure_slop
        return Slop.new(:strict => false, :indent => 2, :help => true) do
          banner 'Usage: property-tagger [OPTIONS] -- [PYTHON OPTIONS]'

          separator <<-EOF.chomp

About:

    Component for finding the properties in a KAF document. This command reads
    input from STDIN.

Examples:

    Processing a KAF file:

        cat some_file.kaf | property-tagger

    Displaying the underlying kernel options:

        property-tagger -- --help

          EOF

          separator "\nOptions:\n"

          on :v, :version, 'Shows the current version' do
            abort "property-tagger v#{VERSION} on #{RUBY_DESCRIPTION}"
          end

          run do |opts, args|
            tagger = PropertyTagger.new(:args => args)
            input  = STDIN.tty? ? nil : STDIN.read

            puts tagger.run(input)
          end
        end
      end
    end # CLI
  end # PropertyTagger
end # Opener

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
opener-property-tagger-3.0.4 lib/opener/property_tagger/cli.rb
opener-property-tagger-3.0.3 lib/opener/property_tagger/cli.rb
opener-property-tagger-3.0.2 lib/opener/property_tagger/cli.rb
opener-property-tagger-3.0.1 lib/opener/property_tagger/cli.rb
opener-property-tagger-3.0.0 lib/opener/property_tagger/cli.rb