mirror of https://github.com/docker/buildx.git
				
				
				
			cli: fix standalone command behavior
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									6a702ebe5b
								
							
						
					
					
						commit
						95086cf641
					
				|  | @ -15,11 +15,6 @@ import ( | ||||||
| 	cliflags "github.com/docker/cli/cli/flags" | 	cliflags "github.com/docker/cli/cli/flags" | ||||||
| 	"github.com/moby/buildkit/solver/errdefs" | 	"github.com/moby/buildkit/solver/errdefs" | ||||||
| 	"github.com/moby/buildkit/util/stack" | 	"github.com/moby/buildkit/util/stack" | ||||||
| 	"github.com/moby/buildkit/util/tracing/detect" |  | ||||||
| 	"go.opentelemetry.io/otel" |  | ||||||
| 
 |  | ||||||
| 	_ "github.com/moby/buildkit/util/tracing/detect/delegated" |  | ||||||
| 	_ "github.com/moby/buildkit/util/tracing/env" |  | ||||||
| 
 | 
 | ||||||
| 	// FIXME: "k8s.io/client-go/plugin/pkg/client/auth/azure" is excluded because of compilation error
 | 	// FIXME: "k8s.io/client-go/plugin/pkg/client/auth/azure" is excluded because of compilation error
 | ||||||
| 	_ "k8s.io/client-go/plugin/pkg/client/auth/gcp" | 	_ "k8s.io/client-go/plugin/pkg/client/auth/gcp" | ||||||
|  | @ -31,73 +26,64 @@ import ( | ||||||
| 	_ "github.com/docker/buildx/driver/kubernetes" | 	_ "github.com/docker/buildx/driver/kubernetes" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var experimental string |  | ||||||
| 
 |  | ||||||
| func init() { | func init() { | ||||||
| 	seed.WithTimeAndRand() | 	seed.WithTimeAndRand() | ||||||
| 	stack.SetVersionInfo(version.Version, version.Revision) | 	stack.SetVersionInfo(version.Version, version.Revision) | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 	detect.ServiceName = "buildx" | func runStandalone(cmd *command.DockerCli) error { | ||||||
| 	// do not log tracing errors to stdio
 | 	if err := cmd.Initialize(cliflags.NewClientOptions()); err != nil { | ||||||
| 	otel.SetErrorHandler(skipErrors{}) | 		return err | ||||||
|  | 	} | ||||||
|  | 	rootCmd := commands.NewRootCmd(os.Args[0], false, cmd) | ||||||
|  | 	return rootCmd.Execute() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func runPlugin(cmd *command.DockerCli) error { | ||||||
|  | 	rootCmd := commands.NewRootCmd("buildx", true, cmd) | ||||||
|  | 	return plugin.RunPlugin(cmd, rootCmd, manager.Metadata{ | ||||||
|  | 		SchemaVersion: "0.1.0", | ||||||
|  | 		Vendor:        "Docker Inc.", | ||||||
|  | 		Version:       version.Version, | ||||||
|  | 	}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func main() { | func main() { | ||||||
| 	if plugin.RunningStandalone() { | 	cmd, err := command.NewDockerCli() | ||||||
| 		dockerCli, err := command.NewDockerCli() |  | ||||||
| 		if err != nil { |  | ||||||
| 			fmt.Fprintln(os.Stderr, err) |  | ||||||
| 			os.Exit(1) |  | ||||||
| 		} |  | ||||||
| 		opts := cliflags.NewClientOptions() |  | ||||||
| 		dockerCli.Initialize(opts) |  | ||||||
| 		rootCmd := commands.NewRootCmd(os.Args[0], false, dockerCli) |  | ||||||
| 		if err := rootCmd.Execute(); err != nil { |  | ||||||
| 			os.Exit(1) |  | ||||||
| 		} |  | ||||||
| 		os.Exit(0) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	dockerCli, err := command.NewDockerCli() |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		fmt.Fprintln(os.Stderr, err) | 		fmt.Fprintln(os.Stderr, err) | ||||||
| 		os.Exit(1) | 		os.Exit(1) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	p := commands.NewRootCmd("buildx", true, dockerCli) | 	if plugin.RunningStandalone() { | ||||||
| 	meta := manager.Metadata{ | 		err = runStandalone(cmd) | ||||||
| 		SchemaVersion: "0.1.0", | 	} else { | ||||||
| 		Vendor:        "Docker Inc.", | 		err = runPlugin(cmd) | ||||||
| 		Version:       version.Version, | 	} | ||||||
| 		Experimental:  experimental != "", | 	if err == nil { | ||||||
|  | 		return | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if err := plugin.RunPlugin(dockerCli, p, meta); err != nil { | 	if sterr, ok := err.(cli.StatusError); ok { | ||||||
| 		if sterr, ok := err.(cli.StatusError); ok { | 		if sterr.Status != "" { | ||||||
| 			if sterr.Status != "" { | 			fmt.Fprintln(cmd.Err(), sterr.Status) | ||||||
| 				fmt.Fprintln(dockerCli.Err(), sterr.Status) |  | ||||||
| 			} |  | ||||||
| 			// StatusError should only be used for errors, and all errors should
 |  | ||||||
| 			// have a non-zero exit status, so never exit with 0
 |  | ||||||
| 			if sterr.StatusCode == 0 { |  | ||||||
| 				os.Exit(1) |  | ||||||
| 			} |  | ||||||
| 			os.Exit(sterr.StatusCode) |  | ||||||
| 		} | 		} | ||||||
| 		for _, s := range errdefs.Sources(err) { | 		// StatusError should only be used for errors, and all errors should
 | ||||||
| 			s.Print(dockerCli.Err()) | 		// have a non-zero exit status, so never exit with 0
 | ||||||
|  | 		if sterr.StatusCode == 0 { | ||||||
|  | 			os.Exit(1) | ||||||
| 		} | 		} | ||||||
| 
 | 		os.Exit(sterr.StatusCode) | ||||||
| 		if debug.IsEnabled() { |  | ||||||
| 			fmt.Fprintf(dockerCli.Err(), "error: %+v", stack.Formatter(err)) |  | ||||||
| 		} else { |  | ||||||
| 			fmt.Fprintf(dockerCli.Err(), "error: %v\n", err) |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		os.Exit(1) |  | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	for _, s := range errdefs.Sources(err) { | ||||||
|  | 		s.Print(cmd.Err()) | ||||||
|  | 	} | ||||||
|  | 	if debug.IsEnabled() { | ||||||
|  | 		fmt.Fprintf(cmd.Err(), "error: %+v", stack.Formatter(err)) | ||||||
|  | 	} else { | ||||||
|  | 		fmt.Fprintf(cmd.Err(), "error: %v\n", err) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	os.Exit(1) | ||||||
| } | } | ||||||
| 
 |  | ||||||
| type skipErrors struct{} |  | ||||||
| 
 |  | ||||||
| func (skipErrors) Handle(err error) {} |  | ||||||
|  |  | ||||||
|  | @ -0,0 +1,19 @@ | ||||||
|  | package main | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"github.com/moby/buildkit/util/tracing/detect" | ||||||
|  | 	"go.opentelemetry.io/otel" | ||||||
|  | 
 | ||||||
|  | 	_ "github.com/moby/buildkit/util/tracing/detect/delegated" | ||||||
|  | 	_ "github.com/moby/buildkit/util/tracing/env" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | func init() { | ||||||
|  | 	detect.ServiceName = "buildx" | ||||||
|  | 	// do not log tracing errors to stdio
 | ||||||
|  | 	otel.SetErrorHandler(skipErrors{}) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type skipErrors struct{} | ||||||
|  | 
 | ||||||
|  | func (skipErrors) Handle(err error) {} | ||||||
|  | @ -6,6 +6,7 @@ import ( | ||||||
| 	imagetoolscmd "github.com/docker/buildx/commands/imagetools" | 	imagetoolscmd "github.com/docker/buildx/commands/imagetools" | ||||||
| 	"github.com/docker/buildx/util/logutil" | 	"github.com/docker/buildx/util/logutil" | ||||||
| 	"github.com/docker/cli-docs-tool/annotation" | 	"github.com/docker/cli-docs-tool/annotation" | ||||||
|  | 	"github.com/docker/cli/cli" | ||||||
| 	"github.com/docker/cli/cli-plugins/plugin" | 	"github.com/docker/cli/cli-plugins/plugin" | ||||||
| 	"github.com/docker/cli/cli/command" | 	"github.com/docker/cli/cli/command" | ||||||
| 	"github.com/sirupsen/logrus" | 	"github.com/sirupsen/logrus" | ||||||
|  | @ -26,6 +27,14 @@ func NewRootCmd(name string, isPlugin bool, dockerCli command.Cli) *cobra.Comman | ||||||
| 		cmd.PersistentPreRunE = func(cmd *cobra.Command, args []string) error { | 		cmd.PersistentPreRunE = func(cmd *cobra.Command, args []string) error { | ||||||
| 			return plugin.PersistentPreRunE(cmd, args) | 			return plugin.PersistentPreRunE(cmd, args) | ||||||
| 		} | 		} | ||||||
|  | 	} else { | ||||||
|  | 		// match plugin behavior for standalone mode
 | ||||||
|  | 		// https://github.com/docker/cli/blob/6c9eb708fa6d17765d71965f90e1c59cea686ee9/cli-plugins/plugin/plugin.go#L117-L127
 | ||||||
|  | 		cmd.SilenceUsage = true | ||||||
|  | 		cmd.SilenceErrors = true | ||||||
|  | 		cmd.TraverseChildren = true | ||||||
|  | 		cmd.DisableFlagsInUseLine = true | ||||||
|  | 		cli.DisableFlagsInUseLine(cmd) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	logrus.SetFormatter(&logutil.Formatter{}) | 	logrus.SetFormatter(&logutil.Formatter{}) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue