lib/chef/knife/diff.rb in chef-11.4.4 vs lib/chef/knife/diff.rb in chef-11.6.0.hotfix.1
- old
+ new
@@ -1,14 +1,15 @@
require 'chef/chef_fs/knife'
-require 'chef/chef_fs/command_line'
class Chef
class Knife
class Diff < Chef::ChefFS::Knife
banner "knife diff PATTERNS"
- common_options
+ deps do
+ require 'chef/chef_fs/command_line'
+ end
option :recurse,
:long => '--[no-]recurse',
:boolean => true,
:default => true,
@@ -22,23 +23,39 @@
option :name_status,
:long => '--name-status',
:boolean => true,
:description => "Only show names and statuses of modified files: Added, Deleted, Modified, and Type Changed."
+ option :diff_filter,
+ :long => '--diff-filter=[(A|D|M|T)...[*]]',
+ :description => "Select only files that are Added (A), Deleted (D), Modified (M), or have their type (i.e. regular file, directory) changed (T). Any combination of the filter characters (including none) can be used. When * (All-or-none) is added to the combination, all paths are selected if
+ there is any file that matches other criteria in the comparison; if there is no file that matches other criteria, nothing is selected."
+
def run
if config[:name_only]
output_mode = :name_only
end
if config[:name_status]
output_mode = :name_status
end
patterns = pattern_args_from(name_args.length > 0 ? name_args : [ "" ])
# Get the matches (recursively)
- patterns.each do |pattern|
- Chef::ChefFS::CommandLine.diff(pattern, chef_fs, local_fs, config[:recurse] ? nil : 1, output_mode) do |diff|
- puts diff
+ error = false
+ begin
+ patterns.each do |pattern|
+ found_error = Chef::ChefFS::CommandLine.diff_print(pattern, chef_fs, local_fs, config[:recurse] ? nil : 1, output_mode, proc { |entry| format_path(entry) }, config[:diff_filter], ui ) do |diff|
+ stdout.print diff
+ end
+ error = true if found_error
end
+ rescue Chef::ChefFS::FileSystem::OperationFailedError => e
+ ui.error "Failed on #{format_path(e.entry)} in #{e.operation}: #{e.message}"
+ error = true
+ end
+
+ if error
+ exit 1
end
end
end
end
end