Module: TerraspaceBundler::Mod::Concerns::StackConcern
- Included in:
- TerraspaceBundler::Mod
- Defined in:
- lib/terraspace_bundler/mod/concerns/stack_concern.rb
Instance Method Summary collapse
- #all_stacks ⇒ Object
- #all_stacks?(*stacks) ⇒ Boolean
-
#normalize_stacks(option) ⇒ Object
Normalizes stack options to an Array of Hashes or just a single Hash.
- #stacks ⇒ Object (also: #stack)
Instance Method Details
#all_stacks ⇒ Object
17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/terraspace_bundler/mod/concerns/stack_concern.rb', line 17 def all_stacks stack = TerraspaceBundler::Exporter::Stacks::Stack.new(self) # to get the mod src path expr = "#{stack.examples_folder}/*" dirs = Dir.glob(expr).select { |path| File.directory?(path) } dirs.map do |dir| example = File.basename(dir) # Set name so multiple app/stacks are created instead of just one app/stack/MOD { name: example, src: example, } end end |
#all_stacks?(*stacks) ⇒ Boolean
13 14 15 |
# File 'lib/terraspace_bundler/mod/concerns/stack_concern.rb', line 13 def all_stacks?(*stacks) stacks.flatten == [:all] end |
#normalize_stacks(option) ⇒ Object
Normalizes stack options to an Array of Hashes or just a single Hash
32 33 34 35 36 37 38 39 40 41 42 43 |
# File 'lib/terraspace_bundler/mod/concerns/stack_concern.rb', line 32 def normalize_stacks(option) defaults = TB.config..dup result = case option when String [defaults.merge(src: option)] when Array option.map! {|s| normalize_stacks(s) } else # Hash [defaults.merge!(option)] end result.flatten end |
#stacks ⇒ Object Also known as: stack
3 4 5 6 7 8 9 10 |
# File 'lib/terraspace_bundler/mod/concerns/stack_concern.rb', line 3 def stacks stacks = @props[:stacks] || @props[:stack] return unless stacks if all_stacks?(stacks) stacks = all_stacks end normalize_stacks(stacks) end |