Add platform configuration in plan.go
to set platform in context.
Signed-off-by: Vasek - Tom C <tom.chauveau@epitech.eu>
This commit is contained in:
parent
3af9ba147e
commit
c08f262ef5
29
plan/plan.go
29
plan/plan.go
@ -48,6 +48,10 @@ func Load(ctx context.Context, args ...string) (*Plan, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := p.configPlatform(); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
return p, nil
|
return p, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,6 +63,31 @@ func (p *Plan) Source() *compiler.Value {
|
|||||||
return p.source
|
return p.source
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// configPlatform load the platform specified in the context
|
||||||
|
// Buildkit will then run every operation using that platform
|
||||||
|
// If platform is not define, context keep default platform
|
||||||
|
func (p *Plan) configPlatform() error {
|
||||||
|
platformField := p.source.Lookup("platform")
|
||||||
|
|
||||||
|
// Ignore if platform is not set in `#Plan`
|
||||||
|
if !platformField.Exists() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convert platform to string
|
||||||
|
platform, err := platformField.String()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set platform to context
|
||||||
|
err = p.context.Platform.Set(platform)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// registerLocalDirectories scans the context for local imports.
|
// registerLocalDirectories scans the context for local imports.
|
||||||
// BuildKit requires to known the list of directories ahead of time.
|
// BuildKit requires to known the list of directories ahead of time.
|
||||||
func (p *Plan) registerLocalDirs() error {
|
func (p *Plan) registerLocalDirs() error {
|
||||||
|
Reference in New Issue
Block a user