mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 01:53:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			126 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package client
 | 
						|
 | 
						|
import (
 | 
						|
	controlapi "github.com/moby/buildkit/api/services/control"
 | 
						|
)
 | 
						|
 | 
						|
var emptyLogVertexSize int
 | 
						|
 | 
						|
func init() {
 | 
						|
	emptyLogVertex := controlapi.VertexLog{}
 | 
						|
	emptyLogVertexSize = emptyLogVertex.Size()
 | 
						|
}
 | 
						|
 | 
						|
func NewSolveStatus(resp *controlapi.StatusResponse) *SolveStatus {
 | 
						|
	s := &SolveStatus{}
 | 
						|
	for _, v := range resp.Vertexes {
 | 
						|
		s.Vertexes = append(s.Vertexes, &Vertex{
 | 
						|
			Digest:        v.Digest,
 | 
						|
			Inputs:        v.Inputs,
 | 
						|
			Name:          v.Name,
 | 
						|
			Started:       v.Started,
 | 
						|
			Completed:     v.Completed,
 | 
						|
			Error:         v.Error,
 | 
						|
			Cached:        v.Cached,
 | 
						|
			ProgressGroup: v.ProgressGroup,
 | 
						|
		})
 | 
						|
	}
 | 
						|
	for _, v := range resp.Statuses {
 | 
						|
		s.Statuses = append(s.Statuses, &VertexStatus{
 | 
						|
			ID:        v.ID,
 | 
						|
			Vertex:    v.Vertex,
 | 
						|
			Name:      v.Name,
 | 
						|
			Total:     v.Total,
 | 
						|
			Current:   v.Current,
 | 
						|
			Timestamp: v.Timestamp,
 | 
						|
			Started:   v.Started,
 | 
						|
			Completed: v.Completed,
 | 
						|
		})
 | 
						|
	}
 | 
						|
	for _, v := range resp.Logs {
 | 
						|
		s.Logs = append(s.Logs, &VertexLog{
 | 
						|
			Vertex:    v.Vertex,
 | 
						|
			Stream:    int(v.Stream),
 | 
						|
			Data:      v.Msg,
 | 
						|
			Timestamp: v.Timestamp,
 | 
						|
		})
 | 
						|
	}
 | 
						|
	for _, v := range resp.Warnings {
 | 
						|
		s.Warnings = append(s.Warnings, &VertexWarning{
 | 
						|
			Vertex:     v.Vertex,
 | 
						|
			Level:      int(v.Level),
 | 
						|
			Short:      v.Short,
 | 
						|
			Detail:     v.Detail,
 | 
						|
			URL:        v.Url,
 | 
						|
			SourceInfo: v.Info,
 | 
						|
			Range:      v.Ranges,
 | 
						|
		})
 | 
						|
	}
 | 
						|
	return s
 | 
						|
}
 | 
						|
 | 
						|
func (ss *SolveStatus) Marshal() (out []*controlapi.StatusResponse) {
 | 
						|
	logSize := 0
 | 
						|
	for {
 | 
						|
		retry := false
 | 
						|
		sr := controlapi.StatusResponse{}
 | 
						|
		for _, v := range ss.Vertexes {
 | 
						|
			sr.Vertexes = append(sr.Vertexes, &controlapi.Vertex{
 | 
						|
				Digest:        v.Digest,
 | 
						|
				Inputs:        v.Inputs,
 | 
						|
				Name:          v.Name,
 | 
						|
				Started:       v.Started,
 | 
						|
				Completed:     v.Completed,
 | 
						|
				Error:         v.Error,
 | 
						|
				Cached:        v.Cached,
 | 
						|
				ProgressGroup: v.ProgressGroup,
 | 
						|
			})
 | 
						|
		}
 | 
						|
		for _, v := range ss.Statuses {
 | 
						|
			sr.Statuses = append(sr.Statuses, &controlapi.VertexStatus{
 | 
						|
				ID:        v.ID,
 | 
						|
				Vertex:    v.Vertex,
 | 
						|
				Name:      v.Name,
 | 
						|
				Current:   v.Current,
 | 
						|
				Total:     v.Total,
 | 
						|
				Timestamp: v.Timestamp,
 | 
						|
				Started:   v.Started,
 | 
						|
				Completed: v.Completed,
 | 
						|
			})
 | 
						|
		}
 | 
						|
		for i, v := range ss.Logs {
 | 
						|
			sr.Logs = append(sr.Logs, &controlapi.VertexLog{
 | 
						|
				Vertex:    v.Vertex,
 | 
						|
				Stream:    int64(v.Stream),
 | 
						|
				Msg:       v.Data,
 | 
						|
				Timestamp: v.Timestamp,
 | 
						|
			})
 | 
						|
			logSize += len(v.Data) + emptyLogVertexSize
 | 
						|
			// avoid logs growing big and split apart if they do
 | 
						|
			if logSize > 1024*1024 {
 | 
						|
				ss.Vertexes = nil
 | 
						|
				ss.Statuses = nil
 | 
						|
				ss.Logs = ss.Logs[i+1:]
 | 
						|
				retry = true
 | 
						|
				break
 | 
						|
			}
 | 
						|
		}
 | 
						|
		for _, v := range ss.Warnings {
 | 
						|
			sr.Warnings = append(sr.Warnings, &controlapi.VertexWarning{
 | 
						|
				Vertex: v.Vertex,
 | 
						|
				Level:  int64(v.Level),
 | 
						|
				Short:  v.Short,
 | 
						|
				Detail: v.Detail,
 | 
						|
				Info:   v.SourceInfo,
 | 
						|
				Ranges: v.Range,
 | 
						|
				Url:    v.URL,
 | 
						|
			})
 | 
						|
		}
 | 
						|
		out = append(out, &sr)
 | 
						|
		if !retry {
 | 
						|
			break
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return
 | 
						|
}
 |