2019-02-28 10:43:30 +01:00
|
|
|
package helper
|
|
|
|
|
2019-03-18 13:34:52 +01:00
|
|
|
import (
|
|
|
|
"os"
|
2019-03-25 09:28:58 +01:00
|
|
|
|
|
|
|
"gitbase.de/apairon/mark2web/pkg/logger"
|
2019-03-18 13:34:52 +01:00
|
|
|
)
|
2019-02-28 10:43:30 +01:00
|
|
|
|
|
|
|
// CreateDirectory creates direcory with all missing parents and panic if error
|
|
|
|
func CreateDirectory(dir string) {
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Debugf("trying to create output directory: %s", dir)
|
2019-02-28 10:43:30 +01:00
|
|
|
|
|
|
|
if dirH, err := os.Stat(dir); os.IsNotExist(err) {
|
|
|
|
err := os.MkdirAll(dir, 0755)
|
|
|
|
if err != nil {
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Panicf("could not create output directory '%s': %s", dir, err)
|
2019-02-28 10:43:30 +01:00
|
|
|
}
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Noticef("created output directory: %s", dir)
|
2019-02-28 10:43:30 +01:00
|
|
|
} else if dirH != nil {
|
|
|
|
if dirH.IsDir() {
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Noticef("output directory '%s' already exists", dir)
|
2019-02-28 10:43:30 +01:00
|
|
|
} else {
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Panicf("output directory '%s' is no directory", dir)
|
2019-02-28 10:43:30 +01:00
|
|
|
}
|
|
|
|
} else {
|
2019-03-25 09:28:58 +01:00
|
|
|
logger.Log.Panicf("unknown error for output directory '%s': %s", dir, err)
|
2019-02-28 10:43:30 +01:00
|
|
|
}
|
|
|
|
}
|