@ -61,32 +61,6 @@ func runCreate(dockerCli command.Cli, in createOptions, args []string) error {
}
}
}
}
buildkitHost := os . Getenv ( "BUILDKIT_HOST" )
driverName := in . driver
if driverName == "" {
if len ( args ) == 0 && buildkitHost != "" {
driverName = "remote"
} else {
var arg string
if len ( args ) > 0 {
arg = args [ 0 ]
}
f , err := driver . GetDefaultFactory ( ctx , arg , dockerCli . Client ( ) , true )
if err != nil {
return err
}
if f == nil {
return errors . Errorf ( "no valid drivers found" )
}
driverName = f . Name ( )
}
}
if driver . GetFactory ( driverName , true ) == nil {
return errors . Errorf ( "failed to find driver %q" , in . driver )
}
txn , release , err := storeutil . GetStore ( dockerCli )
txn , release , err := storeutil . GetStore ( dockerCli )
if err != nil {
if err != nil {
return err
return err
@ -121,17 +95,48 @@ func runCreate(dockerCli command.Cli, in createOptions, args []string) error {
logrus . Warnf ( "failed to find %q for append, creating a new instance instead" , in . name )
logrus . Warnf ( "failed to find %q for append, creating a new instance instead" , in . name )
}
}
if in . actionLeave {
if in . actionLeave {
return errors . Errorf ( "failed to find instance %q for leave" , name )
return errors . Errorf ( "failed to find instance %q for leave" , in . name )
}
} else {
return err
}
}
}
buildkitHost := os . Getenv ( "BUILDKIT_HOST" )
driverName := in . driver
if driverName == "" {
if ng != nil {
driverName = ng . Driver
} else if len ( args ) == 0 && buildkitHost != "" {
driverName = "remote"
} else {
} else {
var arg string
if len ( args ) > 0 {
arg = args [ 0 ]
}
f , err := driver . GetDefaultFactory ( ctx , arg , dockerCli . Client ( ) , true )
if err != nil {
return err
return err
}
}
if f == nil {
return errors . Errorf ( "no valid drivers found" )
}
driverName = f . Name ( )
}
}
}
if ng != nil {
if ng != nil {
if in . nodeName == "" && ! in . actionAppend {
if in . nodeName == "" && ! in . actionAppend {
return errors . Errorf ( "existing instance for %s but no append mode, specify --node to make changes for existing instances" , name )
return errors . Errorf ( "existing instance for % q but no append mode, specify --node to make changes for existing instances", name )
}
}
if driverName != ng . Driver {
return errors . Errorf ( "existing instance for %q but has mismatched driver %q" , name , ng . Driver )
}
}
if driver . GetFactory ( driverName , true ) == nil {
return errors . Errorf ( "failed to find driver %q" , driverName )
}
}
ngOriginal := ng
ngOriginal := ng
@ -142,13 +147,10 @@ func runCreate(dockerCli command.Cli, in createOptions, args []string) error {
if ng == nil {
if ng == nil {
ng = & store . NodeGroup {
ng = & store . NodeGroup {
Name : name ,
Name : name ,
Driver : driverName ,
}
}
}
}
if ng . Driver == "" || in . driver != "" {
ng . Driver = driverName
}
var flags [ ] string
var flags [ ] string
if in . flags != "" {
if in . flags != "" {
flags , err = shlex . Split ( in . flags )
flags , err = shlex . Split ( in . flags )