Reset the original environment if we are running something outside of the installer

This commit is contained in:
Seth Vargo 2015-07-09 13:52:27 -06:00
parent 790c625bc0
commit 0a5d37fc8b
1 changed files with 17 additions and 7 deletions

View File

@ -72,6 +72,15 @@ module Vagrant
process.io.stderr = stderr_writer process.io.stderr = stderr_writer
process.duplex = true process.duplex = true
# Reset the Bundler environment back - this is required for anyone who
# is not using the official Vagrant installers and is running Vagrant
# via bundler
if defined?(Bundler::ORIGINAL_ENV)
Bundler::ORIGINAL_ENV.each do |k, v|
process.environment[k] = v
end
end
# If we're in an installer on Mac and we're executing a command # If we're in an installer on Mac and we're executing a command
# in the installer context, then force DYLD_LIBRARY_PATH to look # in the installer context, then force DYLD_LIBRARY_PATH to look
# at our libs first. # at our libs first.
@ -89,14 +98,15 @@ module Vagrant
@logger.info("Command is setuid/setgid, clearing DYLD_LIBRARY_PATH") @logger.info("Command is setuid/setgid, clearing DYLD_LIBRARY_PATH")
process.environment["DYLD_LIBRARY_PATH"] = "" process.environment["DYLD_LIBRARY_PATH"] = ""
end end
end
# Reset the Bundler environment back - this is required for anyone who # If the command that is being run is not inside the installer, reset
# is not using the official Vagrant installers and is running Vagrant # the original environment - this is required for shelling out to
# via bundler # other subprocesses that depend on environment variables (like Ruby
if defined?(Bundler::ORIGINAL_ENV) # and $GEM_PATH for example)
Bundler::ORIGINAL_ENV.each do |k, v| if !command[0].include?(installer_dir)
process.environment[k] = v Vagrant.original_env.each do |k, v|
process.environemnt[k] = v
end
end end
end end