buildkit/worker/result.go

62 lines
1.6 KiB
Go

package worker
import (
"context"
"github.com/moby/buildkit/cache"
"github.com/moby/buildkit/session"
"github.com/moby/buildkit/solver"
)
func NewWorkerRefResult(ref cache.ImmutableRef, worker Worker) solver.Result {
return &workerRefResult{&WorkerRef{ImmutableRef: ref, Worker: worker}}
}
type WorkerRef struct {
ImmutableRef cache.ImmutableRef
Worker Worker
}
func (wr *WorkerRef) ID() string {
refID := ""
if wr.ImmutableRef != nil {
refID = wr.ImmutableRef.ID()
}
return wr.Worker.ID() + "::" + refID
}
// GetRemotes method abstracts ImmutableRef's GetRemotes to allow a Worker to override.
// This is needed for moby integration.
// Use this method instead of calling ImmutableRef.GetRemotes() directly.
func (wr *WorkerRef) GetRemotes(ctx context.Context, createIfNeeded bool, compressionopt solver.CompressionOpt, all bool, g session.Group) ([]*solver.Remote, error) {
if w, ok := wr.Worker.(interface {
GetRemotes(context.Context, cache.ImmutableRef, bool, solver.CompressionOpt, bool, session.Group) ([]*solver.Remote, error)
}); ok {
return w.GetRemotes(ctx, wr.ImmutableRef, createIfNeeded, compressionopt, all, g)
}
return wr.ImmutableRef.GetRemotes(ctx, createIfNeeded, compressionopt, all, g)
}
type workerRefResult struct {
*WorkerRef
}
func (r *workerRefResult) Release(ctx context.Context) error {
if r.ImmutableRef == nil {
return nil
}
return r.ImmutableRef.Release(ctx)
}
func (r *workerRefResult) Sys() interface{} {
return r.WorkerRef
}
func (r *workerRefResult) Clone() solver.Result {
r2 := *r
if r.ImmutableRef != nil {
r.ImmutableRef = r.ImmutableRef.Clone()
}
return &r2
}