providers/os: use Document.Rel

This commit is contained in:
Sasha Koshka 2024-12-08 03:28:33 -05:00
parent cc13abd8f8
commit 25541dadfe

View File

@ -7,7 +7,7 @@ import "io/fs"
import "html/template" import "html/template"
import "git.tebibyte.media/sashakoshka/step" import "git.tebibyte.media/sashakoshka/step"
var _ step.FuncProvider = new(Provider) var _ step.FuncProviderFor = new(Provider)
// FileInfo is like the fs.FileInfo interface, but it directly contains the // FileInfo is like the fs.FileInfo interface, but it directly contains the
// values instead of having getters for them. // values instead of having getters for them.
@ -26,43 +26,63 @@ type Provider struct {
// FuncMap fulfills the step.FuncProvider interface. // FuncMap fulfills the step.FuncProvider interface.
func (this *Provider) FuncMap () template.FuncMap { func (this *Provider) FuncMap () template.FuncMap {
return nil
}
// FuncMapFor fulfills the step.FuncProviderFor interface.
func (this *Provider) FuncMapFor (document *step.Document) template.FuncMap {
stat := &state {
document: document,
}
return template.FuncMap { return template.FuncMap {
"env": funcEnv, "env": stat.funcEnv,
"exists": funcExists, "exists": stat.funcExists,
"isFile": funcIsFile, "isFile": stat.funcIsFile,
"isDir": funcIsDir, "isDir": stat.funcIsDir,
"statFile": funcStatFile, "statFile": stat.funcStatFile,
"readFile": funcReadFile, "readFile": stat.funcReadFile,
"readDir": funcReadDir, "readDir": stat.funcReadDir,
"writeFile": funcWriteFile, "writeFile": stat.funcWriteFile,
"appendFile": funcAppendFile, "appendFile": stat.funcAppendFile,
"renameFile": funcRenameFile, "renameFile": stat.funcRenameFile,
"removeFile": funcRemoveFile, "removeFile": stat.funcRemoveFile,
} }
} }
func funcEnv (name string) string { type state struct {
document *step.Document
}
func (this *state) funcEnv (name string) string {
return os.Getenv(name) return os.Getenv(name)
} }
func funcExists (name string) (bool) { func (this *state) funcExists (name string) (bool, error) {
_, err := os.Stat(name) name, err := this.document.Rel(name)
return err == nil if err != nil { return false, err }
_, err = os.Stat(name)
return err == nil, nil
} }
func funcIsFile (name string) bool { func (this *state) funcIsFile (name string) (bool, error) {
name, err := this.document.Rel(name)
if err != nil { return false, err }
info, err := os.Stat(name) info, err := os.Stat(name)
if err != nil { return false } if err != nil { return false, nil }
return info.Mode().IsRegular() return info.Mode().IsRegular(),nil
} }
func funcIsDir (name string) bool { func (this *state) funcIsDir (name string) (bool, error) {
name, err := this.document.Rel(name)
if err != nil { return false, err }
info, err := os.Stat(name) info, err := os.Stat(name)
if err != nil { return false } if err != nil { return false, nil }
return info.IsDir() return info.IsDir(), nil
} }
func funcStatFile (name string) (FileInfo, error) { func (this *state) funcStatFile (name string) (FileInfo, error) {
name, err := this.document.Rel(name)
if err != nil { return FileInfo { }, err }
info, err := os.Stat(name) info, err := os.Stat(name)
if err != nil { return FileInfo { }, err } if err != nil { return FileInfo { }, err }
return FileInfo { return FileInfo {
@ -74,7 +94,9 @@ func funcStatFile (name string) (FileInfo, error) {
}, nil }, nil
} }
func funcReadFile (name string) (string, error) { func (this *state) funcReadFile (name string) (string, error) {
name, err := this.document.Rel(name)
if err != nil { return "", err }
file, err := os.Open(name) file, err := os.Open(name)
if err != nil { return "", err } if err != nil { return "", err }
defer file.Close() defer file.Close()
@ -83,7 +105,9 @@ func funcReadFile (name string) (string, error) {
return string(buffer), nil return string(buffer), nil
} }
func funcReadDir (name string) ([]string, error) { func (this *state) funcReadDir (name string) ([]string, error) {
name, err := this.document.Rel(name)
if err != nil { return nil, err }
entries, err := os.ReadDir(name) entries, err := os.ReadDir(name)
if err != nil { return nil, err } if err != nil { return nil, err }
names := make([]string, len(entries)) names := make([]string, len(entries))
@ -93,24 +117,32 @@ func funcReadDir (name string) ([]string, error) {
return names, nil return names, nil
} }
func funcWriteFile (name, content string) error { func (this *state) funcWriteFile (name, content string) error {
name, err := this.document.Rel(name)
if err != nil { return err }
file, err := os.Create(name) file, err := os.Create(name)
if err != nil { return err } if err != nil { return err }
_, err = io.WriteString(file, content) _, err = io.WriteString(file, content)
return err return err
} }
func funcAppendFile (name, content string) error { func (this *state) funcAppendFile (name, content string) error {
name, err := this.document.Rel(name)
if err != nil { return err }
file, err := os.OpenFile(name, os.O_CREATE | os.O_WRONLY | os.O_APPEND, 644) file, err := os.OpenFile(name, os.O_CREATE | os.O_WRONLY | os.O_APPEND, 644)
if err != nil { return err } if err != nil { return err }
_, err = io.WriteString(file, content) _, err = io.WriteString(file, content)
return err return err
} }
func funcRenameFile (name, newName string) error { func (this *state) funcRenameFile (name, newName string) error {
name, err := this.document.Rel(name)
if err != nil { return err }
return os.Rename(name, newName) return os.Rename(name, newName)
} }
func funcRemoveFile (name string) error { func (this *state) funcRemoveFile (name string) error {
name, err := this.document.Rel(name)
if err != nil { return err }
return os.Remove(name) return os.Remove(name)
} }