+
+ header += ' (Plugin: ' + plugin_name + ")\n"
+ header += '-' * header.size # Underline the header.
+
+ return header
+end
+
+
+plugin_class = nil
+
+if mode == :rm then
+ plugin_class = RmPlugin
+elsif mode == :mv then
+ plugin_class = MvPlugin
+else
+ # Safe, catch-all default
+ plugin_class = PrunePlugin
+end
+
+
+# Buffer the output so that we can avoid printing the informational
+# header when no plugins produce output.
+require 'stringio'
+output_buffer = StringIO.new()
+$stdout = output_buffer
+
+plugin_class.includers.each do |plugin_class_includer|
+ plugin = plugin_class_includer.new(cfg)
+
+ if cfg.i_mean_business then
+ runner = plugin.runner().new()
+ else
+ runner = plugin.dummy_runner().new()
+ end
+
+ # The splat passes the correct (we hope) number of arguments to the
+ # appropriate runner. The Rm(Dummy)Runner have splats on their
+ # *target arguments as well, to turn ARGV back into an array.
+ runner.run(plugin, *ARGV)
+end
+
+# Restore stdout, and print the header plus whatever the plugins
+# produced if they produced anything. If they didn't, we avoid
+# printing the header.
+$stdout = STDOUT
+if output_buffer.size > 0 then
+ puts make_header(plugin_class.to_s())
+ puts output_buffer.string()