From 42d156cce7c79b9e48db2c7520abb842ee855a68 Mon Sep 17 00:00:00 2001 From: Teemu Matilainen Date: Mon, 23 Dec 2013 18:23:30 -0300 Subject: [PATCH] core: Log loaded plugin versions One more piece of information to help support. --- lib/vagrant.rb | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/lib/vagrant.rb b/lib/vagrant.rb index 1dd2542ab..05b6b3c07 100644 --- a/lib/vagrant.rb +++ b/lib/vagrant.rb @@ -186,8 +186,9 @@ module Vagrant # # @param [String] name Name of the plugin to load. def self.require_plugin(name) + logger = Log4r::Logger.new("vagrant::root") + if ENV["VAGRANT_NO_PLUGINS"] - logger = Log4r::Logger.new("vagrant::root") logger.warn("VAGRANT_NO_PLUGINS is set, not loading 3rd party plugin: #{name}") return end @@ -205,7 +206,6 @@ module Vagrant rescue Exception => e # Since this is a rare case, we create a one-time logger here # in order to output the error - logger = Log4r::Logger.new("vagrant::root") logger.error("Failed to load plugin: #{name}") logger.error(" -- Error: #{e.inspect}") logger.error(" -- Backtrace:") @@ -236,6 +236,12 @@ module Vagrant raise Errors::PluginLoadFailed, :plugin => name end + + # Log plugin version + gem = Gem::Specification.find { |spec| spec.name == name } + version = gem ? gem.version : "" + logger.info("Loaded plugin #{name}, version #{version}") + ensure $stderr = previous_stderr if previous_stderr $stdout = previous_stdout if previous_stdout