providers/os: use Document.Rel
This commit is contained in:
parent
cc13abd8f8
commit
25541dadfe
@ -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)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user