Module: EacCli::RunnerWith::Subcommands

Defined in:
lib/eac_cli/runner_with/subcommands.rb,
lib/eac_cli/runner_with/subcommands/definition_concern.rb

Defined Under Namespace

Modules: DefinitionConcern

Constant Summary collapse

EXTRA_AVAILABLE_SUBCOMMANDS_METHOD_NAME =
:extra_available_subcommands

Class Method Summary collapse

Instance Method Summary collapse

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method_name, *arguments, &block) ⇒ Object



59
60
61
62
63
64
# File 'lib/eac_cli/runner_with/subcommands.rb', line 59

def method_missing(method_name, *arguments, &block)
  return run_with_subcommand(*arguments, &block) if
  run_with_subcommand_alias_run?(method_name)

  super
end

Class Method Details

.runner?(object) ⇒ Boolean

Returns:

  • (Boolean)


12
13
14
# File 'lib/eac_cli/runner_with/subcommands.rb', line 12

def runner?(object)
  ::EacCli::Runner.runner?(object)
end

.subcommands_from_module(a_module) ⇒ Hash<String, EacCli::Runner>

Returns:



17
18
19
20
21
22
# File 'lib/eac_cli/runner_with/subcommands.rb', line 17

def subcommands_from_module(a_module)
  a_module.constants
    .map { |name| [name.to_s.underscore.gsub('_', '-'), a_module.const_get(name)] }
    .select { |c| runner?(c[1]) }
    .to_h.with_indifferent_access
end

Instance Method Details

#available_subcommandsObject



33
34
35
# File 'lib/eac_cli/runner_with/subcommands.rb', line 33

def available_subcommands
  @available_subcommands ||= available_subcommands_auto.merge(available_subcommands_extra)
end

#available_subcommands_autoHash<String, EacCli::Runner>

Returns:



38
39
40
# File 'lib/eac_cli/runner_with/subcommands.rb', line 38

def available_subcommands_auto
  ::EacCli::RunnerWith::Subcommands.subcommands_from_module(self.class)
end

#available_subcommands_extraObject



42
43
44
45
46
47
48
# File 'lib/eac_cli/runner_with/subcommands.rb', line 42

def available_subcommands_extra
  if respond_to?(EXTRA_AVAILABLE_SUBCOMMANDS_METHOD_NAME, true)
    send(EXTRA_AVAILABLE_SUBCOMMANDS_METHOD_NAME)
  else
    {}
  end
end

#available_subcommands_to_sObject



50
51
52
# File 'lib/eac_cli/runner_with/subcommands.rb', line 50

def available_subcommands_to_s
  available_subcommands.keys.sort.join(', ')
end

#help_extra_textHash<String, Enumerable<String>]

Returns Hash<String, Enumerable<String>].

Returns:

  • (Hash<String, Enumerable<String>])

    Hash<String, Enumerable<String>]



55
56
57
# File 'lib/eac_cli/runner_with/subcommands.rb', line 55

def help_extra_text
  help_list_section('Subcommands', available_subcommands.keys.sort)
end

#respond_to_missing?(method_name, include_private = false) ⇒ Boolean

Returns:

  • (Boolean)


66
67
68
# File 'lib/eac_cli/runner_with/subcommands.rb', line 66

def respond_to_missing?(method_name, include_private = false)
  run_with_subcommand_alias_run?(method_name) || super
end

#run_subcommand?Boolean

Returns:

  • (Boolean)


90
91
92
# File 'lib/eac_cli/runner_with/subcommands.rb', line 90

def run_subcommand?
  subcommand_name.present?
end

#run_with_subcommandObject



70
71
72
73
74
75
76
77
78
79
80
# File 'lib/eac_cli/runner_with/subcommands.rb', line 70

def run_with_subcommand
  if run_subcommand?
    if subcommand_runner.respond_to?(:run_run)
      subcommand_runner.run_run
    else
      subcommand_runner.run
    end
  else
    run_without_subcommand
  end
end

#run_with_subcommand_alias_run?(method_name) ⇒ Boolean

Returns:

  • (Boolean)


82
83
84
# File 'lib/eac_cli/runner_with/subcommands.rb', line 82

def run_with_subcommand_alias_run?(method_name)
  subcommands? && method_name.to_sym == :run
end

#run_without_subcommandObject



86
87
88
# File 'lib/eac_cli/runner_with/subcommands.rb', line 86

def run_without_subcommand
  "Method #{__method__} should be overrided in #{self.class.name}"
end

#subcommand_argsObject



98
99
100
# File 'lib/eac_cli/runner_with/subcommands.rb', line 98

def subcommand_args
  parsed.fetch(::EacCli::Definition::SUBCOMMAND_ARGS_ARG)
end

#subcommand_classObject



102
103
104
105
106
107
108
109
110
# File 'lib/eac_cli/runner_with/subcommands.rb', line 102

def subcommand_class
  available_subcommands[subcommand_name].if_present { |v| return v }

  raise(::EacCli::Parser::Error.new(
          self.class.runner_definition, runner_context.argv,
          "Subcommand \"#{subcommand_name}\" not found " \
          "(Available: #{available_subcommands_to_s})"
        ))
end

#subcommand_nameObject



112
113
114
# File 'lib/eac_cli/runner_with/subcommands.rb', line 112

def subcommand_name
  parsed.fetch(::EacCli::Definition::SUBCOMMAND_NAME_ARG)
end

#subcommand_programObject



116
117
118
# File 'lib/eac_cli/runner_with/subcommands.rb', line 116

def subcommand_program
  [program_name, subcommand_name]
end

#subcommand_runnerObject



120
121
122
123
124
125
126
# File 'lib/eac_cli/runner_with/subcommands.rb', line 120

def subcommand_runner
  @subcommand_runner ||= subcommand_class.create(
    argv: subcommand_args,
    program_name: subcommand_program,
    parent: self
  )
end

#subcommands?Boolean

Returns:

  • (Boolean)


94
95
96
# File 'lib/eac_cli/runner_with/subcommands.rb', line 94

def subcommands?
  self.class.runner_definition.subcommands?
end