import (
"bufio"
+ "fmt"
"hash"
"io"
"os"
"path/filepath"
"strconv"
"time"
-
- "golang.org/x/crypto/blake2b"
)
func TempFile(dir, prefix string) (*os.File, error) {
func (ctx *Ctx) NewTmpFile() (*os.File, error) {
jobsPath := filepath.Join(ctx.Spool, "tmp")
- var err error
- if err = os.MkdirAll(jobsPath, os.FileMode(0777)); err != nil {
+ if err := os.MkdirAll(jobsPath, os.FileMode(0777)); err != nil {
return nil, err
}
fd, err := TempFile(jobsPath, "")
if err == nil {
- ctx.LogD("tmp", LEs{{"Src", fd.Name()}}, "created")
+ ctx.LogD("tmp", LEs{{"Src", fd.Name()}}, func(les LEs) string {
+ return "Temporary file created: " + fd.Name()
+ })
}
return fd, err
}
if err != nil {
return nil, err
}
- hsh, err := blake2b.New256(nil)
- if err != nil {
- return nil, err
- }
+ hsh := MTHNew(0, 0)
return &TmpFileWHash{
W: bufio.NewWriter(io.MultiWriter(hsh, tmp)),
Fd: tmp,
return err
}
checksum := tmp.Checksum()
- tmp.ctx.LogD("tmp", LEs{{"Src", tmp.Fd.Name()}, {"Dst", checksum}}, "commit")
+ tmp.ctx.LogD(
+ "tmp-rename",
+ LEs{{"Src", tmp.Fd.Name()}, {"Dst", checksum}},
+ func(les LEs) string {
+ return fmt.Sprintf("Temporary file: %s -> %s", tmp.Fd.Name(), checksum)
+ },
+ )
if err = os.Rename(tmp.Fd.Name(), filepath.Join(dir, checksum)); err != nil {
return err
}