module PowerStencil module CommandProcessors class Plugin include Climatic::Script::UnimplementedProcessor include Climatic::Proxy include PowerStencil::Project::Proxy def execute if config[:install] config[:project_plugins].each do |plugin_definition| gem_name, gem_req = PowerStencil::Plugins::Base.plugin_definition_to_name_and_req plugin_definition specs = PowerStencil::Plugins::Base.install_gem gem_name, gem_req spec = specs.first puts "Installed plugin '#{spec.name}' (version: #{spec.version})" end return end if config[:list] if project.plugins.empty? puts 'No plugin used in this project.' else puts "#{project.plugins.size} plugin#{project.plugins.size == 1 ? '' : 's'} found to be used in this project." end project.plugins.each do |_, plugin| puts " - #{plugin.name} (in '#{plugin.plugin_path}')" if config[:verbose] plugin.capabilities.each do |name, value| puts " #{name}: #{value}" end end end return end if config[:create] if config.command_line_layer.extra_parameters.empty? raise PowerStencil::Error, 'Please specify at least one plugin name !' end config.command_line_layer.extra_parameters.each do |plugin_name| begin target_path = File.join project.project_local_plugin_path(plugin_name) project.create_new_local_plugin_tree plugin_name, target_path puts "Generated new plugin '#{plugin_name}'" rescue => e msg = "Could not create plugin '#{plugin_name}' because '#{e.message}'" puts msg logger.error "Could not create plugin '#{plugin_name}' because '#{e.message}'" logger.debug PowerStencil::Error.report_error(e) end end return end raise PowerStencil::Error, 'You should specify an option' end end end end