Class: R10K::Environment::Git
- Includes:
- Logging, Util::Purgeable
- Defined in:
- lib/r10k/environment/git.rb
Overview
This class implements an environment based on a Git branch.
Constant Summary
Constants included from Logging
Instance Attribute Summary collapse
- #ref ⇒ Object readonly
- #remote ⇒ Object readonly
- #repo ⇒ Object readonly
Attributes inherited from Base
#basedir, #dirname, #name, #path, #puppetfile, #puppetfile_name
Instance Method Summary collapse
-
#desired_contents ⇒ Array<String>
Returns an array of the full paths to all the content being managed.
-
#initialize(name, basedir, dirname, options = {}) ⇒ Git
constructor
Initialize the given Git environment.
- #managed_directories ⇒ Object
-
#signature ⇒ String
Return a sting which uniquely identifies (per source) the current state of the environment.
- #status ⇒ Object
-
#sync ⇒ void
Clone or update the given Git environment.
Methods included from Util::Purgeable
#current_contents, #logger, #pending_contents, #purge!, #stale_contents
Methods included from Logging
debug_formatter, default_formatter, default_outputter, #logger, #logger_name, parse_level
Methods inherited from Base
#accept, #generate_types!, #info, #modules, #purge_exclusions, #whitelist
Constructor Details
#initialize(name, basedir, dirname, options = {}) ⇒ Git
Initialize the given Git environment.
35 36 37 38 39 40 41 |
# File 'lib/r10k/environment/git.rb', line 35 def initialize(name, basedir, dirname, = {}) super @remote = [:remote] @ref = [:ref] @repo = R10K::Git::StatefulRepository.new(@remote, @basedir, @dirname) end |
Instance Attribute Details
#ref ⇒ Object (readonly)
19 20 21 |
# File 'lib/r10k/environment/git.rb', line 19 def ref @ref end |
#remote ⇒ Object (readonly)
15 16 17 |
# File 'lib/r10k/environment/git.rb', line 15 def remote @remote end |
#repo ⇒ Object (readonly)
24 25 26 |
# File 'lib/r10k/environment/git.rb', line 24 def repo @repo end |
Instance Method Details
#desired_contents ⇒ Array<String>
This implements a required method for the Purgeable mixin
Returns an array of the full paths to all the content being managed.
76 77 78 79 |
# File 'lib/r10k/environment/git.rb', line 76 def desired_contents desired = [File.join(@full_path, '.git')] desired += @repo.tracked_paths.map { |entry| File.join(@full_path, entry) } end |
#managed_directories ⇒ Object
69 70 71 |
# File 'lib/r10k/environment/git.rb', line 69 def managed_directories [@full_path] end |
#signature ⇒ String
Return a sting which uniquely identifies (per source) the current state of the environment.
63 64 65 |
# File 'lib/r10k/environment/git.rb', line 63 def signature @repo.head end |
#status ⇒ Object
54 55 56 |
# File 'lib/r10k/environment/git.rb', line 54 def status @repo.status(@ref) end |
#sync ⇒ void
This method returns an undefined value.
Clone or update the given Git environment.
If the environment is being created for the first time, it will automatically update all modules to ensure that the environment is complete.
50 51 52 |
# File 'lib/r10k/environment/git.rb', line 50 def sync @repo.sync(@ref) end |