WIP
This commit is contained in:
parent
ceca011023
commit
3883d1dedc
21
core.go
21
core.go
@ -35,15 +35,14 @@ type stage struct {
|
||||
}
|
||||
|
||||
type goldsmith struct {
|
||||
Context
|
||||
|
||||
stages []stage
|
||||
files chan File
|
||||
wg sync.WaitGroup
|
||||
srcPath, dstPath string
|
||||
stages []stage
|
||||
files chan File
|
||||
wg sync.WaitGroup
|
||||
}
|
||||
|
||||
func NewGoldsmith(srcPath, dstPath string) (Applier, error) {
|
||||
gs := &goldsmith{Context: Context{srcPath, dstPath}}
|
||||
gs := &goldsmith{srcPath: srcPath, dstPath: dstPath}
|
||||
if err := gs.scan(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@ -83,6 +82,14 @@ func (gs *goldsmith) stage() stage {
|
||||
return s
|
||||
}
|
||||
|
||||
func (gs *goldsmith) AbsSrcPath(path string) string {
|
||||
return filepath.Join(gs.srcPath, path)
|
||||
}
|
||||
|
||||
func (gs *goldsmith) AbsDstPath(path string) string {
|
||||
return filepath.Join(gs.dstPath, path)
|
||||
}
|
||||
|
||||
func (gs *goldsmith) Apply(p Processor) Applier {
|
||||
return gs.ApplyTo(p, "*")
|
||||
}
|
||||
@ -92,7 +99,7 @@ func (gs *goldsmith) ApplyTo(p Processor, pattern string) Applier {
|
||||
|
||||
gs.wg.Add(1)
|
||||
go func() {
|
||||
p.ProcessFiles(s.input, s.output)
|
||||
p.Process(gs, s.input, s.output)
|
||||
gs.wg.Done()
|
||||
}()
|
||||
|
||||
|
@ -22,8 +22,9 @@
|
||||
|
||||
package goldsmith
|
||||
|
||||
type Context struct {
|
||||
srcPath, dstPath string
|
||||
type Context interface {
|
||||
AbsSrcPath(path string) string
|
||||
AbsDstPath(path string) string
|
||||
}
|
||||
|
||||
type File struct {
|
||||
@ -32,7 +33,7 @@ type File struct {
|
||||
}
|
||||
|
||||
type Processor interface {
|
||||
ProcessFiles(input chan File, output chan File) error
|
||||
Process(ctx Context, input chan File, output chan File) error
|
||||
}
|
||||
|
||||
type Applier interface {
|
||||
|
Loading…
Reference in New Issue
Block a user