Cleanup
This commit is contained in:
parent
ea28b5c8cf
commit
25d629af10
124
file.go
124
file.go
@ -2,14 +2,17 @@ package goldsmith
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Prop interface{}
|
type (
|
||||||
type PropMap map[string]Prop
|
Prop any
|
||||||
|
PropMap map[string]Prop
|
||||||
|
)
|
||||||
|
|
||||||
// File represents in-memory or on-disk files in a chain.
|
// File represents in-memory or on-disk files in a chain.
|
||||||
type File struct {
|
type File struct {
|
||||||
@ -25,19 +28,12 @@ type File struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Rename modifies the file path relative to the source directory.
|
// Rename modifies the file path relative to the source directory.
|
||||||
func (self *File) Rename(path string) {
|
func (self *File) Rename(path string) error {
|
||||||
self.relPath = path
|
if filepath.IsAbs(path) {
|
||||||
}
|
return fmt.Errorf("unexpected absolute path: %s", path)
|
||||||
|
|
||||||
func (self *File) Rewrite(reader io.Reader) error {
|
|
||||||
data, err := io.ReadAll(reader)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
self.reader = bytes.NewReader(data)
|
self.relPath = path
|
||||||
self.modTime = time.Now()
|
|
||||||
self.size = int64(len(data))
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,16 +42,16 @@ func (self *File) Path() string {
|
|||||||
return filepath.ToSlash(self.relPath)
|
return filepath.ToSlash(self.relPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Name returns the base name of the file.
|
|
||||||
func (self *File) Name() string {
|
|
||||||
return filepath.Base(self.relPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Dir returns the containing directory of the file.
|
// Dir returns the containing directory of the file.
|
||||||
func (self *File) Dir() string {
|
func (self *File) Dir() string {
|
||||||
return filepath.ToSlash(filepath.Dir(self.relPath))
|
return filepath.ToSlash(filepath.Dir(self.relPath))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Name returns the base name of the file.
|
||||||
|
func (self *File) Name() string {
|
||||||
|
return filepath.Base(self.relPath)
|
||||||
|
}
|
||||||
|
|
||||||
// Ext returns the extension of the file.
|
// Ext returns the extension of the file.
|
||||||
func (self *File) Ext() string {
|
func (self *File) Ext() string {
|
||||||
return filepath.Ext(self.relPath)
|
return filepath.Ext(self.relPath)
|
||||||
@ -102,36 +98,60 @@ func (self *File) Seek(offset int64, whence int) (int64, error) {
|
|||||||
return self.reader.Seek(offset, whence)
|
return self.reader.Seek(offset, whence)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns value for string formatting.
|
// GoString returns value for string formatting.
|
||||||
func (self *File) GoString() string {
|
func (self *File) GoString() string {
|
||||||
return self.relPath
|
return self.relPath
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// RemoveProp deletes the metadata property for the provided name.
|
||||||
|
func (self *File) RemoveProp(name string) {
|
||||||
|
delete(self.props, name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetProp updates the metadata property for the provided name.
|
||||||
func (self *File) SetProp(name string, value Prop) {
|
func (self *File) SetProp(name string, value Prop) {
|
||||||
self.props[name] = value
|
self.props[name] = value
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Prop returns the metadata property for the provided name.
|
||||||
|
func (self *File) Prop(name string) (Prop, bool) {
|
||||||
|
value, ok := self.props[name]
|
||||||
|
return value, ok
|
||||||
|
}
|
||||||
|
|
||||||
|
// PropOrDef returns the metadata property for the provided name or the default.
|
||||||
|
func (self *File) PropOrDef(name string, valueDef Prop) Prop {
|
||||||
|
if value, ok := self.Prop(name); ok {
|
||||||
|
return value
|
||||||
|
}
|
||||||
|
|
||||||
|
return valueDef
|
||||||
|
}
|
||||||
|
|
||||||
|
// Props returns all of the metadata properties.
|
||||||
|
func (self *File) Props() PropMap {
|
||||||
|
return self.props
|
||||||
|
}
|
||||||
|
|
||||||
|
// CopyProps copies all metadata properties from the provided file.
|
||||||
func (self *File) CopyProps(file *File) {
|
func (self *File) CopyProps(file *File) {
|
||||||
for key, value := range file.props {
|
for key, value := range file.props {
|
||||||
self.props[key] = value
|
self.props[key] = value
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *File) Prop(name string) (Prop, bool) {
|
func (self *File) load() error {
|
||||||
value, ok := self.props[name]
|
if self.reader != nil {
|
||||||
return value, ok
|
return nil
|
||||||
}
|
|
||||||
|
|
||||||
func (self *File) Props() PropMap {
|
|
||||||
return self.props
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *File) PropOrDefault(name string, valueDef Prop) Prop {
|
|
||||||
if value, ok := self.Prop(name); ok {
|
|
||||||
return value
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return valueDef
|
data, err := os.ReadFile(self.dataPath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
self.reader = bytes.NewReader(data)
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *File) export(targetDir string) error {
|
func (self *File) export(targetDir string) error {
|
||||||
@ -151,39 +171,17 @@ func (self *File) export(targetDir string) error {
|
|||||||
}
|
}
|
||||||
defer fw.Close()
|
defer fw.Close()
|
||||||
|
|
||||||
if self.reader == nil {
|
if err := self.load(); err != nil {
|
||||||
fr, err := os.Open(self.dataPath)
|
return err
|
||||||
if err != nil {
|
}
|
||||||
return err
|
|
||||||
}
|
if _, err := self.Seek(0, io.SeekStart); err != nil {
|
||||||
defer fr.Close()
|
return err
|
||||||
|
}
|
||||||
if _, err := io.Copy(fw, fr); err != nil {
|
|
||||||
return err
|
if _, err := self.WriteTo(fw); err != nil {
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if _, err := self.Seek(0, io.SeekStart); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, err := self.WriteTo(fw); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *File) load() error {
|
|
||||||
if self.reader != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
data, err := os.ReadFile(self.dataPath)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
self.reader = bytes.NewReader(data)
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,7 @@ func (self *fileImporter) Initialize(context *Context) error {
|
|||||||
|
|
||||||
relPath, err := filepath.Rel(self.sourceDir, path)
|
relPath, err := filepath.Rel(self.sourceDir, path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
file, err := context.CreateFileFromAsset(relPath, path)
|
file, err := context.CreateFileFromAsset(relPath, path)
|
||||||
|
Loading…
Reference in New Issue
Block a user