Skip to content

Commit

Permalink
Better handling of resolved paths. Fixes #241.
Browse files Browse the repository at this point in the history
  • Loading branch information
ioquatix committed May 10, 2024
1 parent 0e66cff commit bd0d779
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 9 deletions.
10 changes: 6 additions & 4 deletions lib/falcon/command/paths.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,18 @@ module Paths
# Resolve a set of `@paths` that may contain wildcards, into a sorted, unique array.
# @returns [Array(String)]
def resolved_paths(&block)
@paths.collect do |path|
Dir.glob(path)
end.flatten.sort.uniq.each(&block)
if @paths
@paths.collect do |path|
Dir.glob(path)
end.flatten.sort.uniq.each(&block)
end
end

# Build a configuration based on the resolved paths.
def configuration
configuration = Configuration.new

self.resolved_paths.each do |path|
self.resolved_paths do |path|
path = File.expand_path(path)

configuration.load_file(path)
Expand Down
2 changes: 1 addition & 1 deletion lib/falcon/command/proxy.rb
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ def call
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
buffer.puts "- To reload: kill -HUP #{Process.pid}"

self.resolved_paths.each do |path|
self.resolved_paths do |path|
buffer.puts "- Loading configuration from #{path}"
end
end
Expand Down
2 changes: 1 addition & 1 deletion lib/falcon/command/redirect.rb
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ def call
buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
buffer.puts "- To reload: kill -HUP #{Process.pid}"

self.resolved_paths.each do |path|
self.resolved_paths do |path|
buffer.puts "- Loading configuration from #{path}"
end
end
Expand Down
10 changes: 7 additions & 3 deletions lib/falcon/environment/configured.rb
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,13 @@ def configuration_paths

# All the falcon application configuration paths, with wildcards expanded.
def resolved_configuration_paths
configuration_paths.flat_map do |path|
Dir.glob(path)
end.uniq
if configuration_paths = self.configuration_paths
configuration_paths.flat_map do |path|
Dir.glob(path)
end.uniq
else
[]
end
end

def configuration
Expand Down

0 comments on commit bd0d779

Please sign in to comment.