package pkg import ( "context" "crypto/sha512" "fmt" ) // A fileArtifact is an [Artifact] that cures into data known ahead of time. type fileArtifact []byte var _ KnownChecksum = new(fileArtifact) // fileArtifactNamed embeds fileArtifact alongside a caller-supplied name. type fileArtifactNamed struct { fileArtifact // Caller-supplied user-facing reporting name. name string } var _ fmt.Stringer = new(fileArtifactNamed) var _ KnownChecksum = new(fileArtifactNamed) // String returns the caller-supplied reporting name. func (a *fileArtifactNamed) String() string { return a.name } // NewFile returns a [File] that cures into a caller-supplied byte slice. // // Caller must not modify data after NewFile returns. func NewFile(name string, data []byte) File { f := fileArtifact(data) if name != "" { return &fileArtifactNamed{f, name} } return &f } // Kind returns the hardcoded [Kind] constant. func (a *fileArtifact) Kind() Kind { return KindFile } // Params writes the result of Cure. func (a *fileArtifact) Params(ctx *IContext) { ctx.GetHash().Write(*a) } // Dependencies returns a nil slice. func (a *fileArtifact) Dependencies() []Artifact { return nil } // Checksum computes and returns the checksum of caller-supplied data. func (a *fileArtifact) Checksum() Checksum { h := sha512.New384() h.Write(*a) return Checksum(h.Sum(nil)) } // Cure returns the caller-supplied data. func (a *fileArtifact) Cure(context.Context) ([]byte, error) { return *a, nil }