Unverified Commit f2d63c52 authored by Dimitris Koutsogiorgas's avatar Dimitris Koutsogiorgas Committed by GitHub

Merge pull request #7539 from CocoaPods/manu-fix-preserve-glob-order

Return list of files preserving given pattern order on glob
parents 0778a2aa 99a2f74f
...@@ -129,21 +129,23 @@ module Pod ...@@ -129,21 +129,23 @@ module Pod
full_list = files full_list = files
end end
patterns_array = Array(patterns) patterns_array = Array(patterns)
exact_matches = full_list & patterns_array exact_matches = (full_list & patterns_array).to_set
patterns_array -= exact_matches
unless patterns_array.empty?
all_patterns = patterns_array.map do |pattern| list = patterns_array.flat_map do |pattern|
if directory?(pattern) && dir_pattern if exact_matches.include?(pattern)
pattern += '/' unless pattern.end_with?('/') pattern
pattern += dir_pattern else
end if directory?(pattern) && dir_pattern
dir_glob_equivalent_patterns(pattern) pattern += '/' unless pattern.end_with?('/')
end.flatten pattern += dir_pattern
list = exact_matches end
unless all_patterns.empty? expanded_patterns = dir_glob_equivalent_patterns(pattern)
list += full_list.select do |path| full_list.select do |path|
all_patterns.any? do |p| expanded_patterns.any? do |p|
File.fnmatch(p, path, File::FNM_CASEFOLD | File::FNM_PATHNAME) File.fnmatch(p, path, File::FNM_CASEFOLD | File::FNM_PATHNAME)
end
end
end end
end end
end end
......
...@@ -199,6 +199,21 @@ module Pod ...@@ -199,6 +199,21 @@ module Pod
libBananalib.a libBananalib.a
) )
end end
it 'preserves pattern order' do
patterns = %w(
Classes/BananaPrivate.h
Classes/Banana.h
Classes/Banana.m
)
paths = @path_list.relative_glob(patterns).map(&:to_s)
paths.should == %w(
Classes/BananaPrivate.h
Classes/Banana.h
Classes/Banana.m
)
end
end end
describe 'Reading file system' do describe 'Reading file system' do
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment