Class: Vagrant::Action::Builtin::CleanupDisks
- Inherits:
-
Object
- Object
- Vagrant::Action::Builtin::CleanupDisks
- Defined in:
- lib/vagrant/action/builtin/cleanup_disks.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
- #get_disks(machine, env) ⇒ Object
-
#initialize(app, env) ⇒ CleanupDisks
constructor
Removes any attached disks no longer defined in a Vagrantfile config.
- #read_disk_metadata(machine) ⇒ Object
Constructor Details
#initialize(app, env) ⇒ CleanupDisks
Removes any attached disks no longer defined in a Vagrantfile config
11 12 13 14 |
# File 'lib/vagrant/action/builtin/cleanup_disks.rb', line 11 def initialize(app, env) @app = app @logger = Log4r::Logger.new("vagrant::action::builtin::disk") end |
Instance Method Details
#call(env) ⇒ Object
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/vagrant/action/builtin/cleanup_disks.rb', line 16 def call(env) machine = env[:machine] defined_disks = get_disks(machine, env) # Call into providers machine implementation for disk management = (machine) if !.empty? if machine.provider.capability?(:cleanup_disks) machine.provider.capability(:cleanup_disks, defined_disks, ) else env[:ui].warn(I18n.t("vagrant.actions.disk.provider_unsupported", provider: machine.provider_name)) end end # Continue On @app.call(env) end |
#get_disks(machine, env) ⇒ Object
48 49 50 51 52 53 54 55 |
# File 'lib/vagrant/action/builtin/cleanup_disks.rb', line 48 def get_disks(machine, env) return @_disks if @_disks @_disks = [] @_disks = machine.config.vm.disks @_disks end |
#read_disk_metadata(machine) ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/vagrant/action/builtin/cleanup_disks.rb', line 36 def (machine) = machine.data_dir.join("disk_meta") if File.file?() = JSON.parse(.read) else @logger.info("No previous disk_meta file defined for guest #{machine.name}") = {} end return end |