mirror of
https://github.com/jesseduffield/lazydocker.git
synced 2024-10-04 08:27:22 +03:00
2bbdb9bf6e
- If passed, passes to docker-compose as -f flag - Supports multiple docker-compose files
78 lines
1.8 KiB
Go
78 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"log"
|
|
"os"
|
|
"runtime"
|
|
|
|
"github.com/docker/docker/client"
|
|
"github.com/go-errors/errors"
|
|
"github.com/integrii/flaggy"
|
|
"github.com/jesseduffield/lazydocker/pkg/app"
|
|
"github.com/jesseduffield/lazydocker/pkg/config"
|
|
"github.com/jesseduffield/yaml"
|
|
)
|
|
|
|
var (
|
|
commit string
|
|
version = "unversioned"
|
|
date string
|
|
buildSource = "unknown"
|
|
|
|
configFlag = false
|
|
debuggingFlag = false
|
|
composeFiles []string
|
|
)
|
|
|
|
func main() {
|
|
|
|
flaggy.SetName("lazydocker")
|
|
flaggy.SetDescription("The lazier way to manage everything docker")
|
|
flaggy.DefaultParser.AdditionalHelpPrepend = "https://github.com/jesseduffield/lazydocker"
|
|
|
|
flaggy.Bool(&configFlag, "c", "config", "Print the current default config")
|
|
flaggy.Bool(&debuggingFlag, "d", "debug", "a boolean")
|
|
flaggy.StringSlice(&composeFiles, "f", "file", "Specify alternate compose files")
|
|
flaggy.SetVersion(fmt.Sprintf("commit=%s, build date=%s, build source=%s, version=%s, os=%s, arch=%s\n", commit, date, buildSource, version, runtime.GOOS, runtime.GOARCH))
|
|
|
|
flaggy.Parse()
|
|
|
|
if configFlag {
|
|
var buf bytes.Buffer
|
|
yaml.NewEncoder(&buf).Encode(config.GetDefaultConfig())
|
|
fmt.Printf("%v\n", buf.String())
|
|
os.Exit(0)
|
|
}
|
|
|
|
appConfig, err := config.NewAppConfig("lazydocker", version, commit, date, buildSource, debuggingFlag, composeFiles)
|
|
if err != nil {
|
|
log.Fatal(err.Error())
|
|
}
|
|
|
|
app, err := app.NewApp(appConfig)
|
|
|
|
if err == nil {
|
|
err = app.Run()
|
|
}
|
|
|
|
if err != nil {
|
|
if errMessage, known := app.KnownError(err); known {
|
|
log.Println(errMessage)
|
|
os.Exit(0)
|
|
}
|
|
|
|
if client.IsErrConnectionFailed(err) {
|
|
log.Println(app.Tr.ConnectionFailed)
|
|
os.Exit(0)
|
|
}
|
|
|
|
newErr := errors.Wrap(err, 0)
|
|
stackTrace := newErr.ErrorStack()
|
|
app.Log.Error(stackTrace)
|
|
|
|
log.Fatal(fmt.Sprintf("%s\n\n%s", app.Tr.ErrorOccurred, stackTrace))
|
|
}
|
|
}
|