Commit c1aa059d authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

Merge pull request #168 from markpeek/markpeek-filelogging

Add ability to send log output to a file using PACKER_LOG_PATH
parents 0e9c0eda 1d22f2ef
...@@ -14,12 +14,24 @@ import ( ...@@ -14,12 +14,24 @@ import (
) )
func main() { func main() {
// Setup logging if PACKER_LOG is set.
// Log to PACKER_LOG_PATH if it is set, otherwise default to stderr.
if os.Getenv("PACKER_LOG") == "" { if os.Getenv("PACKER_LOG") == "" {
// If we don't have logging explicitly enabled, then disable it // If we don't have logging explicitly enabled, then disable it
log.SetOutput(ioutil.Discard) log.SetOutput(ioutil.Discard)
} else { } else {
// Logging is enabled, make sure it goes to stderr if log_path := os.Getenv("PACKER_LOG_PATH"); log_path == "" {
log.SetOutput(os.Stderr) log.SetOutput(os.Stderr)
} else {
file, err := os.OpenFile(log_path, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0600)
if err == nil {
log.SetOutput(file)
} else {
// Problem opening the file, fail back to Stderr
log.SetOutput(os.Stderr)
log.Printf("Could not open %s for logging (%s). Using stderr instead.", log_path, err.Error())
}
}
} }
// If there is no explicit number of Go threads to use, then set it // If there is no explicit number of Go threads to use, then set it
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment